Qt Quick 3D - XR Simple Example
Demonstrates setting up a simple VR scene with Qt Quick 3D XR.
This example gives an introductory overview of the basic Qt Quick 3D Xr features.
The main difference when writing an XR application is that the root item of our main.qml is an XrView instead of a Window with a View3D:
import QtQuick3D import QtQuick3D.Xr XrView { id: xrView XrErrorDialog { id: err } onInitializeFailed: (errorString) => err.run("XRView", errorString) referenceSpace: XrView.ReferenceSpaceLocalFloor
The XrView contains the 3D scene, just like a View3D. In this example we add an XrErrorDialog that will show an error dialog if we get an error initializing the VR headset when streaming from a desktop PC. We also specify that the reference frame for this application is measured from the floor of the room where the user is located. That is, the floor will be at y = 0
.
The origin of the reference frame is defined by the XrOrigin:
xrOrigin: theOrigin XrOrigin { id: theOrigin XrController { controller: XrController.ControllerLeft poseSpace: XrController.AimPose CubeModel { color: "blue" } } XrController { controller: XrController.ControllerRight poseSpace: XrController.AimPose CubeModel { color: "red" } } }
In this example we add two XrController items, one for each hand. They will track the position and orientation of the user's hands. Since XrController is a Node, any children will automatically follow the hand movements. In this case, we use a simple model of a cube to visualize the controller's position.
The rest of main.qml is a normal Qt Quick 3D scene.
© 2025 The Qt Company Ltd. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd. in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.