annotate trunk/tests/ChipmunkDemos/drawSpace.d @ 31:4604c914f2ab default tip

removed workaround for dmd-bug #5249
author Extrawurst
date Thu, 30 Dec 2010 13:50:40 +0100
parents f897d96cc7c9
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
20
f897d96cc7c9 cleanup
Extrawurst
parents: 16
diff changeset
1
f897d96cc7c9 cleanup
Extrawurst
parents: 16
diff changeset
2 // written in the D programming language
f897d96cc7c9 cleanup
Extrawurst
parents: 16
diff changeset
3
16
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
4 module drawSpace;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
5
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
6 import derelict.opengl.gl;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
7
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
8 import chipmunkd.chipmunk;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
9
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
10 import std.math:PI;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
11 import std.stdio;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
12
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
13 struct drawSpaceOptions {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
14 int drawHash;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
15 int drawBBs;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
16 int drawShapes;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
17 float collisionPointSize;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
18 float bodyPointSize;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
19 float lineThickness;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
20 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
21
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
22 /*
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
23 IMPORTANT - READ ME!
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
24
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
25 This file sets up a simple interface that the individual demos can use to get
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
26 a Chipmunk space running and draw what's in it. In order to keep the Chipmunk
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
27 examples clean and simple, they contain no graphics code. All drawing is done
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
28 by accessing the Chipmunk structures at a very low level. It is NOT
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
29 recommended to write a game or application this way as it does not scale
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
30 beyond simple shape drawing and is very dependent on implementation details
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
31 about Chipmunk which may change with little to no warning.
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
32 */
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
33
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
34 enum float[3] LINE_COLOR = [0,0,0];
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
35 enum float[3] COLLISION_COLOR = [1,0,0];
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
36 enum float[3] BODY_COLOR = [0,0,1];
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
37
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
38 static void
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
39 glColor_from_pointer(void *ptr)
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
40 {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
41 ulong val = cast(long)ptr;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
42
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
43 // hash the pointer up nicely
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
44 val = (val+0x7ed55d16) + (val<<12);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
45 val = (val^0xc761c23c) ^ (val>>19);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
46 val = (val+0x165667b1) + (val<<5);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
47 val = (val+0xd3a2646c) ^ (val<<9);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
48 val = (val+0xfd7046c5) + (val<<3);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
49 val = (val^0xb55a4f09) ^ (val>>16);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
50
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
51 // GLfloat v = (GLfloat)val/(GLfloat)ULONG_MAX;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
52 // v = 0.95f - v*0.15f;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
53 //
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
54 // glColor3f(v, v, v);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
55
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
56 GLubyte r = (val>>0) & 0xFF;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
57 GLubyte g = (val>>8) & 0xFF;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
58 GLubyte b = (val>>16) & 0xFF;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
59
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
60 GLubyte max = r>g ? (r>b ? r : b) : (g>b ? g : b);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
61
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
62 const int mult = 127;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
63 const int add = 63;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
64 r = cast(ubyte)((r*mult)/max + add);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
65 g = cast(ubyte)((g*mult)/max + add);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
66 b = cast(ubyte)((b*mult)/max + add);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
67
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
68 glColor3ub(r, g, b);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
69 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
70
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
71 static void
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
72 glColor_for_shape(cpShape *shape, cpSpace *space)
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
73 {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
74 cpBody *_body = shape._body;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
75 if(_body){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
76 if(_body.node.next){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
77 GLfloat v = 0.25f;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
78 glColor3f(v,v,v);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
79 return;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
80 } else if(_body.node.idleTime > space.sleepTimeThreshold) {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
81 GLfloat v = 0.9f;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
82 glColor3f(v,v,v);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
83 return;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
84 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
85 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
86
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
87 glColor_from_pointer(shape);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
88 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
89
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
90 enum GLfloat[] circleVAR = [
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
91 0.0000f, 1.0000f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
92 0.2588f, 0.9659f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
93 0.5000f, 0.8660f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
94 0.7071f, 0.7071f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
95 0.8660f, 0.5000f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
96 0.9659f, 0.2588f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
97 1.0000f, 0.0000f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
98 0.9659f, -0.2588f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
99 0.8660f, -0.5000f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
100 0.7071f, -0.7071f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
101 0.5000f, -0.8660f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
102 0.2588f, -0.9659f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
103 0.0000f, -1.0000f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
104 -0.2588f, -0.9659f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
105 -0.5000f, -0.8660f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
106 -0.7071f, -0.7071f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
107 -0.8660f, -0.5000f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
108 -0.9659f, -0.2588f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
109 -1.0000f, -0.0000f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
110 -0.9659f, 0.2588f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
111 -0.8660f, 0.5000f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
112 -0.7071f, 0.7071f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
113 -0.5000f, 0.8660f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
114 -0.2588f, 0.9659f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
115 0.0000f, 1.0000f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
116 0.0f, 0.0f, // For an extra line to see the rotation.
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
117 ];
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
118 enum int circleVAR_count = circleVAR.length / 2;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
119
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
120 static void
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
121 drawCircleShape(cpBody *_body, cpCircleShape *circle, cpSpace *space)
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
122 {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
123 glVertexPointer(2, GL_FLOAT, 0, circleVAR.ptr);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
124
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
125 glPushMatrix(); {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
126 cpVect center = circle.tc;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
127 glTranslatef(center.x, center.y, 0.0f);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
128 glRotatef(_body.a*180.0f/PI, 0.0f, 0.0f, 1.0f);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
129 glScalef(circle.r, circle.r, 1.0f);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
130
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
131 if(!circle.shape.sensor){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
132 glColor_for_shape(cast(cpShape *)circle, space);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
133 glDrawArrays(GL_TRIANGLE_FAN, 0, circleVAR_count - 1);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
134 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
135
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
136 glColor3fv(LINE_COLOR.ptr);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
137 glDrawArrays(GL_LINE_STRIP, 0, circleVAR_count);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
138 } glPopMatrix();
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
139 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
140
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
141 enum GLfloat[] pillVAR = [
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
142 0.0000f, 1.0000f, 1.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
143 0.2588f, 0.9659f, 1.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
144 0.5000f, 0.8660f, 1.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
145 0.7071f, 0.7071f, 1.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
146 0.8660f, 0.5000f, 1.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
147 0.9659f, 0.2588f, 1.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
148 1.0000f, 0.0000f, 1.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
149 0.9659f, -0.2588f, 1.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
150 0.8660f, -0.5000f, 1.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
151 0.7071f, -0.7071f, 1.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
152 0.5000f, -0.8660f, 1.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
153 0.2588f, -0.9659f, 1.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
154 0.0000f, -1.0000f, 1.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
155
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
156 0.0000f, -1.0000f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
157 -0.2588f, -0.9659f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
158 -0.5000f, -0.8660f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
159 -0.7071f, -0.7071f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
160 -0.8660f, -0.5000f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
161 -0.9659f, -0.2588f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
162 -1.0000f, -0.0000f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
163 -0.9659f, 0.2588f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
164 -0.8660f, 0.5000f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
165 -0.7071f, 0.7071f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
166 -0.5000f, 0.8660f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
167 -0.2588f, 0.9659f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
168 0.0000f, 1.0000f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
169 ];
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
170 enum int pillVAR_count = pillVAR.length/3;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
171
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
172 static void
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
173 drawSegmentShape(cpBody *_body, cpSegmentShape *seg, cpSpace *space)
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
174 {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
175 cpVect a = seg.ta;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
176 cpVect b = seg.tb;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
177
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
178 if(seg.r){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
179 glVertexPointer(3, GL_FLOAT, 0, pillVAR.ptr);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
180 glPushMatrix(); {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
181 cpVect d = cpvsub(b, a);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
182 cpVect r = cpvmult(d, seg.r/cpvlength(d));
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
183
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
184 GLfloat matrix[] = [
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
185 r.x, r.y, 0.0f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
186 -r.y, r.x, 0.0f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
187 d.x, d.y, 0.0f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
188 a.x, a.y, 0.0f, 1.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
189 ];
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
190 glMultMatrixf(matrix.ptr);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
191
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
192 if(!seg.shape.sensor){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
193 glColor_for_shape(cast(cpShape *)seg, space);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
194 glDrawArrays(GL_TRIANGLE_FAN, 0, pillVAR_count);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
195 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
196
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
197 glColor3fv(LINE_COLOR.ptr);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
198 glDrawArrays(GL_LINE_LOOP, 0, pillVAR_count);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
199 } glPopMatrix();
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
200 } else {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
201 glColor3fv(LINE_COLOR.ptr);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
202 glBegin(GL_LINES); {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
203 glVertex2f(a.x, a.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
204 glVertex2f(b.x, b.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
205 } glEnd();
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
206 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
207 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
208
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
209 static void
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
210 drawPolyShape(cpBody *_body, cpPolyShape *poly, cpSpace *space)
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
211 {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
212 int count = poly.numVerts;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
213 version(CP_USE_DOUBLES)
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
214 {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
215 glVertexPointer(2, GL_DOUBLE, 0, poly.tVerts);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
216 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
217 else
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
218 {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
219 glVertexPointer(2, GL_FLOAT, 0, poly.tVerts);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
220 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
221
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
222 if(!poly.shape.sensor){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
223 glColor_for_shape(cast(cpShape *)poly, space);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
224 glDrawArrays(GL_TRIANGLE_FAN, 0, count);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
225 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
226
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
227 glColor3fv(LINE_COLOR.ptr);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
228 glDrawArrays(GL_LINE_LOOP, 0, count);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
229 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
230
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
231 static void
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
232 drawObject(cpShape *shape, cpSpace *space)
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
233 {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
234 cpBody *_body = shape._body;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
235
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
236 switch(shape.klass.type){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
237 case cpShapeType.CP_CIRCLE_SHAPE:
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
238 drawCircleShape(_body, cast(cpCircleShape *)shape, space);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
239 break;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
240 case cpShapeType.CP_SEGMENT_SHAPE:
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
241 drawSegmentShape(_body, cast(cpSegmentShape *)shape, space);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
242 break;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
243 case cpShapeType.CP_POLY_SHAPE:
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
244 drawPolyShape(_body, cast(cpPolyShape *)shape, space);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
245 break;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
246 default:
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
247 writefln("Bad enumeration in drawObject().");
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
248 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
249 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
250
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
251 enum GLfloat[] springVAR = [
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
252 0.00f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
253 0.20f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
254 0.25f, 3.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
255 0.30f,-6.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
256 0.35f, 6.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
257 0.40f,-6.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
258 0.45f, 6.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
259 0.50f,-6.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
260 0.55f, 6.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
261 0.60f,-6.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
262 0.65f, 6.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
263 0.70f,-3.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
264 0.75f, 6.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
265 0.80f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
266 1.00f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
267 ];
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
268 enum int springVAR_count = springVAR.length / 2;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
269
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
270 static void
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
271 drawSpring(cpDampedSpring *spring, cpBody *body_a, cpBody *body_b)
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
272 {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
273 cpVect a = cpvadd(body_a.p, cpvrotate(spring.anchr1, body_a.rot));
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
274 cpVect b = cpvadd(body_b.p, cpvrotate(spring.anchr2, body_b.rot));
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
275
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
276 glPointSize(5.0f);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
277 glBegin(GL_POINTS); {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
278 glVertex2f(a.x, a.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
279 glVertex2f(b.x, b.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
280 } glEnd();
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
281
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
282 cpVect delta = cpvsub(b, a);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
283
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
284 glVertexPointer(2, GL_FLOAT, 0, springVAR.ptr);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
285 glPushMatrix(); {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
286 GLfloat x = a.x;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
287 GLfloat y = a.y;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
288 GLfloat cos = delta.x;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
289 GLfloat sin = delta.y;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
290 GLfloat s = 1.0f/cpvlength(delta);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
291
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
292 GLfloat matrix[] = [
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
293 cos, sin, 0.0f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
294 -sin*s, cos*s, 0.0f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
295 0.0f, 0.0f, 1.0f, 0.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
296 x, y, 0.0f, 1.0f,
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
297 ];
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
298
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
299 glMultMatrixf(matrix.ptr);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
300 glDrawArrays(GL_LINE_STRIP, 0, springVAR_count);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
301 } glPopMatrix();
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
302 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
303
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
304 static void
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
305 drawConstraint(cpConstraint *constraint)
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
306 {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
307 cpBody *body_a = constraint.a;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
308 cpBody *body_b = constraint.b;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
309
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
310 const cpConstraintClass *klass = constraint.klass;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
311 if(klass == cpPinJointGetClass()){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
312 cpPinJoint *joint = cast(cpPinJoint *)constraint;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
313
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
314 cpVect a = cpvadd(body_a.p, cpvrotate(joint.anchr1, body_a.rot));
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
315 cpVect b = cpvadd(body_b.p, cpvrotate(joint.anchr2, body_b.rot));
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
316
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
317 glPointSize(5.0f);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
318 glBegin(GL_POINTS); {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
319 glVertex2f(a.x, a.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
320 glVertex2f(b.x, b.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
321 } glEnd();
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
322
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
323 glBegin(GL_LINES); {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
324 glVertex2f(a.x, a.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
325 glVertex2f(b.x, b.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
326 } glEnd();
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
327 } else if(klass == cpSlideJointGetClass()){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
328 cpSlideJoint *joint = cast(cpSlideJoint *)constraint;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
329
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
330 cpVect a = cpvadd(body_a.p, cpvrotate(joint.anchr1, body_a.rot));
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
331 cpVect b = cpvadd(body_b.p, cpvrotate(joint.anchr2, body_b.rot));
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
332
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
333 glPointSize(5.0f);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
334 glBegin(GL_POINTS); {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
335 glVertex2f(a.x, a.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
336 glVertex2f(b.x, b.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
337 } glEnd();
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
338
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
339 glBegin(GL_LINES); {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
340 glVertex2f(a.x, a.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
341 glVertex2f(b.x, b.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
342 } glEnd();
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
343 } else if(klass == cpPivotJointGetClass()){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
344 cpPivotJoint *joint = cast(cpPivotJoint *)constraint;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
345
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
346 cpVect a = cpvadd(body_a.p, cpvrotate(joint.anchr1, body_a.rot));
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
347 cpVect b = cpvadd(body_b.p, cpvrotate(joint.anchr2, body_b.rot));
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
348
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
349 glPointSize(10.0f);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
350 glBegin(GL_POINTS); {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
351 glVertex2f(a.x, a.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
352 glVertex2f(b.x, b.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
353 } glEnd();
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
354 } else if(klass == cpGrooveJointGetClass()){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
355 cpGrooveJoint *joint = cast(cpGrooveJoint *)constraint;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
356
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
357 cpVect a = cpvadd(body_a.p, cpvrotate(joint.grv_a, body_a.rot));
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
358 cpVect b = cpvadd(body_a.p, cpvrotate(joint.grv_b, body_a.rot));
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
359 cpVect c = cpvadd(body_b.p, cpvrotate(joint.anchr2, body_b.rot));
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
360
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
361 glPointSize(5.0f);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
362 glBegin(GL_POINTS); {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
363 glVertex2f(c.x, c.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
364 } glEnd();
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
365
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
366 glBegin(GL_LINES); {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
367 glVertex2f(a.x, a.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
368 glVertex2f(b.x, b.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
369 } glEnd();
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
370 } else if(klass == cpDampedSpringGetClass()){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
371 drawSpring(cast(cpDampedSpring *)constraint, body_a, body_b);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
372 } else {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
373 // printf("Cannot draw constraint\n");
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
374 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
375 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
376
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
377 static void
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
378 drawBB(cpShape *shape, void *unused)
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
379 {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
380 glBegin(GL_LINE_LOOP); {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
381 glVertex2f(shape.bb.l, shape.bb.b);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
382 glVertex2f(shape.bb.l, shape.bb.t);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
383 glVertex2f(shape.bb.r, shape.bb.t);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
384 glVertex2f(shape.bb.r, shape.bb.b);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
385 } glEnd();
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
386 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
387
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
388 // copied from cpSpaceHash.c
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
389 static cpHashValue
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
390 hash_func(cpHashValue x, cpHashValue y, cpHashValue n)
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
391 {
20
f897d96cc7c9 cleanup
Extrawurst
parents: 16
diff changeset
392 return cast(cpHashValue)(( (x*1640531513uL) ^ (y*2654435789uL) ) % n);
16
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
393 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
394
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
395 static void
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
396 drawSpatialHash(cpSpaceHash *hash)
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
397 {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
398 cpBB bb = cpBBNew(-320, -240, 320, 240);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
399
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
400 cpFloat dim = hash.celldim;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
401 int n = hash.numcells;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
402
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
403 int l = cast(int)floorf(bb.l/dim);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
404 int r = cast(int)floorf(bb.r/dim);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
405 int b = cast(int)floorf(bb.b/dim);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
406 int t = cast(int)floorf(bb.t/dim);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
407
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
408 for(int i=l; i<=r; i++){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
409 for(int j=b; j<=t; j++){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
410 int cell_count = 0;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
411
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
412 int index = hash_func(i,j,n);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
413 for(cpSpaceHashBin *bin = hash.table[index]; bin; bin = bin.next)
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
414 cell_count++;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
415
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
416 GLfloat v = 1.0f - cast(GLfloat)cell_count/10.0f;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
417 glColor3f(v,v,v);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
418 glRectf(i*dim, j*dim, (i + 1)*dim, (j + 1)*dim);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
419 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
420 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
421 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
422
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
423 void
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
424 DrawSpace(cpSpace *space, const drawSpaceOptions *options)
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
425 {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
426 if(options.drawHash){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
427 glColorMask(GL_FALSE, GL_TRUE, GL_FALSE, GL_TRUE);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
428 drawSpatialHash(space.activeShapes);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
429 glColorMask(GL_TRUE, GL_FALSE, GL_FALSE, GL_FALSE);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
430 drawSpatialHash(space.staticShapes);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
431 glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
432 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
433
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
434 glLineWidth(options.lineThickness);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
435 if(options.drawShapes){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
436 cpSpaceHashEach(space.activeShapes, cast(cpSpaceHashIterator)&drawObject, space);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
437 cpSpaceHashEach(space.staticShapes, cast(cpSpaceHashIterator)&drawObject, space);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
438 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
439
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
440 glLineWidth(1.0f);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
441 if(options.drawBBs){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
442 glColor3f(0.3f, 0.5f, 0.3f);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
443 cpSpaceHashEach(space.activeShapes, cast(cpSpaceHashIterator)&drawBB, null);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
444 cpSpaceHashEach(space.staticShapes, cast(cpSpaceHashIterator)&drawBB, null);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
445 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
446
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
447 cpArray *constraints = space.constraints;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
448
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
449 glColor3f(0.5f, 1.0f, 0.5f);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
450 for(int i=0, count = constraints.num; i<count; i++){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
451 drawConstraint(cast(cpConstraint *)constraints.arr[i]);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
452 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
453
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
454 if(options.bodyPointSize){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
455 glPointSize(options.bodyPointSize);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
456
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
457 glBegin(GL_POINTS); {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
458 glColor3fv(LINE_COLOR.ptr);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
459 cpArray *bodies = space.bodies;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
460 for(int i=0, count = bodies.num; i<count; i++){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
461 cpBody *_body = cast(cpBody *)bodies.arr[i];
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
462 glVertex2f(_body.p.x, _body.p.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
463 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
464
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
465 // glColor3f(0.5f, 0.5f, 0.5f);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
466 // cpArray *components = space.components;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
467 // for(int i=0; i<components.num; i++){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
468 // cpBody *root = components.arr[i];
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
469 // cpBody *body = root, *next;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
470 // do {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
471 // next = body.node.next;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
472 // glVertex2f(body.p.x, body.p.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
473 // } while((body = next) != root);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
474 // }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
475 } glEnd();
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
476 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
477
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
478 if(options.collisionPointSize){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
479 glPointSize(options.collisionPointSize);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
480 glBegin(GL_POINTS); {
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
481 cpArray *arbiters = space.arbiters;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
482 for(int i=0; i<arbiters.num; i++){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
483 cpArbiter *arb = cast(cpArbiter*)arbiters.arr[i];
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
484
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
485 glColor3fv(COLLISION_COLOR.ptr);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
486 foreach(j; 0..arb.numContacts){
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
487 cpVect v = arb.contacts[j].p;
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
488 glVertex2f(v.x, v.y);
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
489 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
490 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
491 } glEnd();
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
492 }
af2f61a96318 ported chipmunk demos
Extrawurst
parents:
diff changeset
493 }