aboutsummaryrefslogtreecommitdiffstats
path: root/tests/manual/shadowCasting2/main.qml
blob: b3df7e20480bc7d97dd1f0ab779fe3005d77e211 (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
// Copyright (C) 2023 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only
import QtQuick
import QtQuick3D
import QtQuick3D.Helpers
import QtQuick.Controls
import QtQuick.Layouts

Window {
    width: 640
    height: 480
    visible: true

    View3D {
        id: viewport
        anchors.fill: parent

        environment: SceneEnvironment {
            clearColor: "#d6dbdf"
            backgroundMode: SceneEnvironment.Color
        }

        PerspectiveCamera {
            id: camera
            position: Qt.vector3d(0, 0, 300)
            clipFar: 5000
            clipNear: 1
        }

        DirectionalLight {
            eulerRotation.x: -45
            eulerRotation.y: 45
            castsShadow: lightCastsShadow.checked
            brightness: 1
            shadowFactor: 100
        }

        Model {
            eulerRotation: Qt.vector3d(-45, 0, 0)
            source: "#Rectangle"
            scale: Qt.vector3d(2, 2, 2)
            materials: DefaultMaterial {
                diffuseColor: "green"
            }
            castsShadows: rectangleCastsShadows.checked
            receivesShadows: rectangleReceivesShadows.checked
        }

        Model {
            source: "#Cube"
            scale: Qt.vector3d(1, 1, 1)
            materials: DefaultMaterial {
                diffuseColor: "blue"
            }
            castsShadows: cubeCastsShadows.checked
            receivesShadows: cubeReceivesShadows.checked
        }
    }

    WasdController {
        speed: 2
        controlledObject: camera
        Keys.onPressed: event => {
                            handleKeyPress(event)
                        }
        Keys.onReleased: event => {
                             handleKeyRelease(event)
                         }
    }

    Frame {
        background: Rectangle {
            color: "#c0c0c0"
            border.color: "#202020"
        }
        anchors.top: parent.top
        anchors.left: parent.left
        anchors.margins: 10

        ColumnLayout {
            CheckBox {
                id: lightCastsShadow
                checked: true
                text: qsTr("light castsShadow")
            }
            CheckBox {
                id: cubeCastsShadows
                checked: true
                text: qsTr("cube castsShadows")
            }
            CheckBox {
                id: cubeReceivesShadows
                checked: true
                text: qsTr("cube receivesShadows")
            }
            CheckBox {
                id: rectangleCastsShadows
                checked: true
                text: qsTr("rectangle castsShadows")
            }
            CheckBox {
                id: rectangleReceivesShadows
                checked: true
                text: qsTr("rectangle receivesShadows")
            }
        }
    }
}