annotate examples/opengl/hellogl/glwidget_d1.d @ 284:1f6923c8cba0

consistent emit syntax.
author eldar
date Fri, 16 Oct 2009 12:23:12 +0000
parents 06e7d3219464
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
216
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
1 /****************************************************************************
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
2 **
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
3 ** Copyright (C) 2008 Nokia Corporation and/or its subsidiary(-ies).
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
4 ** Contact: Qt Software Information (qt-info@nokia.com)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
5 **
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
6 ** This file is part of the example classes of the Qt Toolkit.
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
7 **
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
8 ** Commercial Usage
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
9 ** Licensees holding valid Qt Commercial licenses may use this file in
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
10 ** accordance with the Qt Commercial License Agreement provided with the
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
11 ** Software or, alternatively, in accordance with the terms contained in
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
12 ** a written agreement between you and Nokia.
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
13 **
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
14 **
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
15 ** GNU General Public License Usage
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
16 ** Alternatively, this file may be used under the terms of the GNU
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
17 ** General Public License versions 2.0 or 3.0 as published by the Free
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
18 ** Software Foundation and appearing in the file LICENSE.GPL included in
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
19 ** the packaging of this file. Please review the following information
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
20 ** to ensure GNU General Public Licensing requirements will be met:
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
21 ** http://www.fsf.org/licensing/licenses/info/GPLv2.html and
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
22 ** http://www.gnu.org/copyleft/gpl.html. In addition, as a special
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
23 ** exception, Nokia gives you certain additional rights. These rights
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
24 ** are described in the Nokia Qt GPL Exception version 1.3, included in
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
25 ** the file GPL_EXCEPTION.txt in this package.
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
26 **
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
27 ** Qt for Windows(R) Licensees
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
28 ** As a special exception, Nokia, as the sole copyright holder for Qt
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
29 ** Designer, grants users of the Qt/Eclipse Integration plug-in the
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
30 ** right for the Qt/Eclipse Integration to link to functionality
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
31 ** provided by Qt Designer and its related libraries.
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
32 **
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
33 ** If you are unsure which license is appropriate for your use, please
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
34 ** contact the sales department at qt-sales@nokia.com.
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
35 **
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
36 ****************************************************************************/
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
37
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
38
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
39 import tango.math.Math;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
40
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
41 import qt.core.QPoint;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
42 import qt.gui.QMouseEvent;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
43 import qt.opengl.QGLWidget;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
44 import qt.gui.QColor;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
45 import qt.core.QSize;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
46 import qt.opengl.gl;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
47 import qt.opengl.glu;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
48
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
49 class GLWidget : QGLWidget
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
50 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
51 // Q_OBJECT
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
52
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
53 public:
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
54 this(QWidget parent = null)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
55 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
56 super(parent);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
57 object = 0;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
58 xRot = 0;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
59 yRot = 0;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
60 zRot = 0;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
61
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
62 trolltechGreen = QColor.fromCmykF(0.40, 0.0, 1.0, 0.0);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
63 trolltechPurple = QColor.fromCmykF(0.39, 0.39, 0.0, 0.0);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
64 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
65
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
66 ~this()
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
67 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
68 makeCurrent();
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
69 glDeleteLists(object, 1);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
70 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
71
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
72 QSize minimumSizeHint()
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
73 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
74 return QSize(50, 50);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
75 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
76
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
77 QSize sizeHint()
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
78 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
79 return QSize(400, 400);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
80 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
81
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
82
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
83 public: // slots:
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
84 void setXRotation(int angle)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
85 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
86 normalizeAngle(&angle);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
87 if (angle != xRot) {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
88 xRot = angle;
284
1f6923c8cba0 consistent emit syntax.
eldar
parents: 216
diff changeset
89 xRotationChanged(angle);
216
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
90 updateGL();
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
91 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
92 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
93
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
94 void setYRotation(int angle)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
95 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
96 normalizeAngle(&angle);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
97 if (angle != yRot) {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
98 yRot = angle;
284
1f6923c8cba0 consistent emit syntax.
eldar
parents: 216
diff changeset
99 yRotationChanged(angle);
216
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
100 updateGL();
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
101 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
102 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
103
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
104 void setZRotation(int angle)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
105 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
106 normalizeAngle(&angle);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
107 if (angle != zRot) {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
108 zRot = angle;
284
1f6923c8cba0 consistent emit syntax.
eldar
parents: 216
diff changeset
109 zRotationChanged(angle);
216
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
110 updateGL();
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
111 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
112 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
113
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
114 mixin Signal!("xRotationChanged", int);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
115 mixin Signal!("yRotationChanged", int);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
116 mixin Signal!("zRotationChanged", int);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
117
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
118
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
119 protected:
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
120 void initializeGL()
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
121 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
122 qglClearColor(trolltechPurple.darker());
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
123 object = makeObject();
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
124 glShadeModel(GL_FLAT);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
125 glEnable(GL_DEPTH_TEST);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
126 glEnable(GL_CULL_FACE);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
127 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
128
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
129 void paintGL()
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
130 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
131 glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
132 glLoadIdentity();
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
133 glTranslated(0.0, 0.0, -10.0);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
134 glRotated(xRot / 16.0, 1.0, 0.0, 0.0);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
135 glRotated(yRot / 16.0, 0.0, 1.0, 0.0);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
136 glRotated(zRot / 16.0, 0.0, 0.0, 1.0);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
137 glCallList(object);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
138 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
139
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
140 void resizeGL(int width, int height)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
141 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
142 int side = qMin(width, height);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
143 glViewport((width - side) / 2, (height - side) / 2, side, side);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
144
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
145 glMatrixMode(GL_PROJECTION);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
146 glLoadIdentity();
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
147 glOrtho(-0.5, +0.5, +0.5, -0.5, 4.0, 15.0);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
148 glMatrixMode(GL_MODELVIEW);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
149 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
150
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
151 void mousePressEvent(QMouseEvent event)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
152 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
153 lastPos = QPoint(event.pos.x, event.pos.y);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
154 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
155
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
156 void mouseMoveEvent(QMouseEvent event)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
157 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
158 int dx = event.x - lastPos.x;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
159 int dy = event.y - lastPos.y;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
160
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
161 if (event.buttons() & Qt.LeftButton) {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
162 setXRotation(xRot + 8 * dy);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
163 setYRotation(yRot + 8 * dx);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
164 } else if (event.buttons() & Qt.RightButton) {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
165 setXRotation(xRot + 8 * dy);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
166 setZRotation(zRot + 8 * dx);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
167 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
168 lastPos = QPoint(event.pos.x, event.pos.y);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
169 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
170 private:
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
171 GLuint makeObject()
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
172 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
173 GLuint list = glGenLists(1);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
174 glNewList(list, GL_COMPILE);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
175
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
176 glBegin(GL_QUADS);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
177
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
178 GLdouble x1 = +0.06;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
179 GLdouble y1 = -0.14;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
180 GLdouble x2 = +0.14;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
181 GLdouble y2 = -0.06;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
182 GLdouble x3 = +0.08;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
183 GLdouble y3 = +0.00;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
184 GLdouble x4 = +0.30;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
185 GLdouble y4 = +0.22;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
186
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
187 quad(x1, y1, x2, y2, y2, x2, y1, x1);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
188 quad(x3, y3, x4, y4, y4, x4, y3, x3);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
189
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
190 extrude(x1, y1, x2, y2);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
191 extrude(x2, y2, y2, x2);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
192 extrude(y2, x2, y1, x1);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
193 extrude(y1, x1, x1, y1);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
194 extrude(x3, y3, x4, y4);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
195 extrude(x4, y4, y4, x4);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
196 extrude(y4, x4, y3, x3);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
197
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
198 const double Pi = 3.14159265358979323846;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
199 const int NumSectors = 200;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
200
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
201 for (int i = 0; i < NumSectors; ++i) {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
202 double angle1 = (i * 2 * Pi) / NumSectors;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
203 GLdouble x5 = 0.30 * sin(angle1);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
204 GLdouble y5 = 0.30 * cos(angle1);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
205 GLdouble x6 = 0.20 * sin(angle1);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
206 GLdouble y6 = 0.20 * cos(angle1);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
207
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
208 double angle2 = ((i + 1) * 2 * Pi) / NumSectors;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
209 GLdouble x7 = 0.20 * sin(angle2);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
210 GLdouble y7 = 0.20 * cos(angle2);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
211 GLdouble x8 = 0.30 * sin(angle2);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
212 GLdouble y8 = 0.30 * cos(angle2);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
213
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
214 quad(x5, y5, x6, y6, x7, y7, x8, y8);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
215
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
216 extrude(x6, y6, x7, y7);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
217 extrude(x8, y8, x5, y5);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
218 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
219
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
220 glEnd();
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
221
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
222 glEndList();
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
223 return list;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
224 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
225
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
226 void quad(GLdouble x1, GLdouble y1, GLdouble x2, GLdouble y2,
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
227 GLdouble x3, GLdouble y3, GLdouble x4, GLdouble y4)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
228 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
229 qglColor(trolltechGreen);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
230
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
231 glVertex3d(x1, y1, -0.05);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
232 glVertex3d(x2, y2, -0.05);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
233 glVertex3d(x3, y3, -0.05);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
234 glVertex3d(x4, y4, -0.05);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
235
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
236 glVertex3d(x4, y4, +0.05);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
237 glVertex3d(x3, y3, +0.05);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
238 glVertex3d(x2, y2, +0.05);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
239 glVertex3d(x1, y1, +0.05);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
240 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
241
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
242 void extrude(GLdouble x1, GLdouble y1, GLdouble x2, GLdouble y2)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
243 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
244 qglColor(trolltechGreen.darker(rndint(250 + (100 * x1))));
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
245
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
246 glVertex3d(x1, y1, +0.05);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
247 glVertex3d(x2, y2, +0.05);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
248 glVertex3d(x2, y2, -0.05);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
249 glVertex3d(x1, y1, -0.05);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
250 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
251
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
252 void normalizeAngle(int *angle)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
253 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
254 while (*angle < 0)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
255 *angle += 360 * 16;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
256 while (*angle > 360 * 16)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
257 *angle -= 360 * 16;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
258 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
259
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
260 GLuint object;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
261 int xRot;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
262 int yRot;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
263 int zRot;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
264 QPoint lastPos;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
265 QColor trolltechGreen;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
266 QColor trolltechPurple;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
267 }