summaryrefslogtreecommitdiffstats
path: root/tests/manual/qardboard/QardboardCamera.qml
blob: f20a1807871bf4eb944737205fb8ab246dfad820 (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
// Copyright (C) 2017 Klaralvdalens Datakonsult AB (KDAB).
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only

import Qt3D.Core 2.0
import Qt3D.Render 2.0
import Qardboard 1.0

Entity {
    id: root
    property real convergence: 2000.0
    property real eyeSeparation: 35.0
    property real aspectRatio: _window.width / _window.height
    property real fieldOfView: 60.0
    property real nearPlane: 1.
    property real farPlane: 1000.0

    property vector3d position: Qt.vector3d(0.0, 0.0, 0.0)
    property vector3d viewDirection: Qt.vector3d(0.0, 0.0, 1.0)
    property vector3d viewUp: Qt.vector3d(0.0, 1.0, 0.0)
    property alias viewMatrix: eyeTransform.matrix

    readonly property real _fov2: Math.tan(fieldOfView * Math.PI / 180 * 0.5)
    readonly property real top: nearPlane * _fov2
    readonly property real a: aspectRatio * _fov2 * convergence

    DeviceOrientation {
        id: orientation
        enabled: true
    }

    CameraLens {
        id: leftEyeLens
        projectionType: CameraLens.FrustumProjection
        nearPlane : root.nearPlane
        farPlane : root.farPlane
        left: -(a - eyeSeparation * 0.5) * nearPlane / convergence
        right: (a + eyeSeparation * 0.5) * nearPlane / convergence
        top: root.top
        bottom: -root.top
    }

    CameraLens {
        id: rightEyeLens
        projectionType: CameraLens.FrustumProjection
        nearPlane : root.nearPlane
        farPlane : root.farPlane
        left: -(a + eyeSeparation * 0.5) * nearPlane / convergence
        right: (a - eyeSeparation * 0.5) * nearPlane / convergence
        top: root.top
        bottom: -root.top
    }

    Transform {
        id: eyeTransform

        function computeMatrix(roll, pitch, yaw) {
            var n = Qt.matrix4x4()
            n.rotate(-roll, Qt.vector3d(1, 0, 0))
            n.rotate(yaw, Qt.vector3d(0, 1, 0))
            var vd = n.times(stereoCamera.viewDirection)
            var vu = n.times(stereoCamera.viewUp)
            var vc = stereoCamera.position.minus(vd)

            var m = Qt.matrix4x4();
            m.translate(stereoCamera.position)
            var zAxis = stereoCamera.position.minus(vc).normalized()
            var xAxis = vu.crossProduct(zAxis).normalized();
            var yAxis = zAxis.crossProduct(xAxis);
            var r = Qt.matrix4x4(xAxis.x, yAxis.x, zAxis.x, 0,
                                 xAxis.y, yAxis.y, zAxis.y, 0,
                                 xAxis.z, yAxis.z, zAxis.z, 0,
                                 0, 0, 0, 1)
            return m.times(r);
        }

        matrix: computeMatrix(orientation.roll, orientation.pitch, orientation.yaw)
    }

    components: [ eyeTransform ]

    property Entity leftCamera: Entity {
        components: [ leftEyeLens ]
    }

    property Entity rightCamera: Entity {
        id: rightCameraEntity
        components: [ rightEyeLens ]
    }
}