annotate demos/shared/hoverpoints.d @ 162:4bbd9f3d9add

a few fixes
author mwarning
date Wed, 17 Jun 2009 22:40:56 +0000
parents 691e68637348
children 5bcfe9e7db7f 96a75b1e5b26
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
41
691e68637348 non-working deform example
maxter
parents:
diff changeset
1 /****************************************************************************
691e68637348 non-working deform example
maxter
parents:
diff changeset
2 **
691e68637348 non-working deform example
maxter
parents:
diff changeset
3 ** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
691e68637348 non-working deform example
maxter
parents:
diff changeset
4 ** Contact: Qt Software Information (qt-info@nokia.com)
691e68637348 non-working deform example
maxter
parents:
diff changeset
5 **
691e68637348 non-working deform example
maxter
parents:
diff changeset
6 ** This file is part of the demonstration applications of the Qt Toolkit.
691e68637348 non-working deform example
maxter
parents:
diff changeset
7 **
691e68637348 non-working deform example
maxter
parents:
diff changeset
8 ** $QT_BEGIN_LICENSE:LGPL$
691e68637348 non-working deform example
maxter
parents:
diff changeset
9 ** Commercial Usage
691e68637348 non-working deform example
maxter
parents:
diff changeset
10 ** Licensees holding valid Qt Commercial licenses may use this file in
691e68637348 non-working deform example
maxter
parents:
diff changeset
11 ** accordance with the Qt Commercial License Agreement provided with the
691e68637348 non-working deform example
maxter
parents:
diff changeset
12 ** Software or, alternatively, in accordance with the terms contained in
691e68637348 non-working deform example
maxter
parents:
diff changeset
13 ** a written agreement between you and Nokia.
691e68637348 non-working deform example
maxter
parents:
diff changeset
14 **
691e68637348 non-working deform example
maxter
parents:
diff changeset
15 ** GNU Lesser General Public License Usage
691e68637348 non-working deform example
maxter
parents:
diff changeset
16 ** Alternatively, this file may be used under the terms of the GNU Lesser
691e68637348 non-working deform example
maxter
parents:
diff changeset
17 ** General Public License version 2.1 as published by the Free Software
691e68637348 non-working deform example
maxter
parents:
diff changeset
18 ** Foundation and appearing in the file LICENSE.LGPL included in the
691e68637348 non-working deform example
maxter
parents:
diff changeset
19 ** packaging of this file. Please review the following information to
691e68637348 non-working deform example
maxter
parents:
diff changeset
20 ** ensure the GNU Lesser General Public License version 2.1 requirements
691e68637348 non-working deform example
maxter
parents:
diff changeset
21 ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
691e68637348 non-working deform example
maxter
parents:
diff changeset
22 **
691e68637348 non-working deform example
maxter
parents:
diff changeset
23 ** In addition, as a special exception, Nokia gives you certain
691e68637348 non-working deform example
maxter
parents:
diff changeset
24 ** additional rights. These rights are described in the Nokia Qt LGPL
691e68637348 non-working deform example
maxter
parents:
diff changeset
25 ** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
691e68637348 non-working deform example
maxter
parents:
diff changeset
26 ** package.
691e68637348 non-working deform example
maxter
parents:
diff changeset
27 **
691e68637348 non-working deform example
maxter
parents:
diff changeset
28 ** GNU General Public License Usage
691e68637348 non-working deform example
maxter
parents:
diff changeset
29 ** Alternatively, this file may be used under the terms of the GNU
691e68637348 non-working deform example
maxter
parents:
diff changeset
30 ** General Public License version 3.0 as published by the Free Software
691e68637348 non-working deform example
maxter
parents:
diff changeset
31 ** Foundation and appearing in the file LICENSE.GPL included in the
691e68637348 non-working deform example
maxter
parents:
diff changeset
32 ** packaging of this file. Please review the following information to
691e68637348 non-working deform example
maxter
parents:
diff changeset
33 ** ensure the GNU General Public License version 3.0 requirements will be
691e68637348 non-working deform example
maxter
parents:
diff changeset
34 ** met: http://www.gnu.org/copyleft/gpl.html.
691e68637348 non-working deform example
maxter
parents:
diff changeset
35 **
691e68637348 non-working deform example
maxter
parents:
diff changeset
36 ** If you are unsure which license is appropriate for your use, please
691e68637348 non-working deform example
maxter
parents:
diff changeset
37 ** contact the sales department at qt-sales@nokia.com.
691e68637348 non-working deform example
maxter
parents:
diff changeset
38 ** $QT_END_LICENSE$
691e68637348 non-working deform example
maxter
parents:
diff changeset
39 **
691e68637348 non-working deform example
maxter
parents:
diff changeset
40 ****************************************************************************/
162
4bbd9f3d9add a few fixes
mwarning
parents: 41
diff changeset
41 module hoverpoints;
41
691e68637348 non-working deform example
maxter
parents:
diff changeset
42
691e68637348 non-working deform example
maxter
parents:
diff changeset
43 version (QT_OPENGL_SUPPORT)
691e68637348 non-working deform example
maxter
parents:
diff changeset
44 import qt.opengl.QGLWidget;
691e68637348 non-working deform example
maxter
parents:
diff changeset
45
691e68637348 non-working deform example
maxter
parents:
diff changeset
46 version (D_Version2) {}
691e68637348 non-working deform example
maxter
parents:
diff changeset
47 else
691e68637348 non-working deform example
maxter
parents:
diff changeset
48 import tango.core.Array : sort;
691e68637348 non-working deform example
maxter
parents:
diff changeset
49
691e68637348 non-working deform example
maxter
parents:
diff changeset
50 import
691e68637348 non-working deform example
maxter
parents:
diff changeset
51 qt.gui.QWidget,
691e68637348 non-working deform example
maxter
parents:
diff changeset
52 qt.qtd.Array,
691e68637348 non-working deform example
maxter
parents:
diff changeset
53 arthurwidgets;
691e68637348 non-working deform example
maxter
parents:
diff changeset
54
691e68637348 non-working deform example
maxter
parents:
diff changeset
55 final class HoverPoints : QObject
691e68637348 non-working deform example
maxter
parents:
diff changeset
56 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
57 public:
691e68637348 non-working deform example
maxter
parents:
diff changeset
58 enum PointShape {
691e68637348 non-working deform example
maxter
parents:
diff changeset
59 CircleShape,
691e68637348 non-working deform example
maxter
parents:
diff changeset
60 RectangleShape
691e68637348 non-working deform example
maxter
parents:
diff changeset
61 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
62
691e68637348 non-working deform example
maxter
parents:
diff changeset
63 enum LockType {
691e68637348 non-working deform example
maxter
parents:
diff changeset
64 LockToLeft = 0x01,
691e68637348 non-working deform example
maxter
parents:
diff changeset
65 LockToRight = 0x02,
691e68637348 non-working deform example
maxter
parents:
diff changeset
66 LockToTop = 0x04,
691e68637348 non-working deform example
maxter
parents:
diff changeset
67 LockToBottom = 0x08
691e68637348 non-working deform example
maxter
parents:
diff changeset
68 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
69
691e68637348 non-working deform example
maxter
parents:
diff changeset
70 enum SortType {
691e68637348 non-working deform example
maxter
parents:
diff changeset
71 NoSort,
691e68637348 non-working deform example
maxter
parents:
diff changeset
72 XSort,
691e68637348 non-working deform example
maxter
parents:
diff changeset
73 YSort
691e68637348 non-working deform example
maxter
parents:
diff changeset
74 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
75
691e68637348 non-working deform example
maxter
parents:
diff changeset
76 enum ConnectionType {
691e68637348 non-working deform example
maxter
parents:
diff changeset
77 NoConnection,
691e68637348 non-working deform example
maxter
parents:
diff changeset
78 LineConnection,
691e68637348 non-working deform example
maxter
parents:
diff changeset
79 CurveConnection
691e68637348 non-working deform example
maxter
parents:
diff changeset
80 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
81
691e68637348 non-working deform example
maxter
parents:
diff changeset
82 private:
691e68637348 non-working deform example
maxter
parents:
diff changeset
83 QWidget m_widget;
691e68637348 non-working deform example
maxter
parents:
diff changeset
84
691e68637348 non-working deform example
maxter
parents:
diff changeset
85 QPolygonF m_points;
691e68637348 non-working deform example
maxter
parents:
diff changeset
86 QRectF m_bounds;
691e68637348 non-working deform example
maxter
parents:
diff changeset
87 PointShape m_shape;
691e68637348 non-working deform example
maxter
parents:
diff changeset
88 SortType m_sortType;
691e68637348 non-working deform example
maxter
parents:
diff changeset
89 ConnectionType m_connectionType;
691e68637348 non-working deform example
maxter
parents:
diff changeset
90
691e68637348 non-working deform example
maxter
parents:
diff changeset
91 uint[] m_locks;
691e68637348 non-working deform example
maxter
parents:
diff changeset
92
691e68637348 non-working deform example
maxter
parents:
diff changeset
93 QSizeF m_pointSize;
691e68637348 non-working deform example
maxter
parents:
diff changeset
94 int m_currentIndex;
691e68637348 non-working deform example
maxter
parents:
diff changeset
95 bool m_editable;
691e68637348 non-working deform example
maxter
parents:
diff changeset
96 bool m_enabled;
691e68637348 non-working deform example
maxter
parents:
diff changeset
97
691e68637348 non-working deform example
maxter
parents:
diff changeset
98 QPen m_pointPen;
691e68637348 non-working deform example
maxter
parents:
diff changeset
99 QBrush m_pointBrush;
691e68637348 non-working deform example
maxter
parents:
diff changeset
100 QPen m_connectionPen;
691e68637348 non-working deform example
maxter
parents:
diff changeset
101
691e68637348 non-working deform example
maxter
parents:
diff changeset
102 public:
691e68637348 non-working deform example
maxter
parents:
diff changeset
103 mixin Signal!("pointsChanged", QPolygonF /*points*/);
691e68637348 non-working deform example
maxter
parents:
diff changeset
104
691e68637348 non-working deform example
maxter
parents:
diff changeset
105 this(QWidget widget, PointShape shape)
691e68637348 non-working deform example
maxter
parents:
diff changeset
106 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
107 super(widget);
691e68637348 non-working deform example
maxter
parents:
diff changeset
108
691e68637348 non-working deform example
maxter
parents:
diff changeset
109 m_widget = widget;
691e68637348 non-working deform example
maxter
parents:
diff changeset
110 widget.installEventFilter(this);
691e68637348 non-working deform example
maxter
parents:
diff changeset
111
691e68637348 non-working deform example
maxter
parents:
diff changeset
112 m_connectionType = ConnectionType.CurveConnection;
691e68637348 non-working deform example
maxter
parents:
diff changeset
113 m_sortType = SortType.NoSort;
691e68637348 non-working deform example
maxter
parents:
diff changeset
114 m_shape = shape;
691e68637348 non-working deform example
maxter
parents:
diff changeset
115 m_pointPen = new QPen(new QBrush(new QColor(255, 255, 255, 191)), 1);
691e68637348 non-working deform example
maxter
parents:
diff changeset
116 m_connectionPen = new QPen(new QBrush(new QColor(255, 255, 255, 127)), 2);
691e68637348 non-working deform example
maxter
parents:
diff changeset
117 m_pointBrush = new QBrush(new QColor(191, 191, 191, 127));
691e68637348 non-working deform example
maxter
parents:
diff changeset
118 m_pointSize = QSizeF(11, 11);
691e68637348 non-working deform example
maxter
parents:
diff changeset
119 m_currentIndex = -1;
691e68637348 non-working deform example
maxter
parents:
diff changeset
120 m_editable = true;
691e68637348 non-working deform example
maxter
parents:
diff changeset
121 m_enabled = true;
691e68637348 non-working deform example
maxter
parents:
diff changeset
122
691e68637348 non-working deform example
maxter
parents:
diff changeset
123 pointsChanged.connect(&m_widget.update);
691e68637348 non-working deform example
maxter
parents:
diff changeset
124 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
125
691e68637348 non-working deform example
maxter
parents:
diff changeset
126 void setBoundingRect(QRectF boundingRect) { m_bounds = boundingRect; }
691e68637348 non-working deform example
maxter
parents:
diff changeset
127
691e68637348 non-working deform example
maxter
parents:
diff changeset
128
691e68637348 non-working deform example
maxter
parents:
diff changeset
129 QRectF pointBoundingRect(int i)
691e68637348 non-working deform example
maxter
parents:
diff changeset
130 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
131 QPointF p = m_points.at(i);
691e68637348 non-working deform example
maxter
parents:
diff changeset
132 qreal w = m_pointSize.width();
691e68637348 non-working deform example
maxter
parents:
diff changeset
133 qreal h = m_pointSize.height();
691e68637348 non-working deform example
maxter
parents:
diff changeset
134 qreal x = p.x() - w / 2;
691e68637348 non-working deform example
maxter
parents:
diff changeset
135 qreal y = p.y() - h / 2;
691e68637348 non-working deform example
maxter
parents:
diff changeset
136 return new QRectF(x, y, w, h);
691e68637348 non-working deform example
maxter
parents:
diff changeset
137 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
138
691e68637348 non-working deform example
maxter
parents:
diff changeset
139 QRectF boundingRect()
691e68637348 non-working deform example
maxter
parents:
diff changeset
140 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
141 if (m_bounds.isEmpty())
691e68637348 non-working deform example
maxter
parents:
diff changeset
142 return new QRectF(m_widget.rect());
691e68637348 non-working deform example
maxter
parents:
diff changeset
143 else
691e68637348 non-working deform example
maxter
parents:
diff changeset
144 return m_bounds;
691e68637348 non-working deform example
maxter
parents:
diff changeset
145 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
146
691e68637348 non-working deform example
maxter
parents:
diff changeset
147 QPolygonF points() { return m_points; }
691e68637348 non-working deform example
maxter
parents:
diff changeset
148
691e68637348 non-working deform example
maxter
parents:
diff changeset
149 QSizeF pointSize() { return m_pointSize; }
691e68637348 non-working deform example
maxter
parents:
diff changeset
150 void setPointSize(QSizeF size) { m_pointSize = size; }
691e68637348 non-working deform example
maxter
parents:
diff changeset
151
691e68637348 non-working deform example
maxter
parents:
diff changeset
152 SortType sortType() { return m_sortType; }
691e68637348 non-working deform example
maxter
parents:
diff changeset
153 void setSortType(SortType sortType) { m_sortType = sortType; }
691e68637348 non-working deform example
maxter
parents:
diff changeset
154
691e68637348 non-working deform example
maxter
parents:
diff changeset
155 ConnectionType connectionType() { return m_connectionType; }
691e68637348 non-working deform example
maxter
parents:
diff changeset
156 void setConnectionType(ConnectionType connectionType) { m_connectionType = connectionType; }
691e68637348 non-working deform example
maxter
parents:
diff changeset
157
691e68637348 non-working deform example
maxter
parents:
diff changeset
158 void setConnectionPen(QPen pen) { m_connectionPen = pen; }
691e68637348 non-working deform example
maxter
parents:
diff changeset
159 void setShapePen(QPen pen) { m_pointPen = pen; }
691e68637348 non-working deform example
maxter
parents:
diff changeset
160 void setShapeBrush(QBrush brush) { m_pointBrush = brush; }
691e68637348 non-working deform example
maxter
parents:
diff changeset
161
691e68637348 non-working deform example
maxter
parents:
diff changeset
162 void setPointLock(int pos, LockType lock) { m_locks[pos] = lock; }
691e68637348 non-working deform example
maxter
parents:
diff changeset
163
691e68637348 non-working deform example
maxter
parents:
diff changeset
164 void setEditable(bool editable) { m_editable = editable; }
691e68637348 non-working deform example
maxter
parents:
diff changeset
165 bool editable() { return m_editable; }
691e68637348 non-working deform example
maxter
parents:
diff changeset
166
691e68637348 non-working deform example
maxter
parents:
diff changeset
167 void setEnabled(bool enabled)
691e68637348 non-working deform example
maxter
parents:
diff changeset
168 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
169 if (m_enabled != enabled) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
170 m_enabled = enabled;
691e68637348 non-working deform example
maxter
parents:
diff changeset
171 m_widget.update();
691e68637348 non-working deform example
maxter
parents:
diff changeset
172 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
173 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
174
691e68637348 non-working deform example
maxter
parents:
diff changeset
175
691e68637348 non-working deform example
maxter
parents:
diff changeset
176 override bool eventFilter(QObject object, QEvent event)
691e68637348 non-working deform example
maxter
parents:
diff changeset
177 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
178 if ((object == m_widget) && m_enabled) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
179 switch (event.type()) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
180
691e68637348 non-working deform example
maxter
parents:
diff changeset
181 case QEvent.MouseButtonPress:
691e68637348 non-working deform example
maxter
parents:
diff changeset
182 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
183 QMouseEvent me = cast(QMouseEvent) event;
691e68637348 non-working deform example
maxter
parents:
diff changeset
184
691e68637348 non-working deform example
maxter
parents:
diff changeset
185 QPointF clickPos = me.pos();
691e68637348 non-working deform example
maxter
parents:
diff changeset
186 int index = -1;
691e68637348 non-working deform example
maxter
parents:
diff changeset
187 for (int i=0; i<m_points.size(); ++i) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
188 auto path = new QPainterPath;
691e68637348 non-working deform example
maxter
parents:
diff changeset
189 if (m_shape == PointShape.CircleShape)
691e68637348 non-working deform example
maxter
parents:
diff changeset
190 path.addEllipse(pointBoundingRect(i));
691e68637348 non-working deform example
maxter
parents:
diff changeset
191 else
691e68637348 non-working deform example
maxter
parents:
diff changeset
192 path.addRect(pointBoundingRect(i));
691e68637348 non-working deform example
maxter
parents:
diff changeset
193
691e68637348 non-working deform example
maxter
parents:
diff changeset
194 if (path.contains(clickPos)) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
195 index = i;
691e68637348 non-working deform example
maxter
parents:
diff changeset
196 break;
691e68637348 non-working deform example
maxter
parents:
diff changeset
197 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
198 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
199
691e68637348 non-working deform example
maxter
parents:
diff changeset
200 if (me.button() == Qt.LeftButton) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
201 if (index == -1) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
202 if (!m_editable)
691e68637348 non-working deform example
maxter
parents:
diff changeset
203 return false;
691e68637348 non-working deform example
maxter
parents:
diff changeset
204 int pos = 0;
691e68637348 non-working deform example
maxter
parents:
diff changeset
205 // Insert sort for x or y
691e68637348 non-working deform example
maxter
parents:
diff changeset
206 if (m_sortType == SortType.XSort) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
207 for (int i=0; i<m_points.size(); ++i)
691e68637348 non-working deform example
maxter
parents:
diff changeset
208 if (m_points.at(i).x() > clickPos.x()) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
209 pos = i;
691e68637348 non-working deform example
maxter
parents:
diff changeset
210 break;
691e68637348 non-working deform example
maxter
parents:
diff changeset
211 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
212 } else if (m_sortType == SortType.YSort) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
213 for (int i=0; i<m_points.size(); ++i)
691e68637348 non-working deform example
maxter
parents:
diff changeset
214 if (m_points.at(i).y() > clickPos.y()) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
215 pos = i;
691e68637348 non-working deform example
maxter
parents:
diff changeset
216 break;
691e68637348 non-working deform example
maxter
parents:
diff changeset
217 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
218 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
219
691e68637348 non-working deform example
maxter
parents:
diff changeset
220 // TODO: implement QPoligon(F).insert
691e68637348 non-working deform example
maxter
parents:
diff changeset
221 auto tmpPoints = m_points.toList;
691e68637348 non-working deform example
maxter
parents:
diff changeset
222 tmpPoints.insert(pos, clickPos);
691e68637348 non-working deform example
maxter
parents:
diff changeset
223 m_points = new QPolygonF(tmpPoints);
691e68637348 non-working deform example
maxter
parents:
diff changeset
224
691e68637348 non-working deform example
maxter
parents:
diff changeset
225 m_locks.insert(pos, 0u);
691e68637348 non-working deform example
maxter
parents:
diff changeset
226 m_currentIndex = pos;
691e68637348 non-working deform example
maxter
parents:
diff changeset
227 firePointChange();
691e68637348 non-working deform example
maxter
parents:
diff changeset
228 } else {
691e68637348 non-working deform example
maxter
parents:
diff changeset
229 m_currentIndex = index;
691e68637348 non-working deform example
maxter
parents:
diff changeset
230 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
231 return true;
691e68637348 non-working deform example
maxter
parents:
diff changeset
232
691e68637348 non-working deform example
maxter
parents:
diff changeset
233 } else if (me.button() == Qt.RightButton) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
234 if ((index >= 0) && m_editable) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
235 if (m_locks[index] == 0) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
236 m_locks.removeAt(index);
691e68637348 non-working deform example
maxter
parents:
diff changeset
237 m_points.remove(index);
691e68637348 non-working deform example
maxter
parents:
diff changeset
238 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
239 firePointChange();
691e68637348 non-working deform example
maxter
parents:
diff changeset
240 return true;
691e68637348 non-working deform example
maxter
parents:
diff changeset
241 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
242 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
243
691e68637348 non-working deform example
maxter
parents:
diff changeset
244 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
245 break;
691e68637348 non-working deform example
maxter
parents:
diff changeset
246
691e68637348 non-working deform example
maxter
parents:
diff changeset
247 case QEvent.MouseButtonRelease:
691e68637348 non-working deform example
maxter
parents:
diff changeset
248 m_currentIndex = -1;
691e68637348 non-working deform example
maxter
parents:
diff changeset
249 break;
691e68637348 non-working deform example
maxter
parents:
diff changeset
250
691e68637348 non-working deform example
maxter
parents:
diff changeset
251 case QEvent.MouseMove:
691e68637348 non-working deform example
maxter
parents:
diff changeset
252 if (m_currentIndex >= 0)
691e68637348 non-working deform example
maxter
parents:
diff changeset
253 movePoint(m_currentIndex, QPointF((cast(QMouseEvent)event).pos));
691e68637348 non-working deform example
maxter
parents:
diff changeset
254 break;
691e68637348 non-working deform example
maxter
parents:
diff changeset
255
691e68637348 non-working deform example
maxter
parents:
diff changeset
256 case QEvent.Resize:
691e68637348 non-working deform example
maxter
parents:
diff changeset
257 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
258 QResizeEvent e = cast(QResizeEvent) event;
691e68637348 non-working deform example
maxter
parents:
diff changeset
259 if (e.oldSize().width() == 0 || e.oldSize().height() == 0)
691e68637348 non-working deform example
maxter
parents:
diff changeset
260 break;
691e68637348 non-working deform example
maxter
parents:
diff changeset
261 qreal stretch_x = e.size().width() / cast(qreal)e.oldSize.width;
691e68637348 non-working deform example
maxter
parents:
diff changeset
262 qreal stretch_y = e.size().height() / cast(qreal)e.oldSize.height;
691e68637348 non-working deform example
maxter
parents:
diff changeset
263 for (int i=0; i<m_points.size(); ++i) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
264 QPointF p = m_points.at(i);
691e68637348 non-working deform example
maxter
parents:
diff changeset
265 movePoint(i, QPointF(p.x() * stretch_x, p.y() * stretch_y), false);
691e68637348 non-working deform example
maxter
parents:
diff changeset
266 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
267
691e68637348 non-working deform example
maxter
parents:
diff changeset
268 firePointChange();
691e68637348 non-working deform example
maxter
parents:
diff changeset
269 break;
691e68637348 non-working deform example
maxter
parents:
diff changeset
270 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
271
691e68637348 non-working deform example
maxter
parents:
diff changeset
272 case QEvent.Paint:
691e68637348 non-working deform example
maxter
parents:
diff changeset
273 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
274 QWidget that_widget = m_widget;
691e68637348 non-working deform example
maxter
parents:
diff changeset
275 m_widget = null;
691e68637348 non-working deform example
maxter
parents:
diff changeset
276 QApplication.sendEvent(object, event);
691e68637348 non-working deform example
maxter
parents:
diff changeset
277 m_widget = that_widget;
691e68637348 non-working deform example
maxter
parents:
diff changeset
278 paintPoints();
691e68637348 non-working deform example
maxter
parents:
diff changeset
279 version (QT_OPENGL_SUPPORT)
691e68637348 non-working deform example
maxter
parents:
diff changeset
280 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
281 ArthurFrame af = cast(ArthurFrame)(that_widget);
691e68637348 non-working deform example
maxter
parents:
diff changeset
282 if (af && af.usesOpenGL())
691e68637348 non-working deform example
maxter
parents:
diff changeset
283 af.glWidget().swapBuffers();
691e68637348 non-working deform example
maxter
parents:
diff changeset
284 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
285
691e68637348 non-working deform example
maxter
parents:
diff changeset
286 return true;
691e68637348 non-working deform example
maxter
parents:
diff changeset
287 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
288 default:
691e68637348 non-working deform example
maxter
parents:
diff changeset
289 break;
691e68637348 non-working deform example
maxter
parents:
diff changeset
290 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
291 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
292
691e68637348 non-working deform example
maxter
parents:
diff changeset
293 return false;
691e68637348 non-working deform example
maxter
parents:
diff changeset
294 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
295
691e68637348 non-working deform example
maxter
parents:
diff changeset
296
691e68637348 non-working deform example
maxter
parents:
diff changeset
297 void paintPoints()
691e68637348 non-working deform example
maxter
parents:
diff changeset
298 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
299 scope p = new QPainter;
691e68637348 non-working deform example
maxter
parents:
diff changeset
300 version (QT_OPENGL_SUPPORT)
691e68637348 non-working deform example
maxter
parents:
diff changeset
301 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
302 ArthurFrame af = cast(ArthurFrame)(m_widget);
691e68637348 non-working deform example
maxter
parents:
diff changeset
303 if (af && af.usesOpenGL())
691e68637348 non-working deform example
maxter
parents:
diff changeset
304 p.begin(af.glWidget());
691e68637348 non-working deform example
maxter
parents:
diff changeset
305 else
691e68637348 non-working deform example
maxter
parents:
diff changeset
306 p.begin(m_widget);
691e68637348 non-working deform example
maxter
parents:
diff changeset
307 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
308 else
691e68637348 non-working deform example
maxter
parents:
diff changeset
309 p.begin(m_widget);
691e68637348 non-working deform example
maxter
parents:
diff changeset
310
691e68637348 non-working deform example
maxter
parents:
diff changeset
311 p.setRenderHint(QPainter.Antialiasing);
691e68637348 non-working deform example
maxter
parents:
diff changeset
312
691e68637348 non-working deform example
maxter
parents:
diff changeset
313 if (m_connectionPen.style() != Qt.NoPen && m_connectionType != ConnectionType.NoConnection) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
314 p.setPen(m_connectionPen);
691e68637348 non-working deform example
maxter
parents:
diff changeset
315
691e68637348 non-working deform example
maxter
parents:
diff changeset
316 if (m_connectionType == ConnectionType.CurveConnection) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
317 auto path = new QPainterPath;
691e68637348 non-working deform example
maxter
parents:
diff changeset
318 path.moveTo(m_points.at(0));
691e68637348 non-working deform example
maxter
parents:
diff changeset
319 for (int i=1; i<m_points.size(); ++i) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
320 QPointF p1 = m_points.at(i-1);
691e68637348 non-working deform example
maxter
parents:
diff changeset
321 QPointF p2 = m_points.at(i);
691e68637348 non-working deform example
maxter
parents:
diff changeset
322 qreal distance = p2.x() - p1.x();
691e68637348 non-working deform example
maxter
parents:
diff changeset
323
691e68637348 non-working deform example
maxter
parents:
diff changeset
324 path.cubicTo(p1.x() + distance / 2, p1.y(),
691e68637348 non-working deform example
maxter
parents:
diff changeset
325 p1.x() + distance / 2, p2.y(),
691e68637348 non-working deform example
maxter
parents:
diff changeset
326 p2.x(), p2.y());
691e68637348 non-working deform example
maxter
parents:
diff changeset
327 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
328 p.drawPath(path);
691e68637348 non-working deform example
maxter
parents:
diff changeset
329 } else {
691e68637348 non-working deform example
maxter
parents:
diff changeset
330 p.drawPolyline(m_points);
691e68637348 non-working deform example
maxter
parents:
diff changeset
331 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
332 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
333
691e68637348 non-working deform example
maxter
parents:
diff changeset
334 p.setPen(m_pointPen);
691e68637348 non-working deform example
maxter
parents:
diff changeset
335 p.setBrush(m_pointBrush);
691e68637348 non-working deform example
maxter
parents:
diff changeset
336
691e68637348 non-working deform example
maxter
parents:
diff changeset
337 for (int i=0; i<m_points.size(); ++i) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
338 QRectF bounds = pointBoundingRect(i);
691e68637348 non-working deform example
maxter
parents:
diff changeset
339 if (m_shape == PointShape.CircleShape)
691e68637348 non-working deform example
maxter
parents:
diff changeset
340 p.drawEllipse(bounds);
691e68637348 non-working deform example
maxter
parents:
diff changeset
341 else
691e68637348 non-working deform example
maxter
parents:
diff changeset
342 p.drawRect(bounds);
691e68637348 non-working deform example
maxter
parents:
diff changeset
343 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
344 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
345
691e68637348 non-working deform example
maxter
parents:
diff changeset
346
691e68637348 non-working deform example
maxter
parents:
diff changeset
347 void setPoints(QPolygonF points)
691e68637348 non-working deform example
maxter
parents:
diff changeset
348 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
349 delete m_points;
691e68637348 non-working deform example
maxter
parents:
diff changeset
350 for (int i=0; i<points.size; ++i)
691e68637348 non-working deform example
maxter
parents:
diff changeset
351 m_points.append(bound_point(points.at(i), boundingRect(), 0));
691e68637348 non-working deform example
maxter
parents:
diff changeset
352
691e68637348 non-working deform example
maxter
parents:
diff changeset
353 delete m_locks;
691e68637348 non-working deform example
maxter
parents:
diff changeset
354 if (m_points.size > 0) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
355 m_locks.length = m_points.size;
691e68637348 non-working deform example
maxter
parents:
diff changeset
356
691e68637348 non-working deform example
maxter
parents:
diff changeset
357 m_locks[] = 0;
691e68637348 non-working deform example
maxter
parents:
diff changeset
358 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
359 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
360
691e68637348 non-working deform example
maxter
parents:
diff changeset
361 void movePoint(int index, QPointF point, bool emitUpdate = true)
691e68637348 non-working deform example
maxter
parents:
diff changeset
362 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
363 m_points.replace(index, bound_point(point, boundingRect(), m_locks[index]));
691e68637348 non-working deform example
maxter
parents:
diff changeset
364 if (emitUpdate)
691e68637348 non-working deform example
maxter
parents:
diff changeset
365 firePointChange();
691e68637348 non-working deform example
maxter
parents:
diff changeset
366 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
367
691e68637348 non-working deform example
maxter
parents:
diff changeset
368 void firePointChange()
691e68637348 non-working deform example
maxter
parents:
diff changeset
369 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
370 // printf("HoverPoints.firePointChange(), current=%d\n", m_currentIndex);
691e68637348 non-working deform example
maxter
parents:
diff changeset
371
691e68637348 non-working deform example
maxter
parents:
diff changeset
372 if (m_sortType != SortType.NoSort) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
373
691e68637348 non-working deform example
maxter
parents:
diff changeset
374 QPointF oldCurrent;
691e68637348 non-working deform example
maxter
parents:
diff changeset
375 if (m_currentIndex != -1) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
376 oldCurrent = m_points.at(m_currentIndex);
691e68637348 non-working deform example
maxter
parents:
diff changeset
377 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
378
691e68637348 non-working deform example
maxter
parents:
diff changeset
379 if (m_sortType == SortType.XSort)
691e68637348 non-working deform example
maxter
parents:
diff changeset
380 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
381 auto tmpPoints = m_points.toList;
691e68637348 non-working deform example
maxter
parents:
diff changeset
382 sort(tmpPoints, &x_less_than);
691e68637348 non-working deform example
maxter
parents:
diff changeset
383 m_points = new QPolygonF(tmpPoints);
691e68637348 non-working deform example
maxter
parents:
diff changeset
384 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
385 else if (m_sortType == SortType.YSort)
691e68637348 non-working deform example
maxter
parents:
diff changeset
386 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
387 auto tmpPoints = m_points.toList;
691e68637348 non-working deform example
maxter
parents:
diff changeset
388 sort(tmpPoints, &y_less_than);
691e68637348 non-working deform example
maxter
parents:
diff changeset
389 m_points = new QPolygonF(tmpPoints);
691e68637348 non-working deform example
maxter
parents:
diff changeset
390 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
391
691e68637348 non-working deform example
maxter
parents:
diff changeset
392 // Compensate for changed order...
691e68637348 non-working deform example
maxter
parents:
diff changeset
393 if (m_currentIndex != -1) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
394 for (int i=0; i<m_points.size; ++i) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
395 if (m_points.at(i) == oldCurrent) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
396 m_currentIndex = i;
691e68637348 non-working deform example
maxter
parents:
diff changeset
397 break;
691e68637348 non-working deform example
maxter
parents:
diff changeset
398 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
399 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
400 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
401
691e68637348 non-working deform example
maxter
parents:
diff changeset
402 // printf(" - firePointChange(), current=%d\n", m_currentIndex);
691e68637348 non-working deform example
maxter
parents:
diff changeset
403 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
404
691e68637348 non-working deform example
maxter
parents:
diff changeset
405 // for (int i=0; i<m_points.size(); ++i) {
691e68637348 non-working deform example
maxter
parents:
diff changeset
406 // printf(" - point(%2d)=[%.2f, %.2f], lock=%d\n",
691e68637348 non-working deform example
maxter
parents:
diff changeset
407 // i, m_points.at(i).x(), m_points.at(i).y(), m_locks.at(i));
691e68637348 non-working deform example
maxter
parents:
diff changeset
408 // }
691e68637348 non-working deform example
maxter
parents:
diff changeset
409
691e68637348 non-working deform example
maxter
parents:
diff changeset
410 pointsChanged.emit(m_points);
691e68637348 non-working deform example
maxter
parents:
diff changeset
411 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
412 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
413
691e68637348 non-working deform example
maxter
parents:
diff changeset
414 private QPointF bound_point(QPointF point, QRectF bounds, int lock)
691e68637348 non-working deform example
maxter
parents:
diff changeset
415 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
416 QPointF p = point;
691e68637348 non-working deform example
maxter
parents:
diff changeset
417
691e68637348 non-working deform example
maxter
parents:
diff changeset
418 qreal left = bounds.left();
691e68637348 non-working deform example
maxter
parents:
diff changeset
419 qreal right = bounds.right();
691e68637348 non-working deform example
maxter
parents:
diff changeset
420 qreal top = bounds.top();
691e68637348 non-working deform example
maxter
parents:
diff changeset
421 qreal bottom = bounds.bottom();
691e68637348 non-working deform example
maxter
parents:
diff changeset
422
691e68637348 non-working deform example
maxter
parents:
diff changeset
423 if (p.x() < left || (lock & HoverPoints.LockType.LockToLeft)) p.x = left;
691e68637348 non-working deform example
maxter
parents:
diff changeset
424 else if (p.x() > right || (lock & HoverPoints.LockType.LockToRight)) p.x = right;
691e68637348 non-working deform example
maxter
parents:
diff changeset
425
691e68637348 non-working deform example
maxter
parents:
diff changeset
426 if (p.y() < top || (lock & HoverPoints.LockType.LockToTop)) p.y = top;
691e68637348 non-working deform example
maxter
parents:
diff changeset
427 else if (p.y() > bottom || (lock & HoverPoints.LockType.LockToBottom)) p.y = bottom;
691e68637348 non-working deform example
maxter
parents:
diff changeset
428
691e68637348 non-working deform example
maxter
parents:
diff changeset
429 return p;
691e68637348 non-working deform example
maxter
parents:
diff changeset
430 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
431
691e68637348 non-working deform example
maxter
parents:
diff changeset
432 private bool x_less_than(QPointF p1, QPointF p2)
691e68637348 non-working deform example
maxter
parents:
diff changeset
433 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
434 return p1.x() < p2.x();
691e68637348 non-working deform example
maxter
parents:
diff changeset
435 }
691e68637348 non-working deform example
maxter
parents:
diff changeset
436
691e68637348 non-working deform example
maxter
parents:
diff changeset
437 private bool y_less_than(QPointF p1, QPointF p2)
691e68637348 non-working deform example
maxter
parents:
diff changeset
438 {
691e68637348 non-working deform example
maxter
parents:
diff changeset
439 return p1.y() < p2.y();
691e68637348 non-working deform example
maxter
parents:
diff changeset
440 }