annotate render/render.d @ 18:7f74e064dad5

refactored code
author zzzzrrr <mason.green@gmail.com>
date Wed, 25 Mar 2009 11:28:25 -0400
parents render.d@82efafc87d54
children 4fce5596d1f6
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
1 /*
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
2 * Copyright (c) 2009, Mason Green (zzzzrrr)
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
3 * Based on Box2D by Erin Catto, http://www.box2d.org
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
4 *
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
5 * All rights reserved.
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
6 *
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
7 * Redistribution and use in source and binary forms, with or without modification,
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
8 * are permitted provided that the following conditions are met:
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
9 *
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
10 * * Redistributions of source code must retain the above copyright notice,
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
11 * this list of conditions and the following disclaimer.
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
12 * * Redistributions in binary form must reproduce the above copyright notice,
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
13 * this list of conditions and the following disclaimer in the documentation
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
14 * and/or other materials provided with the distribution.
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
15 * * Neither the name of the polygonal nor the names of its contributors may be
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
16 * used to endorse or promote products derived from this software without specific
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
17 * prior written permission.
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
18 *
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
20 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
21 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
22 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
23 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
24 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
25 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
26 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
27 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
28 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
29 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
30 */
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
31 module openmelee.render.render;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
32
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
33 import tango.math.Math : PI;
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
34
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
35 import xf.dog.Dog;
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
36 import xf.omg.core.LinearAlgebra;
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
37 import xf.hybrid.Event;
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
38 import xf.hybrid.Font;
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
39
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
40 import blaze.bzWorld : bzWorld;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
41 import blaze.dynamics.bzBody : bzBody;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
42 import blaze.collision.shapes.bzShape : bzShape;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
43 import blaze.collision.shapes.bzShapeType;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
44 import blaze.collision.shapes.bzCircle : bzCircle;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
45 import blaze.collision.shapes.bzPolygon : bzPolygon;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
46 import blaze.collision.shapes.bzEdge : bzEdge;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
47 import blaze.collision.nbody.bzBroadPhase : bzBroadPhase, bzProxy;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
48 import blaze.collision.bzCollision : bzAABB;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
49 import blaze.common.bzMath : bzXForm, bzVec2, bzMul, bzClamp;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
50 import blaze.common.bzConstants : k_toiSlop,k_maxProxies;
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
51
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
52 import openmelee.ships.ship : Ship;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
53 import openmelee.melee.melee : Settings;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
54
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
55 // Cursor scale factor
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
56 const CURSORSIZE = 0.05f;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
57 const INIT_SPAWN_SIZE = 0.5f;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
58 // Dragging stuffs
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
59 const BUNGEE_K = 1.5f;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
60 // Damping factor for dragging
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
61 const DRAGDAMP = 20.0f;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
62 // Size of hinges
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
63 const HINGE_RADIUS = 0.05f;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
64 // Smallest allowed dimension
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
65 const MIN_DIMENSION = 0.1;
7
2217fd1fe384 added angular and linear velocity limit
zzzzrrr <mason.green@gmail.com>
parents: 6
diff changeset
66 const MAX_CIRCLE_RES = 32;
2217fd1fe384 added angular and linear velocity limit
zzzzrrr <mason.green@gmail.com>
parents: 6
diff changeset
67
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
68 /// Color for drawing. Each value has the range [0,1].
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
69 struct Color {
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
70 static Color opCall(float r, float g, float b)
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
71 {
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
72 Color u;
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
73 u.r = r;
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
74 u.g = g;
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
75 u.b = b;
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
76 return u;
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
77 }
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
78
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
79 float r = 0;
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
80 float g = 0;
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
81 float b = 0;
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
82 }
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
83
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
84 class Render
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
85 {
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
86
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
87 float zoom = 40;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
88 vec2 viewCenter;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
89 bzWorld world;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
90 vec2i screenSize;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
91 bool scaling = false;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
92 bool full = false;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
93 Settings settings;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
94 Ship ship1, ship2;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
95
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
96 this(bzWorld world, Ship s1, Ship s2, Settings settings) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
97 this.settings = settings;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
98 ship1 = s1;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
99 ship2 = s2;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
100 this.world = world;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
101 viewCenter = vec2(10, 10);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
102 screenSize = vec2i.zero;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
103 }
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
104
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
105 void drawCircle(GL gl, vec2 center, float radius, bool water = false, float theta = float.nan)
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
106 {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
107 int segs = cast(int)(radius) + 20;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
108 if (segs > MAX_CIRCLE_RES) segs = MAX_CIRCLE_RES;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
109 double coef = 2.0 * PI / segs;
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
110
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
111 auto realTheta = (theta <>= 0 ? theta : 0);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
112 if (water) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
113 gl.immediate(GL_TRIANGLE_FAN,
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
114 {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
115 gl.Vertex2fv(center.ptr);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
116 for (int n = 0; n <= segs; n++) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
117 double rads = n * coef;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
118 gl.Vertex2f(radius * cos(rads + realTheta) + center.x, radius * sin(rads + realTheta) + center.y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
119 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
120 });
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
121 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
122
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
123 gl.immediate(GL_LINE_STRIP,
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
124 {
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
125 for (int n = 0; n <= segs; n++) {
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
126 double rads = n * coef;
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
127 gl.Vertex2f(radius * cos(rads + realTheta) + center.x, radius * sin(rads + realTheta) + center.y);
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
128 }
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
129 if (theta <>= 0)
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
130 gl.Vertex2fv(center.ptr);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
131 });
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
132 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
133
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
134 void drawSolidCircle(GL gl, vec2 center, float radius, vec2 axis, Color color)
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
135 {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
136 const k_segments = 25.0f;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
137 const k_increment = 2.0f * PI / k_segments;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
138 float theta = 0.0f;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
139 gl.Enable(GL_BLEND);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
140 gl.BlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
141 gl.Color4f(0.5f * color.r, 0.5f * color.g, 0.5f * color.b, 0.5f);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
142 gl.Begin(GL_TRIANGLE_FAN);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
143 for (int i = 0; i < k_segments; ++i) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
144 vec2 v = center + radius * vec2(cos(theta), sin(theta));
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
145 gl.Vertex2f(v.x, v.y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
146 theta += k_increment;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
147 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
148 gl.End();
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
149 gl.Disable(GL_BLEND);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
150
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
151 theta = 0.0f;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
152 gl.Color4f(color.r, color.g, color.b, 1.0f);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
153 gl.Begin(GL_LINE_LOOP);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
154 for (int i = 0; i < k_segments; ++i) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
155 vec2 v = center + radius * vec2(cos(theta), sin(theta));
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
156 gl.Vertex2f(v.x, v.y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
157 theta += k_increment;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
158 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
159 gl.End();
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
160
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
161 vec2 p = center + radius * axis;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
162 gl.Begin(GL_LINES);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
163 gl.Vertex2f(center.x, center.y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
164 gl.Vertex2f(p.x, p.y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
165 gl.End();
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
166 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
167
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
168 void drawPolygon(GL gl, vec2[] glVerts, Color color)
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
169 {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
170 gl.Color3f(color.r, color.g, color.b);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
171 gl.immediate(GL_LINE_LOOP,
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
172 {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
173 foreach (v; glVerts)
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
174 gl.Vertex2fv(v.ptr);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
175 });
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
176 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
177
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
178 void drawSolidPolygon(GL gl, vec2[] vertices, Color color)
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
179 {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
180 gl.Enable(GL_BLEND);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
181 gl.BlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
182 gl.Color4f(0.5f * color.r, 0.5f * color.g, 0.5f * color.b, 0.5f);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
183 gl.Begin(GL_TRIANGLE_FAN);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
184 for (int i = 0; i < vertices.length; ++i) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
185 gl.Vertex2f(vertices[i].x, vertices[i].y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
186 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
187 gl.End();
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
188 gl.Disable(GL_BLEND);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
189
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
190 gl.Color4f(color.r, color.g, color.b, 1.0f);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
191 gl.Begin(GL_LINE_LOOP);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
192 for (int i = 0; i < vertices.length; ++i) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
193 gl.Vertex2f(vertices[i].x, vertices[i].y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
194 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
195 gl.End();
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
196 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
197
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
198
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
199 void drawPoint(GL gl, vec2 p, float size, Color color)
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
200 {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
201 gl.Color3f(color.r, color.g, color.b);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
202 gl.PointSize(size);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
203 gl.Begin(GL_POINTS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
204 gl.Vertex2f(p.x, p.y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
205 gl.End();
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
206 gl.PointSize(1.0f);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
207 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
208
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
209 void drawSegment(GL gl, vec2 begin, vec2 end, Color color)
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
210 {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
211 gl.Color3f(color.r, color.g, color.b);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
212 gl.immediate(GL_LINES,
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
213 {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
214 gl.Vertex2fv(begin.ptr);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
215 gl.Vertex2fv(end.ptr);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
216 });
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
217 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
218
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
219 // TODO: handle inequal radii correctly
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
220 void connectCircles(GL gl, vec2 center1, float radius1, vec2 center2, float radius2)
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
221 {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
222 auto d = center2 - center1;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
223 if (!d.length)
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
224 return;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
225 d *= (d.length - radius1) / d.length;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
226 center1 += d;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
227 center2 -= d;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
228 gl.immediate(GL_LINES,
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
229 {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
230 gl.Vertex2fv(center1.ptr);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
231 gl.Vertex2fv(center2.ptr);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
232 });
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
233 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
234
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
235 void drawXForm(GL gl, bzXForm xf)
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
236 {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
237 bzVec2 p1 = xf.position, p2;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
238 const k_axisScale = 0.4f;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
239
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
240 gl.Begin(GL_LINES);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
241 {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
242 gl.Color3f(1.0f, 0.0f, 0.0f);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
243 gl.Vertex2f(p1.x, p1.y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
244 p2 = p1 + k_axisScale * xf.R.col1;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
245 gl.Vertex2f(p2.x, p2.y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
246
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
247 gl.Color3f(0.0f, 1.0f, 0.0f);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
248 gl.Vertex2f(p1.x, p1.y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
249 p2 = p1 + k_axisScale * xf.R.col2;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
250 gl.Vertex2f(p2.x, p2.y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
251 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
252 gl.End();
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
253 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
254
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
255 void drawSpring(GL gl, vec2 a, vec2 b, uint zigs)
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
256 {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
257 zigs++;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
258
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
259 // Portion of length dedicated to connectors
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
260 const float connPart = 0.2;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
261
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
262 vec2 inc = (b - a) / (zigs);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
263 // One step from a to b
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
264 vec2 zigLen = inc * (1 - connPart);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
265 // Length of a connector
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
266 vec2 connLen = inc * (connPart / 2) * zigs;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
267 // Width of a zig
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
268 vec2 zigWidth = (b - a).rotatedHalfPi.normalized;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
269 gl.immediate(GL_LINE_STRIP,
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
270 {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
271 gl.Vertex2fv(a.ptr);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
272
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
273 a += connLen;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
274 gl.Vertex2fv(a.ptr);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
275
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
276 bool dir = true;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
277 a += zigWidth / 2 + zigLen / 2;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
278 for (int i = 0; i < zigs; i++) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
279 gl.Vertex2fv(a.ptr);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
280 a += zigLen;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
281 if (dir) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
282 a -= zigWidth;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
283 }else {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
284 a += zigWidth;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
285 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
286 dir = !dir;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
287 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
288
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
289 gl.Vertex2fv((b - connLen).ptr);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
290 gl.Vertex2fv(b.ptr);
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
291 });
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
292 }
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
293
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
294 void drawShape(GL gl, bzShape shape, bzXForm xf, Color color, bool core)
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
295 {
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
296 Color coreColor = Color(0.9f, 0.6f, 0.6f);
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
297
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
298 switch (shape.type) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
299 case bzShapeType.CIRCLE:
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
300 auto circle = cast(bzCircle)shape;
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
301
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
302 vec2 center = vec2.from(bzMul(xf, circle.localPosition));
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
303 float radius = circle.radius;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
304 vec2 axis = vec2.from(xf.R.col1);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
305
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
306 gl.drawSolidCircle(center, radius, axis, color);
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
307
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
308 if (core) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
309 gl.Color3f(coreColor.r, coreColor.g, coreColor.b);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
310 gl.drawCircle(center, radius - k_toiSlop);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
311 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
312 break;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
313 case bzShapeType.POLYGON:
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
314 {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
315 bzPolygon poly = cast(bzPolygon)shape;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
316 bzVec2[] vertices = poly.worldVertices;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
317 vec2[] verts;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
318 verts.length = vertices.length;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
319 foreach (int i, v; vertices) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
320 verts[i] = vec2.from(v);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
321 }
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
322
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
323 gl.drawSolidPolygon(verts, color);
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
324
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
325 if (core) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
326 bzVec2[] localCoreVertices = poly.coreVertices;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
327 verts.length = localCoreVertices.length;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
328 for (int i = 0; i < localCoreVertices.length; ++i) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
329 verts[i] = vec2.from(bzMul(xf, localCoreVertices[i]));
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
330 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
331 gl.drawPolygon(verts, coreColor);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
332 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
333 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
334 break;
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
335
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
336 case bzShapeType.EDGE:
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
337 {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
338 bzEdge edge = cast(bzEdge)shape;
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
339
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
340 vec2 p1 = vec2.from(bzMul(xf, edge.vertex1));
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
341 vec2 p2 = vec2.from(bzMul(xf, edge.vertex2));
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
342 gl.drawSegment(p1, p2, color);
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
343
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
344 if (core) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
345 p1 = vec2.from(bzMul(xf, edge.coreVertex1));
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
346 p2 = vec2.from(bzMul(xf, edge.coreVertex2));
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
347 gl.drawSegment(p1, p2, coreColor);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
348 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
349 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
350 break;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
351 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
352 }
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
353
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
354 void draw(vec2i screenSize, GL gl)
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
355 {
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
356
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
357 vec2 point1 = vec2.from(ship1.rBody.position);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
358 vec2 point2 = vec2.from(ship2.rBody.position);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
359 vec2 range = point1 - point2;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
360 zoom = bzClamp(1000/range.length, 2, 60);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
361 viewCenter = point1 - (range * 0.5f);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
362
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
363 this.screenSize = screenSize;
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
364
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
365 gl.LoadIdentity();
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
366 gl.MatrixMode(GL_PROJECTION);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
367 gl.LoadIdentity();
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
368
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
369 float left = -screenSize.x / zoom;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
370 float right = screenSize.x / zoom;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
371 float bottom = -screenSize.y / zoom;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
372 float top = screenSize.y / zoom;
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
373
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
374 gl.gluOrtho2D(left, right, bottom, top);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
375 gl.Translatef(-viewCenter.x, -viewCenter.y, 0);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
376 gl.MatrixMode(GL_MODELVIEW);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
377 gl.Disable(GL_DEPTH_TEST);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
378 gl.LoadIdentity();
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
379 gl.Clear(GL_COLOR_BUFFER_BIT);
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
380
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
381 vec2 pp1 = vec2.from(ship2.rBody.position);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
382 vec2 pp2 = vec2.from(ship2.state.target);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
383
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
384 //gl.drawSegment(pp1, pp2, Color(0, 1, 0));
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
385
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
386 // Draw dynamic bodies
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
387 if (settings.drawShapes) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
388 for (bzBody b = world.bodyList; b; b = b.next) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
389 for (bzShape shape = b.shapeList; shape; shape = shape.next) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
390
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
391 bzShape s = shape;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
392 bzXForm xf = b.xf;
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
393
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
394 if (b.isStatic) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
395 gl.drawShape(s, xf, Color(0.5f, 0.9f, 0.5f), settings.drawCoreShapes);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
396 }else if (b.isSleeping) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
397 gl.drawShape(s, xf, Color(0.5f, 0.5f, 0.9f), settings.drawCoreShapes);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
398 }else {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
399 gl.drawShape(s, xf, Color(0.9f, 0.9f, 0.9f), settings.drawCoreShapes);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
400 }
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
401
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
402 gl.LoadIdentity();
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
403 gl.Flush();
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
404 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
405 }
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
406 }
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
407
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
408 // Draw joints
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
409 /*
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
410 if (settings.drawJoints) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
411 Color color = Color(0, 0, 1);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
412 gl.Color3f(0, 0, 1);
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
413
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
414 gl.LineWidth(1);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
415 for (bzJoint joint = world.jointList; joint; joint = joint.next) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
416 auto distance = cast(bzDistanceJoint)joint;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
417 auto pulley = cast(bzPulleyJoint)joint;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
418 auto revolute = cast(bzRevoluteJoint)joint;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
419 auto prismatic = cast(bzPrismaticJoint)joint;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
420 auto line = cast(bzLineJoint)joint;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
421 if (distance) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
422 color = Color(.5, .5, 0);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
423 // Endpoints
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
424 vec2 a = vec2.from(distance.anchor1);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
425 vec2 b = vec2.from(distance.anchor2);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
426 // Circles
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
427 gl.drawCircle(a, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
428 gl.drawCircle(b, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
429 // Connecting line
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
430 gl.connectCircles(a, HINGE_RADIUS, b, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
431 }else if (pulley) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
432 auto a = vec2.from(pulley.anchor1);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
433 auto b = vec2.from(pulley.groundAnchor1);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
434 auto c = vec2.from(pulley.groundAnchor2);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
435 auto d = vec2.from(pulley.anchor2);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
436 gl.drawCircle(a, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
437 gl.drawCircle(b, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
438 gl.connectCircles(a, HINGE_RADIUS, b, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
439 gl.drawSegment(b, c, color);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
440 gl.drawCircle(c, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
441 gl.drawCircle(d, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
442 gl.connectCircles(c, HINGE_RADIUS, d, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
443 }else if (revolute) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
444 auto a = vec2.from(revolute.rBody1.position);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
445 auto b = vec2.from(revolute.anchor1);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
446 auto c = vec2.from(revolute.rBody2.position);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
447 gl.drawCircle(a, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
448 gl.drawCircle(b, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
449 gl.connectCircles(a, HINGE_RADIUS, b, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
450 gl.drawCircle(c, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
451 gl.connectCircles(b, HINGE_RADIUS, c, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
452 }else if (prismatic) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
453 auto a = vec2.from(prismatic.rBody1.position);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
454 auto b = vec2.from(prismatic.anchor1);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
455 auto c = vec2.from(prismatic.rBody2.position);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
456 gl.drawCircle(a, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
457 gl.drawCircle(b, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
458 gl.connectCircles(a, HINGE_RADIUS, b, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
459 gl.drawCircle(c, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
460 gl.connectCircles(b, HINGE_RADIUS, c, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
461 }else if (line) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
462 auto a = vec2.from(line.rBody1.position);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
463 auto b = vec2.from(line.anchor1);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
464 auto c = vec2.from(line.rBody2.position);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
465 gl.drawCircle(a, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
466 gl.drawCircle(b, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
467 gl.connectCircles(a, HINGE_RADIUS, b, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
468 gl.drawCircle(c, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
469 gl.connectCircles(b, HINGE_RADIUS, c, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
470 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
471 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
472
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
473
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
474 if (settings.drawControllers) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
475 bzForceGenerator[] forces = world.forces;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
476 foreach (f; forces) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
477 auto spring1 = cast(bzSpring1) f;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
478 auto spring2 = cast(bzSpring2) f;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
479 auto buoyancy = cast(bzBuoyancy) f;
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
480
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
481 if (spring1) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
482 auto bungee1 = cast(bzBungee1)spring1;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
483 if (bungee1) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
484 gl.Color3f(.5, .5, 0);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
485 // Endpoints
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
486 vec2 a = vec2.from(bungee1.rBody.position);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
487 vec2 b = vec2.from(bungee1.anchor);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
488 // Circles
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
489 gl.drawCircle(a, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
490 gl.drawCircle(b, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
491 // Connecting line
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
492 gl.connectCircles(a, HINGE_RADIUS, b, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
493 }else {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
494 uint zigs = 10;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
495 auto anchor1 = vec2.from(spring1.anchor);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
496 auto anchor2 = vec2.from(spring1.rBody.position);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
497 gl.drawSpring(anchor1, anchor2, zigs);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
498 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
499 }
2
a40d066ebbd1 implemented zoom
Zzzzrrr <mason.green@gmail.com>
parents: 0
diff changeset
500
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
501 if (spring2) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
502 auto bungee2 = cast(bzBungee2)spring2;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
503 if (bungee2) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
504 gl.Color3f(.5, .5, 0);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
505 // Endpoints
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
506 vec2 a = vec2.from(bungee2.rBody.position);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
507 vec2 b = vec2.from(bungee2.otherBody.position);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
508 // Circles
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
509 gl.drawCircle(a, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
510 gl.drawCircle(b, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
511 // Connecting line
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
512 gl.connectCircles(a, HINGE_RADIUS, b, HINGE_RADIUS);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
513 }else {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
514 uint zigs = 10;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
515 auto anchor1 = vec2.from(spring2.otherBody.position);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
516 auto anchor2 = vec2.from(spring2.rBody.position);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
517 gl.drawSpring(anchor1, anchor2, zigs);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
518 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
519 }
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
520
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
521 if(buoyancy) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
522 float plane = buoyancy.planeOffset;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
523 vec2 p1 = vec2(-50, plane);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
524 vec2 p2 = vec2(50, plane);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
525 gl.drawSegment(p1, p2, color);
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
526 }
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
527 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
528 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
529 }
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
530 */
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
531
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
532 // Draw the world bounds
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
533 bzBroadPhase bp = world.broadPhase;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
534 bzVec2 worldLower = bp.m_worldAABB.lowerBound;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
535 bzVec2 worldUpper = bp.m_worldAABB.upperBound;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
536 Color color = Color(0.3f, 0.9f, 0.9f);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
537 vec2 vs[4];
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
538 vs[0] = vec2(worldLower.x, worldLower.y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
539 vs[1] = vec2(worldUpper.x, worldLower.y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
540 vs[2] = vec2(worldUpper.x, worldUpper.y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
541 vs[3] = vec2(worldLower.x, worldUpper.y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
542 drawPolygon(gl, vs, color);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
543
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
544 // Draw axis aligned bounding boxes (bzAABB)
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
545 if (settings.drawAABBs) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
546 bzVec2 invQ;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
547 invQ.set(1.0f / bp.m_quantizationFactor.x, 1.0f / bp.m_quantizationFactor.y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
548 color = Color(1.0f, 1.0f, 1.0f);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
549
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
550 for (int i = 0; i < k_maxProxies; ++i) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
551 bzProxy p = bp.m_proxyPool[i];
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
552 if (!p.isValid) {
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
553 continue;
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
554 }
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
555
18
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
556 bzAABB b;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
557 b.lowerBound.x = worldLower.x + invQ.x * bp.m_bounds[0][p.lowerBounds[0]].value;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
558 b.lowerBound.y = worldLower.y + invQ.y * bp.m_bounds[1][p.lowerBounds[1]].value;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
559 b.upperBound.x = worldLower.x + invQ.x * bp.m_bounds[0][p.upperBounds[0]].value;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
560 b.upperBound.y = worldLower.y + invQ.y * bp.m_bounds[1][p.upperBounds[1]].value;
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
561
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
562 vs[0] = vec2(b.lowerBound.x, b.lowerBound.y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
563 vs[1] = vec2(b.upperBound.x, b.lowerBound.y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
564 vs[2] = vec2(b.upperBound.x, b.upperBound.y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
565 vs[3] = vec2(b.lowerBound.x, b.upperBound.y);
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
566
7f74e064dad5 refactored code
zzzzrrr <mason.green@gmail.com>
parents: 17
diff changeset
567 drawPolygon(gl, vs, color);
0
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
568 }
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
569 }
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
570 }
c10bc63824e7 Initial commit!
zzzzrrr <mason.green@gmail.com>
parents:
diff changeset
571 }