aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/Framework
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/Framework')
-rw-r--r--OpenSim/Region/Framework/Scenes/SOPVehicle.cs487
-rw-r--r--OpenSim/Region/Framework/Scenes/Scene.cs2
-rw-r--r--OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs54
-rw-r--r--OpenSim/Region/Framework/Scenes/SceneObjectPart.cs109
-rw-r--r--OpenSim/Region/Framework/Scenes/ScenePresence.cs10
5 files changed, 636 insertions, 26 deletions
diff --git a/OpenSim/Region/Framework/Scenes/SOPVehicle.cs b/OpenSim/Region/Framework/Scenes/SOPVehicle.cs
new file mode 100644
index 0000000..39786bd
--- /dev/null
+++ b/OpenSim/Region/Framework/Scenes/SOPVehicle.cs
@@ -0,0 +1,487 @@
1/*
2 * Copyright (c) Contributors, http://opensimulator.org/
3 * See CONTRIBUTORS.TXT for a full list of copyright holders.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions are met:
7 * * Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * * Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
12 * * Neither the name of the OpenSimulator Project nor the
13 * names of its contributors may be used to endorse or promote products
14 * derived from this software without specific prior written permission.
15 *
16 * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
17 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19 * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
20 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
21 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
22 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
23 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
25 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 */
27
28using System;
29using OpenMetaverse;
30using OpenSim.Framework;
31using OpenSim.Region.Physics.Manager;
32using System.Xml;
33using OpenSim.Framework.Serialization;
34using OpenSim.Framework.Serialization.External;
35using OpenSim.Region.Framework.Scenes.Serialization;
36
37namespace OpenSim.Region.Framework.Scenes
38{
39 public class SOPVehicle
40 {
41 public VehicleData vd;
42
43 public Vehicle Type
44 {
45 get { return vd.m_type; }
46 }
47
48 public SOPVehicle()
49 {
50 vd = new VehicleData();
51 ProcessTypeChange(Vehicle.TYPE_NONE); // is needed?
52 }
53
54 public void ProcessFloatVehicleParam(Vehicle pParam, float pValue)
55 {
56 float len;
57 float timestep = 0.01f;
58 switch (pParam)
59 {
60 case Vehicle.ANGULAR_DEFLECTION_EFFICIENCY:
61 if (pValue < 0f) pValue = 0f;
62 if (pValue > 1f) pValue = 1f;
63 vd.m_angularDeflectionEfficiency = pValue;
64 break;
65 case Vehicle.ANGULAR_DEFLECTION_TIMESCALE:
66 if (pValue < timestep) pValue = timestep;
67 vd.m_angularDeflectionTimescale = pValue;
68 break;
69 case Vehicle.ANGULAR_MOTOR_DECAY_TIMESCALE:
70 if (pValue < timestep) pValue = timestep;
71 else if (pValue > 120) pValue = 120;
72 vd.m_angularMotorDecayTimescale = pValue;
73 break;
74 case Vehicle.ANGULAR_MOTOR_TIMESCALE:
75 if (pValue < timestep) pValue = timestep;
76 vd.m_angularMotorTimescale = pValue;
77 break;
78 case Vehicle.BANKING_EFFICIENCY:
79 if (pValue < -1f) pValue = -1f;
80 if (pValue > 1f) pValue = 1f;
81 vd.m_bankingEfficiency = pValue;
82 break;
83 case Vehicle.BANKING_MIX:
84 if (pValue < 0f) pValue = 0f;
85 if (pValue > 1f) pValue = 1f;
86 vd.m_bankingMix = pValue;
87 break;
88 case Vehicle.BANKING_TIMESCALE:
89 if (pValue < timestep) pValue = timestep;
90 vd.m_bankingTimescale = pValue;
91 break;
92 case Vehicle.BUOYANCY:
93 if (pValue < -1f) pValue = -1f;
94 if (pValue > 1f) pValue = 1f;
95 vd.m_VehicleBuoyancy = pValue;
96 break;
97 case Vehicle.HOVER_EFFICIENCY:
98 if (pValue < 0f) pValue = 0f;
99 if (pValue > 1f) pValue = 1f;
100 vd.m_VhoverEfficiency = pValue;
101 break;
102 case Vehicle.HOVER_HEIGHT:
103 vd.m_VhoverHeight = pValue;
104 break;
105 case Vehicle.HOVER_TIMESCALE:
106 if (pValue < timestep) pValue = timestep;
107 vd.m_VhoverTimescale = pValue;
108 break;
109 case Vehicle.LINEAR_DEFLECTION_EFFICIENCY:
110 if (pValue < 0f) pValue = 0f;
111 if (pValue > 1f) pValue = 1f;
112 vd.m_linearDeflectionEfficiency = pValue;
113 break;
114 case Vehicle.LINEAR_DEFLECTION_TIMESCALE:
115 if (pValue < timestep) pValue = timestep;
116 vd.m_linearDeflectionTimescale = pValue;
117 break;
118 case Vehicle.LINEAR_MOTOR_DECAY_TIMESCALE:
119 // if (pValue < timestep) pValue = timestep;
120 // try to make impulses to work a bit better
121 if (pValue < timestep) pValue = timestep;
122 else if (pValue > 120) pValue = 120;
123 vd.m_linearMotorDecayTimescale = pValue;
124 break;
125 case Vehicle.LINEAR_MOTOR_TIMESCALE:
126 if (pValue < timestep) pValue = timestep;
127 vd.m_linearMotorTimescale = pValue;
128 break;
129 case Vehicle.VERTICAL_ATTRACTION_EFFICIENCY:
130 if (pValue < 0f) pValue = 0f;
131 if (pValue > 1f) pValue = 1f;
132 vd.m_verticalAttractionEfficiency = pValue;
133 break;
134 case Vehicle.VERTICAL_ATTRACTION_TIMESCALE:
135 if (pValue < timestep) pValue = timestep;
136 vd.m_verticalAttractionTimescale = pValue;
137 break;
138
139 // These are vector properties but the engine lets you use a single float value to
140 // set all of the components to the same value
141 case Vehicle.ANGULAR_FRICTION_TIMESCALE:
142 if (pValue < timestep) pValue = timestep;
143 vd.m_angularFrictionTimescale = new Vector3(pValue, pValue, pValue);
144 break;
145 case Vehicle.ANGULAR_MOTOR_DIRECTION:
146 vd.m_angularMotorDirection = new Vector3(pValue, pValue, pValue);
147 len = vd.m_angularMotorDirection.Length();
148 if (len > 12.566f)
149 vd.m_angularMotorDirection *= (12.566f / len);
150 break;
151 case Vehicle.LINEAR_FRICTION_TIMESCALE:
152 if (pValue < timestep) pValue = timestep;
153 vd.m_linearFrictionTimescale = new Vector3(pValue, pValue, pValue);
154 break;
155 case Vehicle.LINEAR_MOTOR_DIRECTION:
156 vd.m_linearMotorDirection = new Vector3(pValue, pValue, pValue);
157 len = vd.m_linearMotorDirection.Length();
158 if (len > 30.0f)
159 vd.m_linearMotorDirection *= (30.0f / len);
160 break;
161 case Vehicle.LINEAR_MOTOR_OFFSET:
162 vd.m_linearMotorOffset = new Vector3(pValue, pValue, pValue);
163 len = vd.m_linearMotorOffset.Length();
164 if (len > 100.0f)
165 vd.m_linearMotorOffset *= (100.0f / len);
166 break;
167 }
168 }//end ProcessFloatVehicleParam
169
170 public void ProcessVectorVehicleParam(Vehicle pParam, Vector3 pValue)
171 {
172 float len;
173 float timestep = 0.01f;
174 switch (pParam)
175 {
176 case Vehicle.ANGULAR_FRICTION_TIMESCALE:
177 if (pValue.X < timestep) pValue.X = timestep;
178 if (pValue.Y < timestep) pValue.Y = timestep;
179 if (pValue.Z < timestep) pValue.Z = timestep;
180
181 vd.m_angularFrictionTimescale = new Vector3(pValue.X, pValue.Y, pValue.Z);
182 break;
183 case Vehicle.ANGULAR_MOTOR_DIRECTION:
184 vd.m_angularMotorDirection = new Vector3(pValue.X, pValue.Y, pValue.Z);
185 // Limit requested angular speed to 2 rps= 4 pi rads/sec
186 len = vd.m_angularMotorDirection.Length();
187 if (len > 12.566f)
188 vd.m_angularMotorDirection *= (12.566f / len);
189 break;
190 case Vehicle.LINEAR_FRICTION_TIMESCALE:
191 if (pValue.X < timestep) pValue.X = timestep;
192 if (pValue.Y < timestep) pValue.Y = timestep;
193 if (pValue.Z < timestep) pValue.Z = timestep;
194 vd.m_linearFrictionTimescale = new Vector3(pValue.X, pValue.Y, pValue.Z);
195 break;
196 case Vehicle.LINEAR_MOTOR_DIRECTION:
197 vd.m_linearMotorDirection = new Vector3(pValue.X, pValue.Y, pValue.Z);
198 len = vd.m_linearMotorDirection.Length();
199 if (len > 30.0f)
200 vd.m_linearMotorDirection *= (30.0f / len);
201 break;
202 case Vehicle.LINEAR_MOTOR_OFFSET:
203 vd.m_linearMotorOffset = new Vector3(pValue.X, pValue.Y, pValue.Z);
204 len = vd.m_linearMotorOffset.Length();
205 if (len > 100.0f)
206 vd.m_linearMotorOffset *= (100.0f / len);
207 break;
208 }
209 }//end ProcessVectorVehicleParam
210
211 public void ProcessRotationVehicleParam(Vehicle pParam, Quaternion pValue)
212 {
213 switch (pParam)
214 {
215 case Vehicle.REFERENCE_FRAME:
216 vd.m_referenceFrame = Quaternion.Inverse(pValue);
217 break;
218 }
219 }//end ProcessRotationVehicleParam
220
221 public void ProcessVehicleFlags(int pParam, bool remove)
222 {
223 if (remove)
224 {
225 vd.m_flags &= ~((VehicleFlag)pParam);
226 }
227 else
228 {
229 vd.m_flags |= (VehicleFlag)pParam;
230 }
231 }//end ProcessVehicleFlags
232
233 public void ProcessTypeChange(Vehicle pType)
234 {
235 vd.m_linearMotorDirection = Vector3.Zero;
236 vd.m_angularMotorDirection = Vector3.Zero;
237 vd.m_linearMotorOffset = Vector3.Zero;
238 vd.m_referenceFrame = Quaternion.Identity;
239
240 // Set Defaults For Type
241 vd.m_type = pType;
242 switch (pType)
243 {
244 case Vehicle.TYPE_NONE:
245 vd.m_linearFrictionTimescale = new Vector3(1000, 1000, 1000);
246 vd.m_angularFrictionTimescale = new Vector3(1000, 1000, 1000);
247 vd.m_linearMotorTimescale = 1000;
248 vd.m_linearMotorDecayTimescale = 120;
249 vd.m_angularMotorTimescale = 1000;
250 vd.m_angularMotorDecayTimescale = 1000;
251 vd.m_VhoverHeight = 0;
252 vd.m_VhoverEfficiency = 1;
253 vd.m_VhoverTimescale = 1000;
254 vd.m_VehicleBuoyancy = 0;
255 vd.m_linearDeflectionEfficiency = 0;
256 vd.m_linearDeflectionTimescale = 1000;
257 vd.m_angularDeflectionEfficiency = 0;
258 vd.m_angularDeflectionTimescale = 1000;
259 vd.m_bankingEfficiency = 0;
260 vd.m_bankingMix = 1;
261 vd.m_bankingTimescale = 1000;
262 vd.m_verticalAttractionEfficiency = 0;
263 vd.m_verticalAttractionTimescale = 1000;
264
265 vd.m_flags = (VehicleFlag)0;
266 break;
267
268 case Vehicle.TYPE_SLED:
269 vd.m_linearFrictionTimescale = new Vector3(30, 1, 1000);
270 vd.m_angularFrictionTimescale = new Vector3(1000, 1000, 1000);
271 vd.m_linearMotorTimescale = 1000;
272 vd.m_linearMotorDecayTimescale = 120;
273 vd.m_angularMotorTimescale = 1000;
274 vd.m_angularMotorDecayTimescale = 120;
275 vd.m_VhoverHeight = 0;
276 vd.m_VhoverEfficiency = 1;
277 vd.m_VhoverTimescale = 10;
278 vd.m_VehicleBuoyancy = 0;
279 vd.m_linearDeflectionEfficiency = 1;
280 vd.m_linearDeflectionTimescale = 1;
281 vd.m_angularDeflectionEfficiency = 0;
282 vd.m_angularDeflectionTimescale = 1000;
283 vd.m_bankingEfficiency = 0;
284 vd.m_bankingMix = 1;
285 vd.m_bankingTimescale = 10;
286 vd.m_flags &=
287 ~(VehicleFlag.HOVER_WATER_ONLY | VehicleFlag.HOVER_TERRAIN_ONLY |
288 VehicleFlag.HOVER_GLOBAL_HEIGHT | VehicleFlag.HOVER_UP_ONLY);
289 vd.m_flags |= (VehicleFlag.NO_DEFLECTION_UP | VehicleFlag.LIMIT_ROLL_ONLY | VehicleFlag.LIMIT_MOTOR_UP);
290 break;
291 case Vehicle.TYPE_CAR:
292 vd.m_linearFrictionTimescale = new Vector3(100, 2, 1000);
293 vd.m_angularFrictionTimescale = new Vector3(1000, 1000, 1000);
294 vd.m_linearMotorTimescale = 1;
295 vd.m_linearMotorDecayTimescale = 60;
296 vd.m_angularMotorTimescale = 1;
297 vd.m_angularMotorDecayTimescale = 0.8f;
298 vd.m_VhoverHeight = 0;
299 vd.m_VhoverEfficiency = 0;
300 vd.m_VhoverTimescale = 1000;
301 vd.m_VehicleBuoyancy = 0;
302 vd.m_linearDeflectionEfficiency = 1;
303 vd.m_linearDeflectionTimescale = 2;
304 vd.m_angularDeflectionEfficiency = 0;
305 vd.m_angularDeflectionTimescale = 10;
306 vd.m_verticalAttractionEfficiency = 1f;
307 vd.m_verticalAttractionTimescale = 10f;
308 vd.m_bankingEfficiency = -0.2f;
309 vd.m_bankingMix = 1;
310 vd.m_bankingTimescale = 1;
311 vd.m_flags &= ~(VehicleFlag.HOVER_WATER_ONLY | VehicleFlag.HOVER_TERRAIN_ONLY | VehicleFlag.HOVER_GLOBAL_HEIGHT);
312 vd.m_flags |= (VehicleFlag.NO_DEFLECTION_UP | VehicleFlag.LIMIT_ROLL_ONLY |
313 VehicleFlag.LIMIT_MOTOR_UP | VehicleFlag.HOVER_UP_ONLY);
314 break;
315 case Vehicle.TYPE_BOAT:
316 vd.m_linearFrictionTimescale = new Vector3(10, 3, 2);
317 vd.m_angularFrictionTimescale = new Vector3(10, 10, 10);
318 vd.m_linearMotorTimescale = 5;
319 vd.m_linearMotorDecayTimescale = 60;
320 vd.m_angularMotorTimescale = 4;
321 vd.m_angularMotorDecayTimescale = 4;
322 vd.m_VhoverHeight = 0;
323 vd.m_VhoverEfficiency = 0.5f;
324 vd.m_VhoverTimescale = 2;
325 vd.m_VehicleBuoyancy = 1;
326 vd.m_linearDeflectionEfficiency = 0.5f;
327 vd.m_linearDeflectionTimescale = 3;
328 vd.m_angularDeflectionEfficiency = 0.5f;
329 vd.m_angularDeflectionTimescale = 5;
330 vd.m_verticalAttractionEfficiency = 0.5f;
331 vd.m_verticalAttractionTimescale = 5f;
332 vd.m_bankingEfficiency = -0.3f;
333 vd.m_bankingMix = 0.8f;
334 vd.m_bankingTimescale = 1;
335 vd.m_flags &= ~(VehicleFlag.HOVER_TERRAIN_ONLY |
336 VehicleFlag.HOVER_GLOBAL_HEIGHT |
337 VehicleFlag.HOVER_UP_ONLY |
338 VehicleFlag.LIMIT_ROLL_ONLY);
339 vd.m_flags |= (VehicleFlag.NO_DEFLECTION_UP |
340 VehicleFlag.LIMIT_MOTOR_UP |
341 VehicleFlag.HOVER_WATER_ONLY);
342 break;
343 case Vehicle.TYPE_AIRPLANE:
344 vd.m_linearFrictionTimescale = new Vector3(200, 10, 5);
345 vd.m_angularFrictionTimescale = new Vector3(20, 20, 20);
346 vd.m_linearMotorTimescale = 2;
347 vd.m_linearMotorDecayTimescale = 60;
348 vd.m_angularMotorTimescale = 4;
349 vd.m_angularMotorDecayTimescale = 8;
350 vd.m_VhoverHeight = 0;
351 vd.m_VhoverEfficiency = 0.5f;
352 vd.m_VhoverTimescale = 1000;
353 vd.m_VehicleBuoyancy = 0;
354 vd.m_linearDeflectionEfficiency = 0.5f;
355 vd.m_linearDeflectionTimescale = 0.5f;
356 vd.m_angularDeflectionEfficiency = 1;
357 vd.m_angularDeflectionTimescale = 2;
358 vd.m_verticalAttractionEfficiency = 0.9f;
359 vd.m_verticalAttractionTimescale = 2f;
360 vd.m_bankingEfficiency = 1;
361 vd.m_bankingMix = 0.7f;
362 vd.m_bankingTimescale = 2;
363 vd.m_flags &= ~(VehicleFlag.HOVER_WATER_ONLY |
364 VehicleFlag.HOVER_TERRAIN_ONLY |
365 VehicleFlag.HOVER_GLOBAL_HEIGHT |
366 VehicleFlag.HOVER_UP_ONLY |
367 VehicleFlag.NO_DEFLECTION_UP |
368 VehicleFlag.LIMIT_MOTOR_UP);
369 vd.m_flags |= (VehicleFlag.LIMIT_ROLL_ONLY);
370 break;
371 case Vehicle.TYPE_BALLOON:
372 vd.m_linearFrictionTimescale = new Vector3(5, 5, 5);
373 vd.m_angularFrictionTimescale = new Vector3(10, 10, 10);
374 vd.m_linearMotorTimescale = 5;
375 vd.m_linearMotorDecayTimescale = 60;
376 vd.m_angularMotorTimescale = 6;
377 vd.m_angularMotorDecayTimescale = 10;
378 vd.m_VhoverHeight = 5;
379 vd.m_VhoverEfficiency = 0.8f;
380 vd.m_VhoverTimescale = 10;
381 vd.m_VehicleBuoyancy = 1;
382 vd.m_linearDeflectionEfficiency = 0;
383 vd.m_linearDeflectionTimescale = 5;
384 vd.m_angularDeflectionEfficiency = 0;
385 vd.m_angularDeflectionTimescale = 5;
386 vd.m_verticalAttractionEfficiency = 0f;
387 vd.m_verticalAttractionTimescale = 1000f;
388 vd.m_bankingEfficiency = 0;
389 vd.m_bankingMix = 0.7f;
390 vd.m_bankingTimescale = 5;
391 vd.m_flags &= ~(VehicleFlag.HOVER_WATER_ONLY |
392 VehicleFlag.HOVER_TERRAIN_ONLY |
393 VehicleFlag.HOVER_UP_ONLY |
394 VehicleFlag.NO_DEFLECTION_UP |
395 VehicleFlag.LIMIT_MOTOR_UP);
396 vd.m_flags |= (VehicleFlag.LIMIT_ROLL_ONLY |
397 VehicleFlag.HOVER_GLOBAL_HEIGHT);
398 break;
399 }
400 }
401 public void SetVehicle(PhysicsActor ph)
402 {
403 if (ph == null)
404 return;
405 ph.SetVehicle(vd);
406 }
407
408 private XmlTextWriter writer;
409
410 private void XWint(string name, int i)
411 {
412 writer.WriteElementString(name, i.ToString());
413 }
414
415 private void XWfloat(string name, float f)
416 {
417 writer.WriteElementString(name, f.ToString(Utils.EnUsCulture));
418 }
419
420 private void XWVector(string name, Vector3 vec)
421 {
422 writer.WriteStartElement(name);
423 writer.WriteElementString("X", vec.X.ToString(Utils.EnUsCulture));
424 writer.WriteElementString("Y", vec.Y.ToString(Utils.EnUsCulture));
425 writer.WriteElementString("Z", vec.Z.ToString(Utils.EnUsCulture));
426 writer.WriteEndElement();
427 }
428
429 private void XWQuat(string name, Quaternion quat)
430 {
431 writer.WriteStartElement(name);
432 writer.WriteElementString("X", quat.X.ToString(Utils.EnUsCulture));
433 writer.WriteElementString("Y", quat.Y.ToString(Utils.EnUsCulture));
434 writer.WriteElementString("Z", quat.Z.ToString(Utils.EnUsCulture));
435 writer.WriteElementString("W", quat.W.ToString(Utils.EnUsCulture));
436 writer.WriteEndElement();
437 }
438
439 public void ToXml2(XmlTextWriter twriter)
440 {
441 writer = twriter;
442 writer.WriteStartElement("SOGVehicle");
443
444 XWint("TYPE", (int)vd.m_type);
445 XWint("FLAGS", (int)vd.m_flags);
446
447 // Linear properties
448 XWVector("LMDIR", vd.m_linearMotorDirection);
449 XWVector("LMFTIME", vd.m_linearFrictionTimescale);
450 XWfloat("LMDTIME", vd.m_linearMotorDecayTimescale);
451 XWfloat("LMTIME", vd.m_linearMotorTimescale);
452 XWVector("LMOFF", vd.m_linearMotorOffset);
453
454 //Angular properties
455 XWVector("AMDIR", vd.m_angularMotorDirection);
456 XWfloat("AMTIME", vd.m_angularMotorTimescale);
457 XWfloat("AMDTIME", vd.m_angularMotorDecayTimescale);
458 XWVector("AMFTIME", vd.m_angularFrictionTimescale);
459
460 //Deflection properties
461 XWfloat("ADEFF", vd.m_angularDeflectionEfficiency);
462 XWfloat("ADTIME", vd.m_angularDeflectionTimescale);
463 XWfloat("LDEFF", vd.m_linearDeflectionEfficiency);
464 XWfloat("LDTIME", vd.m_linearDeflectionTimescale);
465
466 //Banking properties
467 XWfloat("BEFF", vd.m_bankingEfficiency);
468 XWfloat("BMIX", vd.m_bankingMix);
469 XWfloat("BTIME", vd.m_bankingTimescale);
470
471 //Hover and Buoyancy properties
472 XWfloat("HHEI", vd.m_VhoverHeight);
473 XWfloat("HEFF", vd.m_VhoverEfficiency);
474 XWfloat("HTIME", vd.m_VhoverTimescale);
475 XWfloat("VBUO", vd.m_VehicleBuoyancy);
476
477 //Attractor properties
478 XWfloat("VAEFF", vd.m_verticalAttractionEfficiency);
479 XWfloat("VATIME", vd.m_verticalAttractionTimescale);
480
481 XWQuat("REF_FRAME", vd.m_referenceFrame);
482
483 writer.WriteEndElement();
484 writer = null;
485 }
486 }
487} \ No newline at end of file
diff --git a/OpenSim/Region/Framework/Scenes/Scene.cs b/OpenSim/Region/Framework/Scenes/Scene.cs
index 7b1ef40..6274e02 100644
--- a/OpenSim/Region/Framework/Scenes/Scene.cs
+++ b/OpenSim/Region/Framework/Scenes/Scene.cs
@@ -4792,7 +4792,7 @@ Environment.Exit(1);
4792 bool wasUsingPhysics = ((jointProxyObject.Flags & PrimFlags.Physics) != 0); 4792 bool wasUsingPhysics = ((jointProxyObject.Flags & PrimFlags.Physics) != 0);
4793 if (wasUsingPhysics) 4793 if (wasUsingPhysics)
4794 { 4794 {
4795 jointProxyObject.UpdatePrimFlags(false, false, true, false); // FIXME: possible deadlock here; check to make sure all the scene alterations set into motion here won't deadlock 4795 jointProxyObject.UpdatePrimFlags(false, false, true, false,false); // FIXME: possible deadlock here; check to make sure all the scene alterations set into motion here won't deadlock
4796 } 4796 }
4797 } 4797 }
4798 4798
diff --git a/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs b/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs
index cbd45c3..2481dd2 100644
--- a/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs
+++ b/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs
@@ -43,6 +43,7 @@ using OpenSim.Region.Framework.Scenes.Serialization;
43 43
44namespace OpenSim.Region.Framework.Scenes 44namespace OpenSim.Region.Framework.Scenes
45{ 45{
46
46 [Flags] 47 [Flags]
47 public enum scriptEvents 48 public enum scriptEvents
48 { 49 {
@@ -1378,7 +1379,8 @@ namespace OpenSim.Region.Framework.Scenes
1378 1379
1379 m_rootPart.SetParentLocalId(0); 1380 m_rootPart.SetParentLocalId(0);
1380 AttachmentPoint = (byte)0; 1381 AttachmentPoint = (byte)0;
1381 m_rootPart.ApplyPhysics(m_rootPart.GetEffectiveObjectFlags(), m_rootPart.VolumeDetectActive); 1382 // must check if buildind should be true or false here
1383 m_rootPart.ApplyPhysics(m_rootPart.GetEffectiveObjectFlags(), m_rootPart.VolumeDetectActive,false);
1382 HasGroupChanged = true; 1384 HasGroupChanged = true;
1383 RootPart.Rezzed = DateTime.Now; 1385 RootPart.Rezzed = DateTime.Now;
1384 RootPart.RemFlag(PrimFlags.TemporaryOnRez); 1386 RootPart.RemFlag(PrimFlags.TemporaryOnRez);
@@ -1677,22 +1679,32 @@ namespace OpenSim.Region.Framework.Scenes
1677 /// </summary> 1679 /// </summary>
1678 public void ApplyPhysics() 1680 public void ApplyPhysics()
1679 { 1681 {
1680 // Apply physics to the root prim
1681 m_rootPart.ApplyPhysics(m_rootPart.GetEffectiveObjectFlags(), m_rootPart.VolumeDetectActive);
1682
1683 // Apply physics to child prims
1684 SceneObjectPart[] parts = m_parts.GetArray(); 1682 SceneObjectPart[] parts = m_parts.GetArray();
1685 if (parts.Length > 1) 1683 if (parts.Length > 1)
1686 { 1684 {
1685 ResetChildPrimPhysicsPositions();
1686
1687 // Apply physics to the root prim
1688 m_rootPart.ApplyPhysics(m_rootPart.GetEffectiveObjectFlags(), m_rootPart.VolumeDetectActive, true);
1689
1690
1687 for (int i = 0; i < parts.Length; i++) 1691 for (int i = 0; i < parts.Length; i++)
1688 { 1692 {
1689 SceneObjectPart part = parts[i]; 1693 SceneObjectPart part = parts[i];
1690 if (part.LocalId != m_rootPart.LocalId) 1694 if (part.LocalId != m_rootPart.LocalId)
1691 part.ApplyPhysics(m_rootPart.GetEffectiveObjectFlags(), part.VolumeDetectActive); 1695 part.ApplyPhysics(m_rootPart.GetEffectiveObjectFlags(), part.VolumeDetectActive, true);
1692 } 1696 }
1693
1694 // Hack to get the physics scene geometries in the right spot 1697 // Hack to get the physics scene geometries in the right spot
1695 ResetChildPrimPhysicsPositions(); 1698// ResetChildPrimPhysicsPositions();
1699 if (m_rootPart.PhysActor != null)
1700 {
1701 m_rootPart.PhysActor.Building = false;
1702 }
1703 }
1704 else
1705 {
1706 // Apply physics to the root prim
1707 m_rootPart.ApplyPhysics(m_rootPart.GetEffectiveObjectFlags(), m_rootPart.VolumeDetectActive, false);
1696 } 1708 }
1697 } 1709 }
1698 1710
@@ -1863,6 +1875,7 @@ namespace OpenSim.Region.Framework.Scenes
1863 /// <returns></returns> 1875 /// <returns></returns>
1864 public SceneObjectGroup Copy(bool userExposed) 1876 public SceneObjectGroup Copy(bool userExposed)
1865 { 1877 {
1878 m_dupeInProgress = true;
1866 SceneObjectGroup dupe = (SceneObjectGroup)MemberwiseClone(); 1879 SceneObjectGroup dupe = (SceneObjectGroup)MemberwiseClone();
1867 dupe.m_isBackedUp = false; 1880 dupe.m_isBackedUp = false;
1868 dupe.m_parts = new MapAndArray<OpenMetaverse.UUID, SceneObjectPart>(); 1881 dupe.m_parts = new MapAndArray<OpenMetaverse.UUID, SceneObjectPart>();
@@ -1926,13 +1939,16 @@ namespace OpenSim.Region.Framework.Scenes
1926 pbs, 1939 pbs,
1927 newPart.AbsolutePosition, 1940 newPart.AbsolutePosition,
1928 newPart.Scale, 1941 newPart.Scale,
1929 newPart.RotationOffset, 1942 //newPart.RotationOffset,
1943 newPart.GetWorldRotation(),
1930 part.PhysActor.IsPhysical, 1944 part.PhysActor.IsPhysical,
1931 newPart.LocalId); 1945 newPart.LocalId);
1932 1946
1933 newPart.DoPhysicsPropertyUpdate(part.PhysActor.IsPhysical, true); 1947 newPart.DoPhysicsPropertyUpdate(part.PhysActor.IsPhysical, true);
1934 } 1948 }
1935 } 1949 }
1950 if (dupe.m_rootPart.PhysActor != null && userExposed)
1951 dupe.m_rootPart.PhysActor.Building = false; // tell physics to finish building
1936 1952
1937 if (userExposed) 1953 if (userExposed)
1938 { 1954 {
@@ -1943,6 +1959,7 @@ namespace OpenSim.Region.Framework.Scenes
1943 ScheduleGroupForFullUpdate(); 1959 ScheduleGroupForFullUpdate();
1944 } 1960 }
1945 1961
1962 m_dupeInProgress = false;
1946 return dupe; 1963 return dupe;
1947 } 1964 }
1948 1965
@@ -2950,12 +2967,31 @@ namespace OpenSim.Region.Framework.Scenes
2950 } 2967 }
2951 } 2968 }
2952 2969
2970/*
2953 RootPart.UpdatePrimFlags(UsePhysics, SetTemporary, SetPhantom, SetVolumeDetect); 2971 RootPart.UpdatePrimFlags(UsePhysics, SetTemporary, SetPhantom, SetVolumeDetect);
2954 for (int i = 0; i < parts.Length; i++) 2972 for (int i = 0; i < parts.Length; i++)
2955 { 2973 {
2956 if (parts[i] != RootPart) 2974 if (parts[i] != RootPart)
2957 parts[i].UpdatePrimFlags(UsePhysics, SetTemporary, SetPhantom, SetVolumeDetect); 2975 parts[i].UpdatePrimFlags(UsePhysics, SetTemporary, SetPhantom, SetVolumeDetect);
2958 } 2976 }
2977*/
2978 if (parts.Length > 1)
2979 {
2980 m_rootPart.UpdatePrimFlags(UsePhysics, SetTemporary, SetPhantom, SetVolumeDetect, true);
2981
2982 for (int i = 0; i < parts.Length; i++)
2983 {
2984
2985 if (parts[i].UUID != m_rootPart.UUID)
2986 parts[i].UpdatePrimFlags(UsePhysics, SetTemporary, SetPhantom, SetVolumeDetect, true);
2987 }
2988
2989 if (m_rootPart.PhysActor != null)
2990 m_rootPart.PhysActor.Building = false;
2991 }
2992 else
2993 m_rootPart.UpdatePrimFlags(UsePhysics, SetTemporary, SetPhantom, SetVolumeDetect, false);
2994
2959 } 2995 }
2960 } 2996 }
2961 2997
diff --git a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
index d6d04b2..de1dd8c 100644
--- a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
+++ b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
@@ -310,6 +310,9 @@ namespace OpenSim.Region.Framework.Scenes
310 private UUID m_collisionSound; 310 private UUID m_collisionSound;
311 private float m_collisionSoundVolume; 311 private float m_collisionSoundVolume;
312 312
313
314 private SOPVehicle m_vehicle = null;
315
313 #endregion Fields 316 #endregion Fields
314 317
315// ~SceneObjectPart() 318// ~SceneObjectPart()
@@ -1506,7 +1509,8 @@ namespace OpenSim.Region.Framework.Scenes
1506 /// </summary> 1509 /// </summary>
1507 /// <param name="rootObjectFlags"></param> 1510 /// <param name="rootObjectFlags"></param>
1508 /// <param name="VolumeDetectActive"></param> 1511 /// <param name="VolumeDetectActive"></param>
1509 public void ApplyPhysics(uint rootObjectFlags, bool VolumeDetectActive) 1512// public void ApplyPhysics(uint rootObjectFlags, bool VolumeDetectActive)
1513 public void ApplyPhysics(uint rootObjectFlags, bool VolumeDetectActive, bool building)
1510 { 1514 {
1511 if (!ParentGroup.Scene.CollidablePrims) 1515 if (!ParentGroup.Scene.CollidablePrims)
1512 return; 1516 return;
@@ -1542,7 +1546,8 @@ namespace OpenSim.Region.Framework.Scenes
1542 Shape, 1546 Shape,
1543 AbsolutePosition, 1547 AbsolutePosition,
1544 Scale, 1548 Scale,
1545 RotationOffset, 1549// RotationOffset,
1550 GetWorldRotation(), // physics wants world rotation
1546 RigidBody, 1551 RigidBody,
1547 m_localId); 1552 m_localId);
1548 } 1553 }
@@ -1557,8 +1562,16 @@ namespace OpenSim.Region.Framework.Scenes
1557 { 1562 {
1558 PhysActor.SOPName = this.Name; // save object into the PhysActor so ODE internals know the joint/body info 1563 PhysActor.SOPName = this.Name; // save object into the PhysActor so ODE internals know the joint/body info
1559 PhysActor.SetMaterial(Material); 1564 PhysActor.SetMaterial(Material);
1565
1566 // if root part apply vehicle
1567 if (m_vehicle != null && LocalId == ParentGroup.RootPart.LocalId)
1568 m_vehicle.SetVehicle(PhysActor);
1569
1560 DoPhysicsPropertyUpdate(RigidBody, true); 1570 DoPhysicsPropertyUpdate(RigidBody, true);
1561 PhysActor.SetVolumeDetect(VolumeDetectActive ? 1 : 0); 1571 PhysActor.SetVolumeDetect(VolumeDetectActive ? 1 : 0);
1572
1573 if (!building)
1574 PhysActor.Building = false;
1562 } 1575 }
1563 } 1576 }
1564 } 1577 }
@@ -1794,6 +1807,10 @@ namespace OpenSim.Region.Framework.Scenes
1794 if (!isNew) 1807 if (!isNew)
1795 ParentGroup.Scene.RemovePhysicalPrim(1); 1808 ParentGroup.Scene.RemovePhysicalPrim(1);
1796 1809
1810 Velocity = new Vector3(0, 0, 0);
1811 Acceleration = new Vector3(0, 0, 0);
1812 AngularVelocity = new Vector3(0, 0, 0);
1813
1797 PhysActor.OnRequestTerseUpdate -= PhysicsRequestingTerseUpdate; 1814 PhysActor.OnRequestTerseUpdate -= PhysicsRequestingTerseUpdate;
1798 PhysActor.OnOutOfBounds -= PhysicsOutOfBounds; 1815 PhysActor.OnOutOfBounds -= PhysicsOutOfBounds;
1799 PhysActor.delink(); 1816 PhysActor.delink();
@@ -3163,17 +3180,61 @@ namespace OpenSim.Region.Framework.Scenes
3163 } 3180 }
3164 } 3181 }
3165 3182
3183
3184 public int VehicleType
3185 {
3186 get
3187 {
3188 if (m_vehicle == null)
3189 return (int)Vehicle.TYPE_NONE;
3190 else
3191 return (int)m_vehicle.Type;
3192 }
3193 set
3194 {
3195 SetVehicleType(value);
3196 }
3197 }
3198
3166 public void SetVehicleType(int type) 3199 public void SetVehicleType(int type)
3167 { 3200 {
3168 if (PhysActor != null) 3201 m_vehicle = null;
3202 if (type == (int)Vehicle.TYPE_NONE)
3203 {
3204 if (_parentID ==0 && PhysActor != null)
3205 PhysActor.VehicleType = (int)Vehicle.TYPE_NONE;
3206 return;
3207 }
3208 m_vehicle = new SOPVehicle();
3209 m_vehicle.ProcessTypeChange((Vehicle)type);
3210 {
3211 if (_parentID ==0 && PhysActor != null)
3212 PhysActor.VehicleType = type;
3213 return;
3214 }
3215 }
3216
3217 public void SetVehicleFlags(int param, bool remove)
3218 {
3219 if (m_vehicle == null)
3220 return;
3221
3222 m_vehicle.ProcessVehicleFlags(param, remove);
3223
3224 if (_parentID ==0 && PhysActor != null)
3169 { 3225 {
3170 PhysActor.VehicleType = type; 3226 PhysActor.VehicleFlags(param, remove);
3171 } 3227 }
3172 } 3228 }
3173 3229
3174 public void SetVehicleFloatParam(int param, float value) 3230 public void SetVehicleFloatParam(int param, float value)
3175 { 3231 {
3176 if (PhysActor != null) 3232 if (m_vehicle == null)
3233 return;
3234
3235 m_vehicle.ProcessFloatVehicleParam((Vehicle)param, value);
3236
3237 if (_parentID == 0 && PhysActor != null)
3177 { 3238 {
3178 PhysActor.VehicleFloatParam(param, value); 3239 PhysActor.VehicleFloatParam(param, value);
3179 } 3240 }
@@ -3181,7 +3242,12 @@ namespace OpenSim.Region.Framework.Scenes
3181 3242
3182 public void SetVehicleVectorParam(int param, Vector3 value) 3243 public void SetVehicleVectorParam(int param, Vector3 value)
3183 { 3244 {
3184 if (PhysActor != null) 3245 if (m_vehicle == null)
3246 return;
3247
3248 m_vehicle.ProcessVectorVehicleParam((Vehicle)param, value);
3249
3250 if (_parentID == 0 && PhysActor != null)
3185 { 3251 {
3186 PhysActor.VehicleVectorParam(param, value); 3252 PhysActor.VehicleVectorParam(param, value);
3187 } 3253 }
@@ -3189,7 +3255,12 @@ namespace OpenSim.Region.Framework.Scenes
3189 3255
3190 public void SetVehicleRotationParam(int param, Quaternion rotation) 3256 public void SetVehicleRotationParam(int param, Quaternion rotation)
3191 { 3257 {
3192 if (PhysActor != null) 3258 if (m_vehicle == null)
3259 return;
3260
3261 m_vehicle.ProcessRotationVehicleParam((Vehicle)param, rotation);
3262
3263 if (_parentID == 0 && PhysActor != null)
3193 { 3264 {
3194 PhysActor.VehicleRotationParam(param, rotation); 3265 PhysActor.VehicleRotationParam(param, rotation);
3195 } 3266 }
@@ -3376,13 +3447,6 @@ namespace OpenSim.Region.Framework.Scenes
3376 hasProfileCut = hasDimple; // is it the same thing? 3447 hasProfileCut = hasDimple; // is it the same thing?
3377 } 3448 }
3378 3449
3379 public void SetVehicleFlags(int param, bool remove)
3380 {
3381 if (PhysActor != null)
3382 {
3383 PhysActor.VehicleFlags(param, remove);
3384 }
3385 }
3386 3450
3387 public void SetGroup(UUID groupID, IClientAPI client) 3451 public void SetGroup(UUID groupID, IClientAPI client)
3388 { 3452 {
@@ -4270,7 +4334,8 @@ namespace OpenSim.Region.Framework.Scenes
4270 /// <param name="SetTemporary"></param> 4334 /// <param name="SetTemporary"></param>
4271 /// <param name="SetPhantom"></param> 4335 /// <param name="SetPhantom"></param>
4272 /// <param name="SetVD"></param> 4336 /// <param name="SetVD"></param>
4273 public void UpdatePrimFlags(bool UsePhysics, bool SetTemporary, bool SetPhantom, bool SetVD) 4337// public void UpdatePrimFlags(bool UsePhysics, bool SetTemporary, bool SetPhantom, bool SetVD)
4338 public void UpdatePrimFlags(bool UsePhysics, bool SetTemporary, bool SetPhantom, bool SetVD, bool building)
4274 { 4339 {
4275 bool wasUsingPhysics = ((Flags & PrimFlags.Physics) != 0); 4340 bool wasUsingPhysics = ((Flags & PrimFlags.Physics) != 0);
4276 bool wasTemporary = ((Flags & PrimFlags.TemporaryOnRez) != 0); 4341 bool wasTemporary = ((Flags & PrimFlags.TemporaryOnRez) != 0);
@@ -4288,6 +4353,9 @@ namespace OpenSim.Region.Framework.Scenes
4288 // that... 4353 // that...
4289 // ... if VD is changed, all others are not. 4354 // ... if VD is changed, all others are not.
4290 // ... if one of the others is changed, VD is not. 4355 // ... if one of the others is changed, VD is not.
4356 // do this first
4357 if (building && PhysActor != null && PhysActor.Building != building)
4358 PhysActor.Building = building;
4291 if (SetVD) // VD is active, special logic applies 4359 if (SetVD) // VD is active, special logic applies
4292 { 4360 {
4293 // State machine logic for VolumeDetect 4361 // State machine logic for VolumeDetect
@@ -4369,11 +4437,17 @@ namespace OpenSim.Region.Framework.Scenes
4369 Shape, 4437 Shape,
4370 AbsolutePosition, 4438 AbsolutePosition,
4371 Scale, 4439 Scale,
4372 RotationOffset, 4440// RotationOffset,
4441 GetWorldRotation(), //physics wants world rotation like all other functions send
4373 UsePhysics, 4442 UsePhysics,
4374 m_localId); 4443 m_localId);
4375 4444
4376 PhysActor.SetMaterial(Material); 4445 PhysActor.SetMaterial(Material);
4446
4447 // if root part apply vehicle
4448 if (m_vehicle != null && LocalId == ParentGroup.RootPart.LocalId)
4449 m_vehicle.SetVehicle(PhysActor);
4450
4377 DoPhysicsPropertyUpdate(UsePhysics, true); 4451 DoPhysicsPropertyUpdate(UsePhysics, true);
4378 4452
4379 if (!ParentGroup.IsDeleted) 4453 if (!ParentGroup.IsDeleted)
@@ -4449,6 +4523,9 @@ namespace OpenSim.Region.Framework.Scenes
4449 } 4523 }
4450 // m_log.Debug("Update: PHY:" + UsePhysics.ToString() + ", T:" + IsTemporary.ToString() + ", PHA:" + IsPhantom.ToString() + " S:" + CastsShadows.ToString()); 4524 // m_log.Debug("Update: PHY:" + UsePhysics.ToString() + ", T:" + IsTemporary.ToString() + ", PHA:" + IsPhantom.ToString() + " S:" + CastsShadows.ToString());
4451 4525
4526 // and last in case we have a new actor and not building
4527 if (PhysActor != null && PhysActor.Building != building)
4528 PhysActor.Building = building;
4452 if (ParentGroup != null) 4529 if (ParentGroup != null)
4453 { 4530 {
4454 ParentGroup.HasGroupChanged = true; 4531 ParentGroup.HasGroupChanged = true;
diff --git a/OpenSim/Region/Framework/Scenes/ScenePresence.cs b/OpenSim/Region/Framework/Scenes/ScenePresence.cs
index 429fc06..8a42616 100644
--- a/OpenSim/Region/Framework/Scenes/ScenePresence.cs
+++ b/OpenSim/Region/Framework/Scenes/ScenePresence.cs
@@ -1843,8 +1843,11 @@ namespace OpenSim.Region.Framework.Scenes
1843// m_log.DebugFormat("[SCENE PRESENCE]: StandUp() for {0}", Name); 1843// m_log.DebugFormat("[SCENE PRESENCE]: StandUp() for {0}", Name);
1844 1844
1845 SitGround = false; 1845 SitGround = false;
1846
1847/* move this down so avatar gets physical in the new position and not where it is siting
1846 if (PhysicsActor == null) 1848 if (PhysicsActor == null)
1847 AddToPhysicalScene(false); 1849 AddToPhysicalScene(false);
1850 */
1848 1851
1849 if (ParentID != 0) 1852 if (ParentID != 0)
1850 { 1853 {
@@ -1879,6 +1882,10 @@ namespace OpenSim.Region.Framework.Scenes
1879 ParentPosition = Vector3.Zero; 1882 ParentPosition = Vector3.Zero;
1880 1883
1881 ParentID = 0; 1884 ParentID = 0;
1885
1886 if (PhysicsActor == null)
1887 AddToPhysicalScene(false);
1888
1882 SendAvatarDataToAllAgents(); 1889 SendAvatarDataToAllAgents();
1883 m_requestedSitTargetID = 0; 1890 m_requestedSitTargetID = 0;
1884 1891
@@ -1886,6 +1893,9 @@ namespace OpenSim.Region.Framework.Scenes
1886 part.ParentGroup.TriggerScriptChangedEvent(Changed.LINK); 1893 part.ParentGroup.TriggerScriptChangedEvent(Changed.LINK);
1887 } 1894 }
1888 1895
1896 else if (PhysicsActor == null)
1897 AddToPhysicalScene(false);
1898
1889 Animator.TrySetMovementAnimation("STAND"); 1899 Animator.TrySetMovementAnimation("STAND");
1890 } 1900 }
1891 1901