source: trunk/examples/declarative/touchinteraction/mousearea/mousearea-example.qml

Last change on this file was 846, checked in by Dmitry A. Kuminov, 15 years ago

trunk: Merged in qt 4.7.2 sources from branches/vendor/nokia/qt.

File size: 4.3 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
4** All rights reserved.
5** Contact: Nokia Corporation (qt-info@nokia.com)
6**
7** This file is part of the examples of the Qt Toolkit.
8**
9** $QT_BEGIN_LICENSE:BSD$
10** You may use this file under the terms of the BSD license as follows:
11**
12** "Redistribution and use in source and binary forms, with or without
13** modification, are permitted provided that the following conditions are
14** met:
15** * Redistributions of source code must retain the above copyright
16** notice, this list of conditions and the following disclaimer.
17** * Redistributions in binary form must reproduce the above copyright
18** notice, this list of conditions and the following disclaimer in
19** the documentation and/or other materials provided with the
20** distribution.
21** * Neither the name of Nokia Corporation and its Subsidiary(-ies) nor
22** the names of its contributors may be used to endorse or promote
23** products derived from this software without specific prior written
24** permission.
25**
26** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
27** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
28** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
29** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
30** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
31** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
32** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
33** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
34** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
35** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
36** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
37** $QT_END_LICENSE$
38**
39****************************************************************************/
40
41import QtQuick 1.0
42
43Rectangle {
44 id: box
45 width: 350; height: 250
46
47 Rectangle {
48 id: redSquare
49 width: 80; height: 80
50 anchors.top: parent.top; anchors.left: parent.left; anchors.margins: 10
51 color: "red"
52
53 Text { text: "Click"; font.pixelSize: 16; anchors.centerIn: parent }
54
55 MouseArea {
56 anchors.fill: parent
57 hoverEnabled: true
58 acceptedButtons: Qt.LeftButton | Qt.RightButton
59
60 onEntered: info.text = 'Entered'
61 onExited: info.text = 'Exited (pressed=' + pressed + ')'
62
63 onPressed: {
64 info.text = 'Pressed (button=' + (mouse.button == Qt.RightButton ? 'right' : 'left')
65 + ' shift=' + (mouse.modifiers & Qt.ShiftModifier ? 'true' : 'false') + ')'
66 var posInBox = redSquare.mapToItem(box, mouse.x, mouse.y)
67 posInfo.text = + mouse.x + ',' + mouse.y + ' in square'
68 + ' (' + posInBox.x + ',' + posInBox.y + ' in window)'
69 }
70
71 onReleased: {
72 info.text = 'Released (isClick=' + mouse.isClick + ' wasHeld=' + mouse.wasHeld + ')'
73 posInfo.text = ''
74 }
75
76 onPressAndHold: info.text = 'Press and hold'
77 onClicked: info.text = 'Clicked (wasHeld=' + mouse.wasHeld + ')'
78 onDoubleClicked: info.text = 'Double clicked'
79 }
80 }
81
82 Rectangle {
83 id: blueSquare
84 width: 80; height: 80
85 x: box.width - width - 10; y: 10 // making this item draggable, so don't use anchors
86 color: "blue"
87
88 Text { text: "Drag"; font.pixelSize: 16; color: "white"; anchors.centerIn: parent }
89
90 MouseArea {
91 anchors.fill: parent
92 drag.target: blueSquare
93 drag.axis: Drag.XandYAxis
94 drag.minimumX: 0
95 drag.maximumX: box.width - parent.width
96 drag.minimumY: 0
97 drag.maximumY: box.height - parent.width
98 }
99 }
100
101 Text {
102 id: info
103 anchors.bottom: posInfo.top; anchors.horizontalCenter: parent.horizontalCenter; anchors.margins: 30
104
105 onTextChanged: console.log(text)
106 }
107
108 Text {
109 id: posInfo
110 anchors.bottom: parent.bottom; anchors.horizontalCenter: parent.horizontalCenter; anchors.margins: 30
111 }
112}
Note: See TracBrowser for help on using the repository browser.