blob: 3b52172ad7c6a03d908868c7b81ab39d022a8090 (
plain)
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
|
// Copyright (C) 2019 Klaralvdalens Datakonsult AB (KDAB).
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause
import QtQuick 2.0
import Qt3D.Core 2.9
import Qt3D.Render 2.9
import Qt3D.Input 2.0
import Qt3D.Extras 2.9
import QtQuick.Scene3D 2.0
Item {
id: root
property int _trackingPosition : 0
readonly property int squareSize: 100
Timer {
running: true
interval: 16
repeat: true
onTriggered: {
_trackingPosition += 1
if ((_trackingPosition + squareSize) >= root.width)
_trackingPosition = 0
}
}
// Scene3D + Qt3D content
Scene3D {
id: sceneThreeD
readonly property double halfWidth: width * 0.5
focus: true
anchors.fill: parent
// anchors.margins: -15
// Make sure to define the input aspect if we want to handle inputs
aspects: ["render", "input"]
multisample: false
Entity { // Root
id: sceneRoot
components: [
RenderSettings {
activeFrameGraph: ForwardRenderer {
id: forwardRenderer
camera: planeCamera
clearColor: "yellow"
}
},
// Event Source is the Scene3D in that case
InputSettings { }
]
Camera {
id: planeCamera
left: -sceneThreeD.halfWidth
right: sceneThreeD.halfWidth
bottom: -(sceneThreeD.height * 0.5)
top: (sceneThreeD.height * 0.5)
nearPlane: -100
farPlane: 100
projectionType: CameraLens.OrthographicProjection
position: Qt.vector3d(0, 0, 10)
viewCenter: Qt.vector3d(0, 0, 0)
}
Entity {
id: trackingCube
components: [
CuboidMesh {
xExtent: 100
yExtent: 100
zExtent: 2
},
PhongMaterial {
diffuse: "orange"
ambient: "orange"
},
Transform {
translation: Qt.vector3d(-sceneThreeD.halfWidth + squareSize * 0.5 + _trackingPosition, -50, 0)
}
]
}
}
}
// QtQuick Content
Rectangle {
id: qtQuickTracer
x: _trackingPosition
onXChanged: {
console.info("Tracking position is now:" + _trackingPosition);
}
y: root.height * 0.5 - height
width: squareSize; height: squareSize
color: "red"
//transformOrigin: Item.Center
Text {
color: "white"
text: "Rendered with QtQuick"
anchors.fill: parent
horizontalAlignment: Text.AlignHCenter
verticalAlignment: Text.AlignVCenter
wrapMode: Text.WrapAnywhere
}
Text {
color: "white"
text: "Rendered with Qt3D"
width: parent.width
height: parent.height
anchors.top: parent.bottom
horizontalAlignment: Text.AlignHCenter
verticalAlignment: Text.AlignVCenter
wrapMode: Text.WrapAnywhere
}
Rectangle {
width: 1
height: 200
x: 100
color: "black"
}
}
}
|