1 | /**************************************************************************** |
2 | ** |
3 | ** Copyright (C) 2016 The Qt Company Ltd. |
4 | ** Contact: https://www.qt.io/licensing/ |
5 | ** |
6 | ** This file is part of the QtSG module of the Qt Toolkit. |
7 | ** |
8 | ** $QT_BEGIN_LICENSE:LGPL$ |
9 | ** Commercial License Usage |
10 | ** Licensees holding valid commercial Qt licenses may use this file in |
11 | ** accordance with the commercial license agreement provided with the |
12 | ** Software or, alternatively, in accordance with the terms contained in |
13 | ** a written agreement between you and The Qt Company. For licensing terms |
14 | ** and conditions see https://www.qt.io/terms-conditions. For further |
15 | ** information use the contact form at https://www.qt.io/contact-us. |
16 | ** |
17 | ** GNU Lesser General Public License Usage |
18 | ** Alternatively, this file may be used under the terms of the GNU Lesser |
19 | ** General Public License version 3 as published by the Free Software |
20 | ** Foundation and appearing in the file LICENSE.LGPL3 included in the |
21 | ** packaging of this file. Please review the following information to |
22 | ** ensure the GNU Lesser General Public License version 3 requirements |
23 | ** will be met: https://www.gnu.org/licenses/lgpl-3.0.html. |
24 | ** |
25 | ** GNU General Public License Usage |
26 | ** Alternatively, this file may be used under the terms of the GNU |
27 | ** General Public License version 2.0 or (at your option) the GNU General |
28 | ** Public license version 3 or any later version approved by the KDE Free |
29 | ** Qt Foundation. The licenses are as published by the Free Software |
30 | ** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3 |
31 | ** included in the packaging of this file. Please review the following |
32 | ** information to ensure the GNU General Public License requirements will |
33 | ** be met: https://www.gnu.org/licenses/gpl-2.0.html and |
34 | ** https://www.gnu.org/licenses/gpl-3.0.html. |
35 | ** |
36 | ** $QT_END_LICENSE$ |
37 | ** |
38 | ****************************************************************************/ |
39 | |
40 | #ifndef QQUICKPINCHAREA_H |
41 | #define QQUICKPINCHAREA_H |
42 | |
43 | // |
44 | // W A R N I N G |
45 | // ------------- |
46 | // |
47 | // This file is not part of the Qt API. It exists purely as an |
48 | // implementation detail. This header file may change from version to |
49 | // version without notice, or even be removed. |
50 | // |
51 | // We mean it. |
52 | // |
53 | |
54 | #include "qquickitem.h" |
55 | |
56 | QT_BEGIN_NAMESPACE |
57 | |
58 | class Q_AUTOTEST_EXPORT QQuickPinch : public QObject |
59 | { |
60 | Q_OBJECT |
61 | |
62 | Q_PROPERTY(QQuickItem *target READ target WRITE setTarget RESET resetTarget NOTIFY targetChanged) |
63 | Q_PROPERTY(qreal minimumScale READ minimumScale WRITE setMinimumScale NOTIFY minimumScaleChanged) |
64 | Q_PROPERTY(qreal maximumScale READ maximumScale WRITE setMaximumScale NOTIFY maximumScaleChanged) |
65 | Q_PROPERTY(qreal minimumRotation READ minimumRotation WRITE setMinimumRotation NOTIFY minimumRotationChanged) |
66 | Q_PROPERTY(qreal maximumRotation READ maximumRotation WRITE setMaximumRotation NOTIFY maximumRotationChanged) |
67 | Q_PROPERTY(Axis dragAxis READ axis WRITE setAxis NOTIFY dragAxisChanged) |
68 | Q_PROPERTY(qreal minimumX READ xmin WRITE setXmin NOTIFY minimumXChanged) |
69 | Q_PROPERTY(qreal maximumX READ xmax WRITE setXmax NOTIFY maximumXChanged) |
70 | Q_PROPERTY(qreal minimumY READ ymin WRITE setYmin NOTIFY minimumYChanged) |
71 | Q_PROPERTY(qreal maximumY READ ymax WRITE setYmax NOTIFY maximumYChanged) |
72 | Q_PROPERTY(bool active READ active NOTIFY activeChanged) |
73 | QML_NAMED_ELEMENT(Pinch) |
74 | |
75 | public: |
76 | QQuickPinch(); |
77 | |
78 | QQuickItem *target() const { return m_target; } |
79 | void setTarget(QQuickItem *target) { |
80 | if (target == m_target) |
81 | return; |
82 | m_target = target; |
83 | Q_EMIT targetChanged(); |
84 | } |
85 | void resetTarget() { |
86 | if (!m_target) |
87 | return; |
88 | m_target = nullptr; |
89 | Q_EMIT targetChanged(); |
90 | } |
91 | |
92 | qreal minimumScale() const { return m_minScale; } |
93 | void setMinimumScale(qreal s) { |
94 | if (s == m_minScale) |
95 | return; |
96 | m_minScale = s; |
97 | Q_EMIT minimumScaleChanged(); |
98 | } |
99 | qreal maximumScale() const { return m_maxScale; } |
100 | void setMaximumScale(qreal s) { |
101 | if (s == m_maxScale) |
102 | return; |
103 | m_maxScale = s; |
104 | Q_EMIT maximumScaleChanged(); |
105 | } |
106 | |
107 | qreal minimumRotation() const { return m_minRotation; } |
108 | void setMinimumRotation(qreal r) { |
109 | if (r == m_minRotation) |
110 | return; |
111 | m_minRotation = r; |
112 | Q_EMIT minimumRotationChanged(); |
113 | } |
114 | qreal maximumRotation() const { return m_maxRotation; } |
115 | void setMaximumRotation(qreal r) { |
116 | if (r == m_maxRotation) |
117 | return; |
118 | m_maxRotation = r; |
119 | Q_EMIT maximumRotationChanged(); |
120 | } |
121 | |
122 | enum Axis { NoDrag=0x00, XAxis=0x01, YAxis=0x02, XAndYAxis=0x03, XandYAxis=XAndYAxis }; |
123 | Q_ENUM(Axis) |
124 | Axis axis() const { return m_axis; } |
125 | void setAxis(Axis a) { |
126 | if (a == m_axis) |
127 | return; |
128 | m_axis = a; |
129 | Q_EMIT dragAxisChanged(); |
130 | } |
131 | |
132 | qreal xmin() const { return m_xmin; } |
133 | void setXmin(qreal x) { |
134 | if (x == m_xmin) |
135 | return; |
136 | m_xmin = x; |
137 | Q_EMIT minimumXChanged(); |
138 | } |
139 | qreal xmax() const { return m_xmax; } |
140 | void setXmax(qreal x) { |
141 | if (x == m_xmax) |
142 | return; |
143 | m_xmax = x; |
144 | Q_EMIT maximumXChanged(); |
145 | } |
146 | qreal ymin() const { return m_ymin; } |
147 | void setYmin(qreal y) { |
148 | if (y == m_ymin) |
149 | return; |
150 | m_ymin = y; |
151 | Q_EMIT minimumYChanged(); |
152 | } |
153 | qreal ymax() const { return m_ymax; } |
154 | void setYmax(qreal y) { |
155 | if (y == m_ymax) |
156 | return; |
157 | m_ymax = y; |
158 | Q_EMIT maximumYChanged(); |
159 | } |
160 | |
161 | bool active() const { return m_active; } |
162 | void setActive(bool a) { |
163 | if (a == m_active) |
164 | return; |
165 | m_active = a; |
166 | Q_EMIT activeChanged(); |
167 | } |
168 | |
169 | Q_SIGNALS: |
170 | void targetChanged(); |
171 | void minimumScaleChanged(); |
172 | void maximumScaleChanged(); |
173 | void minimumRotationChanged(); |
174 | void maximumRotationChanged(); |
175 | void dragAxisChanged(); |
176 | void minimumXChanged(); |
177 | void maximumXChanged(); |
178 | void minimumYChanged(); |
179 | void maximumYChanged(); |
180 | void activeChanged(); |
181 | |
182 | private: |
183 | QQuickItem *m_target; |
184 | qreal m_minScale; |
185 | qreal m_maxScale; |
186 | qreal m_minRotation; |
187 | qreal m_maxRotation; |
188 | Axis m_axis; |
189 | qreal m_xmin; |
190 | qreal m_xmax; |
191 | qreal m_ymin; |
192 | qreal m_ymax; |
193 | bool m_active; |
194 | }; |
195 | |
196 | class Q_AUTOTEST_EXPORT QQuickPinchEvent : public QObject |
197 | { |
198 | Q_OBJECT |
199 | |
200 | Q_PROPERTY(QPointF center READ center) |
201 | Q_PROPERTY(QPointF startCenter READ startCenter) |
202 | Q_PROPERTY(QPointF previousCenter READ previousCenter) |
203 | Q_PROPERTY(qreal scale READ scale) |
204 | Q_PROPERTY(qreal previousScale READ previousScale) |
205 | Q_PROPERTY(qreal angle READ angle) |
206 | Q_PROPERTY(qreal previousAngle READ previousAngle) |
207 | Q_PROPERTY(qreal rotation READ rotation) |
208 | Q_PROPERTY(QPointF point1 READ point1) |
209 | Q_PROPERTY(QPointF startPoint1 READ startPoint1) |
210 | Q_PROPERTY(QPointF point2 READ point2) |
211 | Q_PROPERTY(QPointF startPoint2 READ startPoint2) |
212 | Q_PROPERTY(int pointCount READ pointCount) |
213 | Q_PROPERTY(bool accepted READ accepted WRITE setAccepted) |
214 | QML_ANONYMOUS |
215 | |
216 | public: |
217 | QQuickPinchEvent(QPointF c, qreal s, qreal a, qreal r) |
218 | : QObject(), m_center(c), m_scale(s), m_angle(a), m_rotation(r) |
219 | , m_pointCount(0), m_accepted(true) {} |
220 | |
221 | QPointF center() const { return m_center; } |
222 | QPointF startCenter() const { return m_startCenter; } |
223 | void setStartCenter(QPointF c) { m_startCenter = c; } |
224 | QPointF previousCenter() const { return m_lastCenter; } |
225 | void setPreviousCenter(QPointF c) { m_lastCenter = c; } |
226 | qreal scale() const { return m_scale; } |
227 | qreal previousScale() const { return m_lastScale; } |
228 | void setPreviousScale(qreal s) { m_lastScale = s; } |
229 | qreal angle() const { return m_angle; } |
230 | qreal previousAngle() const { return m_lastAngle; } |
231 | void setPreviousAngle(qreal a) { m_lastAngle = a; } |
232 | qreal rotation() const { return m_rotation; } |
233 | QPointF point1() const { return m_point1; } |
234 | void setPoint1(QPointF p) { m_point1 = p; } |
235 | QPointF startPoint1() const { return m_startPoint1; } |
236 | void setStartPoint1(QPointF p) { m_startPoint1 = p; } |
237 | QPointF point2() const { return m_point2; } |
238 | void setPoint2(QPointF p) { m_point2 = p; } |
239 | QPointF startPoint2() const { return m_startPoint2; } |
240 | void setStartPoint2(QPointF p) { m_startPoint2 = p; } |
241 | int pointCount() const { return m_pointCount; } |
242 | void setPointCount(int count) { m_pointCount = count; } |
243 | |
244 | bool accepted() const { return m_accepted; } |
245 | void setAccepted(bool a) { m_accepted = a; } |
246 | |
247 | private: |
248 | QPointF m_center; |
249 | QPointF m_startCenter; |
250 | QPointF m_lastCenter; |
251 | qreal m_scale; |
252 | qreal m_lastScale; |
253 | qreal m_angle; |
254 | qreal m_lastAngle; |
255 | qreal m_rotation; |
256 | QPointF m_point1; |
257 | QPointF m_point2; |
258 | QPointF m_startPoint1; |
259 | QPointF m_startPoint2; |
260 | int m_pointCount; |
261 | bool m_accepted; |
262 | }; |
263 | |
264 | |
265 | class QQuickMouseEvent; |
266 | class QQuickPinchAreaPrivate; |
267 | class Q_AUTOTEST_EXPORT QQuickPinchArea : public QQuickItem |
268 | { |
269 | Q_OBJECT |
270 | |
271 | Q_PROPERTY(bool enabled READ isEnabled WRITE setEnabled NOTIFY enabledChanged) |
272 | Q_PROPERTY(QQuickPinch *pinch READ pinch CONSTANT) |
273 | QML_NAMED_ELEMENT(PinchArea) |
274 | |
275 | public: |
276 | QQuickPinchArea(QQuickItem *parent=nullptr); |
277 | ~QQuickPinchArea(); |
278 | |
279 | bool isEnabled() const; |
280 | void setEnabled(bool); |
281 | |
282 | QQuickPinch *pinch(); |
283 | |
284 | Q_SIGNALS: |
285 | void enabledChanged(); |
286 | void pinchStarted(QQuickPinchEvent *pinch); |
287 | void pinchUpdated(QQuickPinchEvent *pinch); |
288 | void pinchFinished(QQuickPinchEvent *pinch); |
289 | Q_REVISION(5) void smartZoom(QQuickPinchEvent *pinch); |
290 | |
291 | protected: |
292 | bool childMouseEventFilter(QQuickItem *i, QEvent *e) override; |
293 | void touchEvent(QTouchEvent *event) override; |
294 | |
295 | void geometryChanged(const QRectF &newGeometry, |
296 | const QRectF &oldGeometry) override; |
297 | void itemChange(ItemChange change, const ItemChangeData& value) override; |
298 | bool event(QEvent *) override; |
299 | |
300 | private: |
301 | void clearPinch(); |
302 | void cancelPinch(); |
303 | void updatePinch(); |
304 | void updatePinchTarget(); |
305 | void handlePress(); |
306 | void handleRelease(); |
307 | |
308 | private: |
309 | Q_DISABLE_COPY(QQuickPinchArea) |
310 | Q_DECLARE_PRIVATE(QQuickPinchArea) |
311 | }; |
312 | |
313 | QT_END_NAMESPACE |
314 | |
315 | QML_DECLARE_TYPE(QQuickPinch) |
316 | QML_DECLARE_TYPE(QQuickPinchEvent) |
317 | QML_DECLARE_TYPE(QQuickPinchArea) |
318 | |
319 | #endif // QQUICKPINCHAREA_H |
320 | |
321 | |