aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/Region/Physics/Meshing/PrimMesher.cs215
1 files changed, 189 insertions, 26 deletions
diff --git a/OpenSim/Region/Physics/Meshing/PrimMesher.cs b/OpenSim/Region/Physics/Meshing/PrimMesher.cs
index 8679f65..d7621d3 100644
--- a/OpenSim/Region/Physics/Meshing/PrimMesher.cs
+++ b/OpenSim/Region/Physics/Meshing/PrimMesher.cs
@@ -151,26 +151,20 @@ namespace OpenSim.Region.Physics.Meshing
151 internal class makeProfile 151 internal class makeProfile
152 { 152 {
153 private float twoPi = 2.0f * (float)Math.PI; 153 private float twoPi = 2.0f * (float)Math.PI;
154
154 internal List<vertex> coords; 155 internal List<vertex> coords;
155 internal List<vertex> hollowCoords;
156 internal List<face> faces; 156 internal List<face> faces;
157 157
158 internal int sides = 4; 158 internal makeProfile(int sides, float profileStart, float profileEnd, float hollow, int hollowSides)
159 internal int hollowSides = 7;
160 internal vertex center = new vertex(0.0f, 0.0f, 0.0f);
161
162 makeProfile(int sides, float profileStart, float profileEnd, float hollow, int hollowSides)
163 { 159 {
164 coords = new List<vertex>(); 160 this.coords = new List<vertex>();
165 hollowCoords = new List<vertex>(); 161 List<vertex> hollowCoords = new List<vertex>();
166 faces = new List<face>(); 162 this.faces = new List<face>();
163 vertex center = new vertex(0.0f, 0.0f, 0.0f);
167 164
168 AngleList angles = new AngleList(); 165 AngleList angles = new AngleList();
169 AngleList hollowAngles = new AngleList(); 166 AngleList hollowAngles = new AngleList();
170 167
171 this.sides = sides;
172 this.hollowSides = hollowSides;
173
174 float xScale = 0.5f; 168 float xScale = 0.5f;
175 float yScale = 0.5f; 169 float yScale = 0.5f;
176 if (sides == 4) // corners of a square are sqrt(2) from center 170 if (sides == 4) // corners of a square are sqrt(2) from center
@@ -181,18 +175,18 @@ namespace OpenSim.Region.Physics.Meshing
181 175
182 float startAngle = profileStart * twoPi; 176 float startAngle = profileStart * twoPi;
183 float stopAngle = profileEnd * twoPi; 177 float stopAngle = profileEnd * twoPi;
184 float stepSize = twoPi / this.sides; 178 float stepSize = twoPi / sides;
185 179
186 angles.makeAngles(this.sides, startAngle, stopAngle); 180 angles.makeAngles(sides, startAngle, stopAngle);
187 181
188 if (hollow > 0.001f) 182 if (hollow > 0.001f)
189 { 183 {
190 if (this.sides == this.hollowSides) 184 if (sides == hollowSides)
191 hollowAngles = angles; 185 hollowAngles = angles;
192 else 186 else
193 { 187 {
194 hollowAngles = new AngleList(); 188 hollowAngles = new AngleList();
195 hollowAngles.makeAngles(this.hollowSides, startAngle, stopAngle); 189 hollowAngles.makeAngles(hollowSides, startAngle, stopAngle);
196 } 190 }
197 } 191 }
198 else 192 else
@@ -201,7 +195,7 @@ namespace OpenSim.Region.Physics.Meshing
201 Angle angle; 195 Angle angle;
202 vertex newVert = new vertex(); 196 vertex newVert = new vertex();
203 197
204 if ( hollow > 0.001f && this.hollowSides != this.sides) 198 if (hollow > 0.001f && hollowSides != sides)
205 { 199 {
206 int numHollowAngles = hollowAngles.angles.Count; 200 int numHollowAngles = hollowAngles.angles.Count;
207 for (int i = 0; i < numHollowAngles; i++) 201 for (int i = 0; i < numHollowAngles; i++)
@@ -210,25 +204,194 @@ namespace OpenSim.Region.Physics.Meshing
210 newVert.X = hollow * xScale * angle.X; 204 newVert.X = hollow * xScale * angle.X;
211 newVert.Y = hollow * yScale * angle.Y; 205 newVert.Y = hollow * yScale * angle.Y;
212 newVert.Z = 0.0f; 206 newVert.Z = 0.0f;
213 this.hollowCoords.Add(newVert); 207
208 hollowCoords.Add(newVert);
214 } 209 }
215 } 210 }
216 211
217 int numAngles = angles.angles.Count; 212 int numAngles = angles.angles.Count;
218 for (int i = 0; i < numAngles; i++) 213 int index;
214 for (index = 0; index < numAngles; index++)
219 { 215 {
220 angle = angles.angles[i]; 216 angle = angles.angles[index];
221 newVert.X = angle.X * xScale; 217 newVert.X = angle.X * xScale;
222 newVert.Y = angle.Y * yScale; 218 newVert.Y = angle.Y * yScale;
223 newVert.Z = 0.0f; 219 newVert.Z = 0.0f;
224 this.coords.Add(newVert); 220 this.coords.Add(newVert);
221
222 if (hollow > 0.0f)
223 {
224 newVert.X = angle.X *= hollow;
225 newVert.Y = angle.Y *= hollow;
226 newVert.Z = 0.0f;
227 hollowCoords.Add(newVert);
228 }
229 else if (angle.angle > 0.0001f)
230 {
231 face newFace = new face();
232 newFace.v1 = 0;
233 newFace.v2 = index;
234 newFace.v3 = index;
235 this.faces.Add(newFace);
236 }
225 } 237 }
226
227 /*
228 continue at python source line 174
229
230 */
231 238
239 if (hollow > 0.0)
240 {
241 hollowCoords.Reverse();
242
243 int numOuterVerts = this.coords.Count;
244 int numHollowVerts = hollowCoords.Count;
245 int numTotalVerts = numOuterVerts + numHollowVerts;
246
247 if (numOuterVerts == numHollowVerts)
248 {
249 face newFace = new face();
250
251 for (int coordIndex = 0; coordIndex < numOuterVerts - 1; coordIndex++)
252 {
253 newFace.v1 = coordIndex;
254 newFace.v2 = coordIndex + 1;
255 newFace.v3 = numTotalVerts - coordIndex - 1;
256
257 this.faces.Add(newFace);
258
259 newFace.v1 = coordIndex + 1;
260 newFace.v2 = numTotalVerts - coordIndex - 2;
261 newFace.v3 = numTotalVerts - coordIndex - 1;
262
263 this.faces.Add(newFace);
264 }
265 }
266
267 else
268 {
269 if (numOuterVerts < numHollowVerts)
270 {
271 face newFace = new face();
272 int j = 0; // j is the index for outer vertices
273 int maxJ = numOuterVerts - 1;
274 for (int i = 0; i < numHollowVerts; i++) // i is the index for inner vertices
275 {
276 if (j < maxJ)
277 if (angles.angles[j + 1].angle - hollowAngles.angles[i].angle <= hollowAngles.angles[i].angle - angles.angles[j].angle)
278 {
279 newFace.v1 = numTotalVerts - i - 2;
280 newFace.v2 = j;
281 newFace.v3 = j + 1;
282
283 this.faces.Add(newFace);
284 j += 1;
285 }
286
287 newFace.v1 = j;
288 newFace.v2 = numTotalVerts - i - 2;
289 newFace.v3 = numTotalVerts - i - 1;
290
291 this.faces.Add(newFace);
292 }
293 }
294 else // numHollowVerts < numOuterVerts
295 {
296 face newFace = new face();
297 int j = 0; // j is the index for inner vertices
298 int maxJ = numHollowVerts - 1;
299 for (int i = 0; i < numOuterVerts; i++)
300 {
301 if (j < maxJ)
302 if (hollowAngles.angles[j + 1].angle - angles.angles[i].angle <= angles.angles[i].angle - hollowAngles.angles[j].angle)
303 {
304 newFace.v1 = i;
305 newFace.v2 = numTotalVerts - j - 2;
306 newFace.v3 = numTotalVerts - j - 1;
307
308 this.faces.Add(newFace);
309 j += 1;
310 }
311
312 newFace.v1 = numTotalVerts - j - 1;
313 newFace.v2 = i;
314 newFace.v3 = i + 1;
315
316 this.faces.Add(newFace);
317 }
318 }
319
320 }
321
322 this.coords.AddRange(hollowCoords);
323 }
324 }
325
326 internal void addPos(vertex v)
327 {
328 this.addPos(v.X, v.Y, v.Z);
329 }
330
331 internal void addPos(float x, float y, float z)
332 {
333 int i;
334 int numVerts = this.coords.Count;
335 vertex vert;
336
337 for (i = 0; i < numVerts; i++)
338 {
339 vert = this.coords[i];
340 vert.X += x;
341 vert.Y += y;
342 vert.Z += z;
343 }
344 }
345
346 internal void addRot(Quaternion q)
347 {
348 int i;
349 int numVerts = this.coords.Count;
350 vertex vert;
351
352 for (i = 0; i < numVerts; i++)
353 {
354 vert = this.coords[i];
355 Vertex v = new Vertex(vert.X, vert.Y, vert.Z);
356
357 v = v * q;
358
359 vert.X = v.X;
360 vert.Y = v.Y;
361 vert.Z = v.Z;
362 }
363 }
364
365 internal void scale(float x, float y, float z)
366 {
367 int i;
368 int numVerts = this.coords.Count;
369 vertex vert;
370
371 for (i = 0; i < numVerts; i++)
372 {
373 vert = this.coords[i];
374
375 vert.X *= x;
376 vert.Y *= y;
377 vert.Z *= z;
378 }
379 }
380
381 internal void flipNormals()
382 {
383 int i;
384 int numFaces = this.faces.Count;
385 face tmpFace;
386 int tmp;
387
388 for (i = 0; i < numFaces; i++)
389 {
390 tmpFace = this.faces[i];
391 tmp = tmpFace.v3;
392 tmpFace.v3 = tmpFace.v1;
393 tmpFace.v1 = tmp;
394 }
232 } 395 }
233 } 396 }
234 397