File: main.qml

package info (click to toggle)
qt6-quick3d 6.8.2-5
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 140,860 kB
  • sloc: cpp: 380,464; ansic: 36,078; xml: 252; sh: 241; makefile: 29
file content (81 lines) | stat: -rw-r--r-- 2,624 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
// Copyright (C) 2024 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only

import QtQuick
import QtQuick.Controls
import QtQuick.Layouts
import QtQuick3D
import QtQuick3D.Helpers
import QtQuick3D.Xr

XrView {
    id: xrView

    XrErrorDialog { id: err }
    onInitializeFailed: (errorString) => err.run("XRView", errorString)
    referenceSpace: XrView.ReferenceSpaceLocal

    environment: SceneEnvironment {
        clearColor: "black"
        backgroundMode: SceneEnvironment.Color
    }

    XrOrigin {
        objectName: "xrorigin"
        XrController {
            id: leftController
            controller: XrController.ControllerLeft
            Component.onCompleted: handInput.poseSpace = XrHandInput.AimPose
            Lazer {
                enableBeam: true
            }
            Node {
                y: rect.height
                x: -rect.width / 2
                Rectangle {
                    id: rect
                    opacity: 0.7
                    width: uiLayout.implicitWidth + 4
                    height: uiLayout.implicitHeight + 4
                    color: "white"
                    radius: 2
                    ColumnLayout {
                        id: uiLayout
                        spacing: 0
                        anchors.fill: parent
                        anchors.margins: 2
                        Text {
                            text: xrView.runtimeInfo.runtimeName + " " + xrView.runtimeInfo.runtimeVersion + "\n" + xrView.runtimeInfo.graphicsApiName
                            font.pixelSize: 2
                            color: "black"
                        }
                        Text {
                            visible: xrView.multiViewRenderingEnabled
                            text: "Multiview rendering enabled"
                            font.pixelSize: 2
                            color: "green"
                        }
                    }
                }
            }
        }
        XrController {
            id: rightController
            controller: XrController.ControllerRight
            Component.onCompleted: handInput.poseSpace = XrHandInput.AimPose
            ActionMapper { }
            Lazer {
                enableBeam: true
            }
        }
    }

    XrVirtualMouse {
        view: xrView
        source: rightController
        enabled: true
        leftMouseButton: rightController.actionMapper.triggerPressed
        rightMouseButton: rightController.actionMapper.button1Pressed
        middleMouseButton: rightController.actionMapper.button2Pressed
    }
}