summaryrefslogtreecommitdiffstats
path: root/examples/declarative/mousearea/mouse.qml
blob: 06134b76cf5b8b0bc56ead8381cdf5554f8fa1ac (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
import Qt 4.7

Rectangle {
    width: 200; height: 200

    Rectangle {
        width: 50; height: 50
        color: "red"

        Text { text: "Click"; anchors.centerIn: parent }

        MouseArea {
            anchors.fill: parent
            hoverEnabled: true
            acceptedButtons: Qt.LeftButton | Qt.RightButton

            onPressed: console.log('press (x: ' + mouse.x + ' y: ' + mouse.y + ' button: ' + (mouse.button == Qt.RightButton ? 'right' : 'left') + ' Shift: ' + (mouse.modifiers & Qt.ShiftModifier ? 'true' : 'false') + ')') 
            onReleased: console.log('release (x: ' + mouse.x + ' y: ' + mouse.y + ' isClick: ' + mouse.isClick + ' wasHeld: ' + mouse.wasHeld + ')') 
            onClicked: console.log('click (x: ' + mouse.x + ' y: ' + mouse.y + ' wasHeld: ' + mouse.wasHeld + ')')
            onDoubleClicked: console.log('double click (x: ' + mouse.x + ' y: ' + mouse.y + ')')
            onPressAndHold: console.log('press and hold')
            onEntered: console.log('entered ' + pressed)
            onExited: console.log('exited ' + pressed)
        }
    }

    Rectangle {
        y: 100; width: 50; height: 50
        color: "blue"

        Text { text: "Drag"; anchors.centerIn: parent }

        MouseArea {
            anchors.fill: parent
            drag.target: parent
            drag.axis: Drag.XAxis
            drag.minimumX: 0
            drag.maximumX: 150

            onPressed: console.log('press')
            onReleased: console.log('release (isClick: ' + mouse.isClick + ') (wasHeld: ' + mouse.wasHeld + ')')
            onClicked: console.log('click' + '(wasHeld: ' + mouse.wasHeld + ')')
            onDoubleClicked: console.log('double click')
            onPressAndHold: console.log('press and hold')
        }
    }
}