aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/PhysicsModules/ubOde/ODECharacter.cs
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/PhysicsModules/ubOde/ODECharacter.cs')
-rw-r--r--OpenSim/Region/PhysicsModules/ubOde/ODECharacter.cs888
1 files changed, 524 insertions, 364 deletions
diff --git a/OpenSim/Region/PhysicsModules/ubOde/ODECharacter.cs b/OpenSim/Region/PhysicsModules/ubOde/ODECharacter.cs
index f111e87..60cc549 100644
--- a/OpenSim/Region/PhysicsModules/ubOde/ODECharacter.cs
+++ b/OpenSim/Region/PhysicsModules/ubOde/ODECharacter.cs
@@ -32,7 +32,6 @@ using System;
32using System.Collections.Generic; 32using System.Collections.Generic;
33using System.Reflection; 33using System.Reflection;
34using OpenMetaverse; 34using OpenMetaverse;
35using OdeAPI;
36using OpenSim.Framework; 35using OpenSim.Framework;
37using OpenSim.Region.PhysicsModules.SharedBase; 36using OpenSim.Region.PhysicsModules.SharedBase;
38using log4net; 37using log4net;
@@ -43,7 +42,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde
43 /// Various properties that ODE uses for AMotors but isn't exposed in ODE.NET so we must define them ourselves. 42 /// Various properties that ODE uses for AMotors but isn't exposed in ODE.NET so we must define them ourselves.
44 /// </summary> 43 /// </summary>
45 44
46 public enum dParam : int 45 public enum dParam:int
47 { 46 {
48 LowStop = 0, 47 LowStop = 0,
49 HiStop = 1, 48 HiStop = 1,
@@ -68,7 +67,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde
68 StopCFM3 = 8 + 512 67 StopCFM3 = 8 + 512
69 } 68 }
70 69
71 public class OdeCharacter : PhysicsActor 70 public class OdeCharacter:PhysicsActor
72 { 71 {
73 private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); 72 private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
74 73
@@ -122,7 +121,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde
122 121
123 private bool m_freemove = false; 122 private bool m_freemove = false;
124 123
125// private string m_name = String.Empty; 124 // private string m_name = String.Empty;
126 // other filter control 125 // other filter control
127 int m_colliderfilter = 0; 126 int m_colliderfilter = 0;
128 int m_colliderGroundfilter = 0; 127 int m_colliderGroundfilter = 0;
@@ -144,7 +143,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde
144 143
145 public IntPtr Amotor = IntPtr.Zero; 144 public IntPtr Amotor = IntPtr.Zero;
146 145
147 public d.Mass ShellMass; 146 internal SafeNativeMethods.Mass ShellMass;
148 147
149 public int m_eventsubscription = 0; 148 public int m_eventsubscription = 0;
150 private int m_cureventsubscription = 0; 149 private int m_cureventsubscription = 0;
@@ -165,7 +164,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde
165 private float m_targetHoverHeight; 164 private float m_targetHoverHeight;
166 165
167 166
168 public OdeCharacter(uint localID, String avName, ODEScene parent_scene, Vector3 pos, Vector3 pSize, float pfeetOffset, float density, float walk_divisor, float rundivisor) 167 public OdeCharacter(uint localID,String avName,ODEScene parent_scene,Vector3 pos,Vector3 pSize,float pfeetOffset,float density,float walk_divisor,float rundivisor)
169 { 168 {
170 m_uuid = UUID.Random(); 169 m_uuid = UUID.Random();
171 m_localID = localID; 170 m_localID = localID;
@@ -174,21 +173,21 @@ namespace OpenSim.Region.PhysicsModule.ubOde
174 timeStep = parent_scene.ODE_STEPSIZE; 173 timeStep = parent_scene.ODE_STEPSIZE;
175 invtimeStep = 1 / timeStep; 174 invtimeStep = 1 / timeStep;
176 175
177 if (pos.IsFinite()) 176 if(pos.IsFinite())
178 { 177 {
179 if (pos.Z > 99999f) 178 if(pos.Z > 99999f)
180 { 179 {
181 pos.Z = parent_scene.GetTerrainHeightAtXY(127, 127) + 5; 180 pos.Z = parent_scene.GetTerrainHeightAtXY(127,127) + 5;
182 } 181 }
183 if (pos.Z < -100f) // shouldn't this be 0 ? 182 if(pos.Z < -100f) // shouldn't this be 0 ?
184 { 183 {
185 pos.Z = parent_scene.GetTerrainHeightAtXY(127, 127) + 5; 184 pos.Z = parent_scene.GetTerrainHeightAtXY(127,127) + 5;
186 } 185 }
187 _position = pos; 186 _position = pos;
188 } 187 }
189 else 188 else
190 { 189 {
191 _position = new Vector3(((float)m_parent_scene.WorldExtents.X * 0.5f), ((float)m_parent_scene.WorldExtents.Y * 0.5f), parent_scene.GetTerrainHeightAtXY(128f, 128f) + 10f); 190 _position = new Vector3(((float)m_parent_scene.WorldExtents.X * 0.5f),((float)m_parent_scene.WorldExtents.Y * 0.5f),parent_scene.GetTerrainHeightAtXY(128f,128f) + 10f);
192 m_log.Warn("[PHYSICS]: Got NaN Position on Character Create"); 191 m_log.Warn("[PHYSICS]: Got NaN Position on Character Create");
193 } 192 }
194 193
@@ -216,7 +215,8 @@ namespace OpenSim.Region.PhysicsModule.ubOde
216 walkDivisor = walk_divisor; 215 walkDivisor = walk_divisor;
217 runDivisor = rundivisor; 216 runDivisor = rundivisor;
218 217
219 m_mass = m_density * m_size.X * m_size.Y * m_size.Z; ; // sure we have a default 218 m_mass = m_density * m_size.X * m_size.Y * m_size.Z;
219 ; // sure we have a default
220 220
221 PID_D = basePID_D * m_mass * invtimeStep; 221 PID_D = basePID_D * m_mass * invtimeStep;
222 PID_P = basePID_P * m_mass * invtimeStep; 222 PID_P = basePID_P * m_mass * invtimeStep;
@@ -225,13 +225,19 @@ namespace OpenSim.Region.PhysicsModule.ubOde
225 225
226 Name = avName; 226 Name = avName;
227 227
228 AddChange(changes.Add, null); 228 AddChange(changes.Add,null);
229 } 229 }
230 230
231 public override int PhysicsActorType 231 public override int PhysicsActorType
232 { 232 {
233 get { return (int)ActorTypes.Agent; } 233 get
234 set { return; } 234 {
235 return (int)ActorTypes.Agent;
236 }
237 set
238 {
239 return;
240 }
235 } 241 }
236 242
237 public override void getContactData(ref ContactData cdata) 243 public override void getContactData(ref ContactData cdata)
@@ -241,68 +247,116 @@ namespace OpenSim.Region.PhysicsModule.ubOde
241 cdata.softcolide = false; 247 cdata.softcolide = false;
242 } 248 }
243 249
244 public override bool Building { get; set; } 250 public override bool Building
251 {
252 get; set;
253 }
245 254
246 /// <summary> 255 /// <summary>
247 /// If this is set, the avatar will move faster 256 /// If this is set, the avatar will move faster
248 /// </summary> 257 /// </summary>
249 public override bool SetAlwaysRun 258 public override bool SetAlwaysRun
250 { 259 {
251 get { return m_alwaysRun; } 260 get
252 set { m_alwaysRun = value; } 261 {
262 return m_alwaysRun;
263 }
264 set
265 {
266 m_alwaysRun = value;
267 }
253 } 268 }
254 269
255 public override uint LocalID 270 public override uint LocalID
256 { 271 {
257 get { return m_localID; } 272 get
258 set { m_localID = value; } 273 {
274 return m_localID;
275 }
276 set
277 {
278 m_localID = value;
279 }
259 } 280 }
260 281
261 public override PhysicsActor ParentActor 282 public override PhysicsActor ParentActor
262 { 283 {
263 get { return (PhysicsActor)this; } 284 get
285 {
286 return (PhysicsActor)this;
287 }
264 } 288 }
265 289
266 public override bool Grabbed 290 public override bool Grabbed
267 { 291 {
268 set { return; } 292 set
293 {
294 return;
295 }
269 } 296 }
270 297
271 public override bool Selected 298 public override bool Selected
272 { 299 {
273 set { return; } 300 set
301 {
302 return;
303 }
274 } 304 }
275 305
276 public override float Buoyancy 306 public override float Buoyancy
277 { 307 {
278 get { return m_buoyancy; } 308 get
279 set { m_buoyancy = value; } 309 {
310 return m_buoyancy;
311 }
312 set
313 {
314 m_buoyancy = value;
315 }
280 } 316 }
281 317
282 public override bool FloatOnWater 318 public override bool FloatOnWater
283 { 319 {
284 set { return; } 320 set
321 {
322 return;
323 }
285 } 324 }
286 325
287 public override bool IsPhysical 326 public override bool IsPhysical
288 { 327 {
289 get { return m_isPhysical; } 328 get
290 set { return; } 329 {
330 return m_isPhysical;
331 }
332 set
333 {
334 return;
335 }
291 } 336 }
292 337
293 public override bool ThrottleUpdates 338 public override bool ThrottleUpdates
294 { 339 {
295 get { return false; } 340 get
296 set { return; } 341 {
342 return false;
343 }
344 set
345 {
346 return;
347 }
297 } 348 }
298 349
299 public override bool Flying 350 public override bool Flying
300 { 351 {
301 get { return m_flying; } 352 get
353 {
354 return m_flying;
355 }
302 set 356 set
303 { 357 {
304 m_flying = value; 358 m_flying = value;
305// m_log.DebugFormat("[PHYSICS]: Set OdeCharacter Flying to {0}", flying); 359 // m_log.DebugFormat("[PHYSICS]: Set OdeCharacter Flying to {0}", flying);
306 } 360 }
307 } 361 }
308 362
@@ -312,23 +366,26 @@ namespace OpenSim.Region.PhysicsModule.ubOde
312 /// </summary> 366 /// </summary>
313 public override bool IsColliding 367 public override bool IsColliding
314 { 368 {
315 get { return (m_iscolliding || m_iscollidingGround); } 369 get
370 {
371 return (m_iscolliding || m_iscollidingGround);
372 }
316 set 373 set
317 { 374 {
318 if (value) 375 if(value)
319 { 376 {
320 m_colliderfilter += 3; 377 m_colliderfilter += 3;
321 if (m_colliderfilter > 3) 378 if(m_colliderfilter > 3)
322 m_colliderfilter = 3; 379 m_colliderfilter = 3;
323 } 380 }
324 else 381 else
325 { 382 {
326 m_colliderfilter--; 383 m_colliderfilter--;
327 if (m_colliderfilter < 0) 384 if(m_colliderfilter < 0)
328 m_colliderfilter = 0; 385 m_colliderfilter = 0;
329 } 386 }
330 387
331 if (m_colliderfilter == 0) 388 if(m_colliderfilter == 0)
332 m_iscolliding = false; 389 m_iscolliding = false;
333 else 390 else
334 { 391 {
@@ -344,28 +401,31 @@ namespace OpenSim.Region.PhysicsModule.ubOde
344 /// </summary> 401 /// </summary>
345 public override bool CollidingGround 402 public override bool CollidingGround
346 { 403 {
347 get { return m_iscollidingGround; } 404 get
405 {
406 return m_iscollidingGround;
407 }
348 set 408 set
349 { 409 {
350/* we now control this 410 /* we now control this
351 if (value) 411 if (value)
352 { 412 {
353 m_colliderGroundfilter += 2; 413 m_colliderGroundfilter += 2;
354 if (m_colliderGroundfilter > 2) 414 if (m_colliderGroundfilter > 2)
355 m_colliderGroundfilter = 2; 415 m_colliderGroundfilter = 2;
356 } 416 }
357 else 417 else
358 { 418 {
359 m_colliderGroundfilter--; 419 m_colliderGroundfilter--;
360 if (m_colliderGroundfilter < 0) 420 if (m_colliderGroundfilter < 0)
361 m_colliderGroundfilter = 0; 421 m_colliderGroundfilter = 0;
362 } 422 }
363 423
364 if (m_colliderGroundfilter == 0) 424 if (m_colliderGroundfilter == 0)
365 m_iscollidingGround = false; 425 m_iscollidingGround = false;
366 else 426 else
367 m_iscollidingGround = true; 427 m_iscollidingGround = true;
368 */ 428 */
369 } 429 }
370 430
371 } 431 }
@@ -375,31 +435,34 @@ namespace OpenSim.Region.PhysicsModule.ubOde
375 /// </summary> 435 /// </summary>
376 public override bool CollidingObj 436 public override bool CollidingObj
377 { 437 {
378 get { return m_iscollidingObj; } 438 get
439 {
440 return m_iscollidingObj;
441 }
379 set 442 set
380 { 443 {
381 // Ubit filter this also 444 // Ubit filter this also
382 if (value) 445 if(value)
383 { 446 {
384 m_colliderObjectfilter += 2; 447 m_colliderObjectfilter += 2;
385 if (m_colliderObjectfilter > 2) 448 if(m_colliderObjectfilter > 2)
386 m_colliderObjectfilter = 2; 449 m_colliderObjectfilter = 2;
387 } 450 }
388 else 451 else
389 { 452 {
390 m_colliderObjectfilter--; 453 m_colliderObjectfilter--;
391 if (m_colliderObjectfilter < 0) 454 if(m_colliderObjectfilter < 0)
392 m_colliderObjectfilter = 0; 455 m_colliderObjectfilter = 0;
393 } 456 }
394 457
395 if (m_colliderObjectfilter == 0) 458 if(m_colliderObjectfilter == 0)
396 m_iscollidingObj = false; 459 m_iscollidingObj = false;
397 else 460 else
398 m_iscollidingObj = true; 461 m_iscollidingObj = true;
399 462
400// m_iscollidingObj = value; 463 // m_iscollidingObj = value;
401 464
402 if (m_iscollidingObj) 465 if(m_iscollidingObj)
403 m_pidControllerActive = false; 466 m_pidControllerActive = false;
404 else 467 else
405 m_pidControllerActive = true; 468 m_pidControllerActive = true;
@@ -418,7 +481,10 @@ namespace OpenSim.Region.PhysicsModule.ubOde
418 481
419 public override bool Stopped 482 public override bool Stopped
420 { 483 {
421 get { return _zeroFlag; } 484 get
485 {
486 return _zeroFlag;
487 }
422 } 488 }
423 489
424 /// <summary> 490 /// <summary>
@@ -428,20 +494,23 @@ namespace OpenSim.Region.PhysicsModule.ubOde
428 /// </summary> 494 /// </summary>
429 public override Vector3 Position 495 public override Vector3 Position
430 { 496 {
431 get { return _position; } 497 get
498 {
499 return _position;
500 }
432 set 501 set
433 { 502 {
434 if (value.IsFinite()) 503 if(value.IsFinite())
435 { 504 {
436 if (value.Z > 9999999f) 505 if(value.Z > 9999999f)
437 { 506 {
438 value.Z = m_parent_scene.GetTerrainHeightAtXY(127, 127) + 5; 507 value.Z = m_parent_scene.GetTerrainHeightAtXY(127,127) + 5;
439 } 508 }
440 if (value.Z < -100f) 509 if(value.Z < -100f)
441 { 510 {
442 value.Z = m_parent_scene.GetTerrainHeightAtXY(127, 127) + 5; 511 value.Z = m_parent_scene.GetTerrainHeightAtXY(127,127) + 5;
443 } 512 }
444 AddChange(changes.Position, value); 513 AddChange(changes.Position,value);
445 } 514 }
446 else 515 else
447 { 516 {
@@ -452,8 +521,14 @@ namespace OpenSim.Region.PhysicsModule.ubOde
452 521
453 public override Vector3 RotationalVelocity 522 public override Vector3 RotationalVelocity
454 { 523 {
455 get { return m_rotationalVelocity; } 524 get
456 set { m_rotationalVelocity = value; } 525 {
526 return m_rotationalVelocity;
527 }
528 set
529 {
530 m_rotationalVelocity = value;
531 }
457 } 532 }
458 533
459 /// <summary> 534 /// <summary>
@@ -468,7 +543,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde
468 } 543 }
469 set 544 set
470 { 545 {
471 if (value.IsFinite()) 546 if(value.IsFinite())
472 { 547 {
473 if(value.X <0.01f) 548 if(value.X <0.01f)
474 value.X = 0.01f; 549 value.X = 0.01f;
@@ -477,7 +552,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde
477 if(value.Z <0.01f) 552 if(value.Z <0.01f)
478 value.Z = 0.01f; 553 value.Z = 0.01f;
479 554
480 AddChange(changes.Size, value); 555 AddChange(changes.Size,value);
481 } 556 }
482 else 557 else
483 { 558 {
@@ -486,21 +561,21 @@ namespace OpenSim.Region.PhysicsModule.ubOde
486 } 561 }
487 } 562 }
488 563
489 public override void setAvatarSize(Vector3 size, float feetOffset) 564 public override void setAvatarSize(Vector3 size,float feetOffset)
490 { 565 {
491 if (size.IsFinite()) 566 if(size.IsFinite())
492 { 567 {
493 if (size.X < 0.01f) 568 if(size.X < 0.01f)
494 size.X = 0.01f; 569 size.X = 0.01f;
495 if (size.Y < 0.01f) 570 if(size.Y < 0.01f)
496 size.Y = 0.01f; 571 size.Y = 0.01f;
497 if (size.Z < 0.01f) 572 if(size.Z < 0.01f)
498 size.Z = 0.01f; 573 size.Z = 0.01f;
499 574
500 strAvatarSize st = new strAvatarSize(); 575 strAvatarSize st = new strAvatarSize();
501 st.size = size; 576 st.size = size;
502 st.offset = feetOffset; 577 st.offset = feetOffset;
503 AddChange(changes.AvatarSize, st); 578 AddChange(changes.AvatarSize,st);
504 } 579 }
505 else 580 else
506 { 581 {
@@ -545,32 +620,44 @@ namespace OpenSim.Region.PhysicsModule.ubOde
545 620
546 public override Vector3 Force 621 public override Vector3 Force
547 { 622 {
548 get { return _target_velocity; } 623 get
549 set { return; } 624 {
625 return _target_velocity;
626 }
627 set
628 {
629 return;
630 }
550 } 631 }
551 632
552 public override int VehicleType 633 public override int VehicleType
553 { 634 {
554 get { return 0; } 635 get
555 set { return; } 636 {
637 return 0;
638 }
639 set
640 {
641 return;
642 }
556 } 643 }
557 644
558 public override void VehicleFloatParam(int param, float value) 645 public override void VehicleFloatParam(int param,float value)
559 { 646 {
560 647
561 } 648 }
562 649
563 public override void VehicleVectorParam(int param, Vector3 value) 650 public override void VehicleVectorParam(int param,Vector3 value)
564 { 651 {
565 652
566 } 653 }
567 654
568 public override void VehicleRotationParam(int param, Quaternion rotation) 655 public override void VehicleRotationParam(int param,Quaternion rotation)
569 { 656 {
570 657
571 } 658 }
572 659
573 public override void VehicleFlags(int param, bool remove) 660 public override void VehicleFlags(int param,bool remove)
574 { 661 {
575 662
576 } 663 }
@@ -600,7 +687,10 @@ namespace OpenSim.Region.PhysicsModule.ubOde
600 687
601 public override PrimitiveBaseShape Shape 688 public override PrimitiveBaseShape Shape
602 { 689 {
603 set { return; } 690 set
691 {
692 return;
693 }
604 } 694 }
605 695
606 public override Vector3 rootVelocity 696 public override Vector3 rootVelocity
@@ -619,9 +709,9 @@ namespace OpenSim.Region.PhysicsModule.ubOde
619 } 709 }
620 set 710 set
621 { 711 {
622 if (value.IsFinite()) 712 if(value.IsFinite())
623 { 713 {
624 AddChange(changes.Velocity, value); 714 AddChange(changes.Velocity,value);
625 } 715 }
626 else 716 else
627 { 717 {
@@ -638,9 +728,9 @@ namespace OpenSim.Region.PhysicsModule.ubOde
638 } 728 }
639 set 729 set
640 { 730 {
641 if (value.IsFinite()) 731 if(value.IsFinite())
642 { 732 {
643 AddChange(changes.TargetVelocity, value); 733 AddChange(changes.TargetVelocity,value);
644 } 734 }
645 else 735 else
646 { 736 {
@@ -651,38 +741,62 @@ namespace OpenSim.Region.PhysicsModule.ubOde
651 741
652 public override Vector3 Torque 742 public override Vector3 Torque
653 { 743 {
654 get { return Vector3.Zero; } 744 get
655 set { return; } 745 {
746 return Vector3.Zero;
747 }
748 set
749 {
750 return;
751 }
656 } 752 }
657 753
658 public override float CollisionScore 754 public override float CollisionScore
659 { 755 {
660 get { return 0f; } 756 get
661 set { } 757 {
758 return 0f;
759 }
760 set
761 {
762 }
662 } 763 }
663 764
664 public override bool Kinematic 765 public override bool Kinematic
665 { 766 {
666 get { return false; } 767 get
667 set { } 768 {
769 return false;
770 }
771 set
772 {
773 }
668 } 774 }
669 775
670 public override Quaternion Orientation 776 public override Quaternion Orientation
671 { 777 {
672 get { return m_orientation; } 778 get
779 {
780 return m_orientation;
781 }
673 set 782 set
674 { 783 {
675// fakeori = value; 784 // fakeori = value;
676// givefakeori++; 785 // givefakeori++;
677 value.Normalize(); 786 value.Normalize();
678 AddChange(changes.Orientation, value); 787 AddChange(changes.Orientation,value);
679 } 788 }
680 } 789 }
681 790
682 public override Vector3 Acceleration 791 public override Vector3 Acceleration
683 { 792 {
684 get { return _acceleration; } 793 get
685 set { } 794 {
795 return _acceleration;
796 }
797 set
798 {
799 }
686 } 800 }
687 801
688 public void SetAcceleration(Vector3 accel) 802 public void SetAcceleration(Vector3 accel)
@@ -696,17 +810,17 @@ namespace OpenSim.Region.PhysicsModule.ubOde
696 /// The PID controller takes this target velocity and tries to make it a reality 810 /// The PID controller takes this target velocity and tries to make it a reality
697 /// </summary> 811 /// </summary>
698 /// <param name="force"></param> 812 /// <param name="force"></param>
699 public override void AddForce(Vector3 force, bool pushforce) 813 public override void AddForce(Vector3 force,bool pushforce)
700 { 814 {
701 if (force.IsFinite()) 815 if(force.IsFinite())
702 { 816 {
703 if (pushforce) 817 if(pushforce)
704 { 818 {
705 AddChange(changes.Force, force * m_density / (m_parent_scene.ODE_STEPSIZE * 28f)); 819 AddChange(changes.Force,force * m_density / (m_parent_scene.ODE_STEPSIZE * 28f));
706 } 820 }
707 else 821 else
708 { 822 {
709 AddChange(changes.TargetVelocity, force); 823 AddChange(changes.TargetVelocity,force);
710 } 824 }
711 } 825 }
712 else 826 else
@@ -716,19 +830,19 @@ namespace OpenSim.Region.PhysicsModule.ubOde
716 //m_lastUpdateSent = false; 830 //m_lastUpdateSent = false;
717 } 831 }
718 832
719 public override void AddAngularForce(Vector3 force, bool pushforce) 833 public override void AddAngularForce(Vector3 force,bool pushforce)
720 { 834 {
721 835
722 } 836 }
723 837
724 public override void SetMomentum(Vector3 momentum) 838 public override void SetMomentum(Vector3 momentum)
725 { 839 {
726 if (momentum.IsFinite()) 840 if(momentum.IsFinite())
727 AddChange(changes.Momentum, momentum); 841 AddChange(changes.Momentum,momentum);
728 } 842 }
729 843
730 844
731 private void AvatarGeomAndBodyCreation(float npositionX, float npositionY, float npositionZ) 845 private void AvatarGeomAndBodyCreation(float npositionX,float npositionY,float npositionZ)
732 { 846 {
733 // sizes one day should came from visual parameters 847 // sizes one day should came from visual parameters
734 float sx = m_size.X; 848 float sx = m_size.X;
@@ -739,7 +853,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde
739 boneOff = bot + 0.3f; 853 boneOff = bot + 0.3f;
740 854
741 float feetsz = sz * 0.45f; 855 float feetsz = sz * 0.45f;
742 if (feetsz > 0.6f) 856 if(feetsz > 0.6f)
743 feetsz = 0.6f; 857 feetsz = 0.6f;
744 858
745 feetOff = bot + feetsz; 859 feetOff = bot + feetsz;
@@ -751,28 +865,28 @@ namespace OpenSim.Region.PhysicsModule.ubOde
751 865
752 m_parent_scene.waitForSpaceUnlock(m_parent_scene.CharsSpace); 866 m_parent_scene.waitForSpaceUnlock(m_parent_scene.CharsSpace);
753 867
754 collider = d.SimpleSpaceCreate(m_parent_scene.CharsSpace); 868 collider = SafeNativeMethods.SimpleSpaceCreate(m_parent_scene.CharsSpace);
755 d.SpaceSetSublevel(collider, 3); 869 SafeNativeMethods.SpaceSetSublevel(collider,3);
756 d.SpaceSetCleanup(collider, false); 870 SafeNativeMethods.SpaceSetCleanup(collider,false);
757 d.GeomSetCategoryBits(collider, (uint)m_collisionCategories); 871 SafeNativeMethods.GeomSetCategoryBits(collider,(uint)m_collisionCategories);
758 d.GeomSetCollideBits(collider, (uint)m_collisionFlags); 872 SafeNativeMethods.GeomSetCollideBits(collider,(uint)m_collisionFlags);
759 873
760 float r = m_size.X; 874 float r = m_size.X;
761 if (m_size.Y > r) 875 if(m_size.Y > r)
762 r = m_size.Y; 876 r = m_size.Y;
763 float l = m_size.Z - r; 877 float l = m_size.Z - r;
764 r *= 0.5f; 878 r *= 0.5f;
765 879
766 capsule = d.CreateCapsule(collider, r, l); 880 capsule = SafeNativeMethods.CreateCapsule(collider,r,l);
767 881
768 m_mass = m_density * m_size.X * m_size.Y * m_size.Z; // update mass 882 m_mass = m_density * m_size.X * m_size.Y * m_size.Z; // update mass
769 883
770 d.MassSetBoxTotal(out ShellMass, m_mass, m_size.X, m_size.Y, m_size.Z); 884 SafeNativeMethods.MassSetBoxTotal(out ShellMass,m_mass,m_size.X,m_size.Y,m_size.Z);
771 885
772 PID_D = basePID_D * m_mass / m_parent_scene.ODE_STEPSIZE; 886 PID_D = basePID_D * m_mass / m_parent_scene.ODE_STEPSIZE;
773 PID_P = basePID_P * m_mass / m_parent_scene.ODE_STEPSIZE; 887 PID_P = basePID_P * m_mass / m_parent_scene.ODE_STEPSIZE;
774 888
775 Body = d.BodyCreate(m_parent_scene.world); 889 Body = SafeNativeMethods.BodyCreate(m_parent_scene.world);
776 890
777 _zeroFlag = false; 891 _zeroFlag = false;
778 m_pidControllerActive = true; 892 m_pidControllerActive = true;
@@ -780,53 +894,53 @@ namespace OpenSim.Region.PhysicsModule.ubOde
780 894
781 _velocity = Vector3.Zero; 895 _velocity = Vector3.Zero;
782 896
783 d.BodySetAutoDisableFlag(Body, false); 897 SafeNativeMethods.BodySetAutoDisableFlag(Body,false);
784 d.BodySetPosition(Body, npositionX, npositionY, npositionZ); 898 SafeNativeMethods.BodySetPosition(Body,npositionX,npositionY,npositionZ);
785 899
786 _position.X = npositionX; 900 _position.X = npositionX;
787 _position.Y = npositionY; 901 _position.Y = npositionY;
788 _position.Z = npositionZ; 902 _position.Z = npositionZ;
789 903
790 d.BodySetMass(Body, ref ShellMass); 904 SafeNativeMethods.BodySetMass(Body,ref ShellMass);
791 d.GeomSetBody(capsule, Body); 905 SafeNativeMethods.GeomSetBody(capsule,Body);
792 906
793 // The purpose of the AMotor here is to keep the avatar's physical 907 // The purpose of the AMotor here is to keep the avatar's physical
794 // surrogate from rotating while moving 908 // surrogate from rotating while moving
795 Amotor = d.JointCreateAMotor(m_parent_scene.world, IntPtr.Zero); 909 Amotor = SafeNativeMethods.JointCreateAMotor(m_parent_scene.world,IntPtr.Zero);
796 d.JointAttach(Amotor, Body, IntPtr.Zero); 910 SafeNativeMethods.JointAttach(Amotor,Body,IntPtr.Zero);
797 911
798 d.JointSetAMotorMode(Amotor, 0); 912 SafeNativeMethods.JointSetAMotorMode(Amotor,0);
799 d.JointSetAMotorNumAxes(Amotor, 3); 913 SafeNativeMethods.JointSetAMotorNumAxes(Amotor,3);
800 d.JointSetAMotorAxis(Amotor, 0, 0, 1, 0, 0); 914 SafeNativeMethods.JointSetAMotorAxis(Amotor,0,0,1,0,0);
801 d.JointSetAMotorAxis(Amotor, 1, 0, 0, 1, 0); 915 SafeNativeMethods.JointSetAMotorAxis(Amotor,1,0,0,1,0);
802 d.JointSetAMotorAxis(Amotor, 2, 0, 0, 0, 1); 916 SafeNativeMethods.JointSetAMotorAxis(Amotor,2,0,0,0,1);
803 917
804 d.JointSetAMotorAngle(Amotor, 0, 0); 918 SafeNativeMethods.JointSetAMotorAngle(Amotor,0,0);
805 d.JointSetAMotorAngle(Amotor, 1, 0); 919 SafeNativeMethods.JointSetAMotorAngle(Amotor,1,0);
806 d.JointSetAMotorAngle(Amotor, 2, 0); 920 SafeNativeMethods.JointSetAMotorAngle(Amotor,2,0);
807 921
808 d.JointSetAMotorParam(Amotor, (int)dParam.StopCFM, 0f); // make it HARD 922 SafeNativeMethods.JointSetAMotorParam(Amotor,(int)dParam.StopCFM,0f); // make it HARD
809 d.JointSetAMotorParam(Amotor, (int)dParam.StopCFM2, 0f); 923 SafeNativeMethods.JointSetAMotorParam(Amotor,(int)dParam.StopCFM2,0f);
810 d.JointSetAMotorParam(Amotor, (int)dParam.StopCFM3, 0f); 924 SafeNativeMethods.JointSetAMotorParam(Amotor,(int)dParam.StopCFM3,0f);
811 d.JointSetAMotorParam(Amotor, (int)dParam.StopERP, 0.8f); 925 SafeNativeMethods.JointSetAMotorParam(Amotor,(int)dParam.StopERP,0.8f);
812 d.JointSetAMotorParam(Amotor, (int)dParam.StopERP2, 0.8f); 926 SafeNativeMethods.JointSetAMotorParam(Amotor,(int)dParam.StopERP2,0.8f);
813 d.JointSetAMotorParam(Amotor, (int)dParam.StopERP3, 0.8f); 927 SafeNativeMethods.JointSetAMotorParam(Amotor,(int)dParam.StopERP3,0.8f);
814 928
815 // These lowstops and high stops are effectively (no wiggle room) 929 // These lowstops and high stops are effectively (no wiggle room)
816 d.JointSetAMotorParam(Amotor, (int)dParam.LowStop, -1e-5f); 930 SafeNativeMethods.JointSetAMotorParam(Amotor,(int)dParam.LowStop,-1e-5f);
817 d.JointSetAMotorParam(Amotor, (int)dParam.HiStop, 1e-5f); 931 SafeNativeMethods.JointSetAMotorParam(Amotor,(int)dParam.HiStop,1e-5f);
818 d.JointSetAMotorParam(Amotor, (int)dParam.LoStop2, -1e-5f); 932 SafeNativeMethods.JointSetAMotorParam(Amotor,(int)dParam.LoStop2,-1e-5f);
819 d.JointSetAMotorParam(Amotor, (int)dParam.HiStop2, 1e-5f); 933 SafeNativeMethods.JointSetAMotorParam(Amotor,(int)dParam.HiStop2,1e-5f);
820 d.JointSetAMotorParam(Amotor, (int)dParam.LoStop3, -1e-5f); 934 SafeNativeMethods.JointSetAMotorParam(Amotor,(int)dParam.LoStop3,-1e-5f);
821 d.JointSetAMotorParam(Amotor, (int)dParam.HiStop3, 1e-5f); 935 SafeNativeMethods.JointSetAMotorParam(Amotor,(int)dParam.HiStop3,1e-5f);
822 936
823 d.JointSetAMotorParam(Amotor, (int)d.JointParam.Vel, 0); 937 SafeNativeMethods.JointSetAMotorParam(Amotor,(int)SafeNativeMethods.JointParam.Vel,0);
824 d.JointSetAMotorParam(Amotor, (int)d.JointParam.Vel2, 0); 938 SafeNativeMethods.JointSetAMotorParam(Amotor,(int)SafeNativeMethods.JointParam.Vel2,0);
825 d.JointSetAMotorParam(Amotor, (int)d.JointParam.Vel3, 0); 939 SafeNativeMethods.JointSetAMotorParam(Amotor,(int)SafeNativeMethods.JointParam.Vel3,0);
826 940
827 d.JointSetAMotorParam(Amotor, (int)dParam.FMax, 5e8f); 941 SafeNativeMethods.JointSetAMotorParam(Amotor,(int)dParam.FMax,5e8f);
828 d.JointSetAMotorParam(Amotor, (int)dParam.FMax2, 5e8f); 942 SafeNativeMethods.JointSetAMotorParam(Amotor,(int)dParam.FMax2,5e8f);
829 d.JointSetAMotorParam(Amotor, (int)dParam.FMax3, 5e8f); 943 SafeNativeMethods.JointSetAMotorParam(Amotor,(int)dParam.FMax3,5e8f);
830 } 944 }
831 945
832 /// <summary> 946 /// <summary>
@@ -835,38 +949,38 @@ namespace OpenSim.Region.PhysicsModule.ubOde
835 private void AvatarGeomAndBodyDestroy() 949 private void AvatarGeomAndBodyDestroy()
836 { 950 {
837 // Kill the Amotor 951 // Kill the Amotor
838 if (Amotor != IntPtr.Zero) 952 if(Amotor != IntPtr.Zero)
839 { 953 {
840 d.JointDestroy(Amotor); 954 SafeNativeMethods.JointDestroy(Amotor);
841 Amotor = IntPtr.Zero; 955 Amotor = IntPtr.Zero;
842 } 956 }
843 957
844 if (Body != IntPtr.Zero) 958 if(Body != IntPtr.Zero)
845 { 959 {
846 //kill the body 960 //kill the body
847 d.BodyDestroy(Body); 961 SafeNativeMethods.BodyDestroy(Body);
848 Body = IntPtr.Zero; 962 Body = IntPtr.Zero;
849 } 963 }
850 964
851 //kill the Geoms 965 //kill the Geoms
852 if (capsule != IntPtr.Zero) 966 if(capsule != IntPtr.Zero)
853 { 967 {
854 m_parent_scene.actor_name_map.Remove(capsule); 968 m_parent_scene.actor_name_map.Remove(capsule);
855 m_parent_scene.waitForSpaceUnlock(collider); 969 m_parent_scene.waitForSpaceUnlock(collider);
856 d.GeomDestroy(capsule); 970 SafeNativeMethods.GeomDestroy(capsule);
857 capsule = IntPtr.Zero; 971 capsule = IntPtr.Zero;
858 } 972 }
859 973
860 if (collider != IntPtr.Zero) 974 if(collider != IntPtr.Zero)
861 { 975 {
862 d.SpaceDestroy(collider); 976 SafeNativeMethods.SpaceDestroy(collider);
863 collider = IntPtr.Zero; 977 collider = IntPtr.Zero;
864 } 978 }
865 979
866 } 980 }
867 981
868 //in place 2D rotation around Z assuming rot is normalised and is a rotation around Z 982 //in place 2D rotation around Z assuming rot is normalised and is a rotation around Z
869 public void RotateXYonZ(ref float x, ref float y, ref Quaternion rot) 983 public void RotateXYonZ(ref float x,ref float y,ref Quaternion rot)
870 { 984 {
871 float sin = 2.0f * rot.Z * rot.W; 985 float sin = 2.0f * rot.Z * rot.W;
872 float cos = rot.W * rot.W - rot.Z * rot.Z; 986 float cos = rot.W * rot.W - rot.Z * rot.Z;
@@ -875,22 +989,22 @@ namespace OpenSim.Region.PhysicsModule.ubOde
875 x = tx * cos - y * sin; 989 x = tx * cos - y * sin;
876 y = tx * sin + y * cos; 990 y = tx * sin + y * cos;
877 } 991 }
878 public void RotateXYonZ(ref float x, ref float y, ref float sin, ref float cos) 992 public void RotateXYonZ(ref float x,ref float y,ref float sin,ref float cos)
879 { 993 {
880 float tx = x; 994 float tx = x;
881 x = tx * cos - y * sin; 995 x = tx * cos - y * sin;
882 y = tx * sin + y * cos; 996 y = tx * sin + y * cos;
883 } 997 }
884 public void invRotateXYonZ(ref float x, ref float y, ref float sin, ref float cos) 998 public void invRotateXYonZ(ref float x,ref float y,ref float sin,ref float cos)
885 { 999 {
886 float tx = x; 1000 float tx = x;
887 x = tx * cos + y * sin; 1001 x = tx * cos + y * sin;
888 y = -tx * sin + y * cos; 1002 y = -tx * sin + y * cos;
889 } 1003 }
890 1004
891 public void invRotateXYonZ(ref float x, ref float y, ref Quaternion rot) 1005 public void invRotateXYonZ(ref float x,ref float y,ref Quaternion rot)
892 { 1006 {
893 float sin = - 2.0f * rot.Z * rot.W; 1007 float sin = -2.0f * rot.Z * rot.W;
894 float cos = rot.W * rot.W - rot.Z * rot.Z; 1008 float cos = rot.W * rot.W - rot.Z * rot.Z;
895 float tx = x; 1009 float tx = x;
896 1010
@@ -898,13 +1012,13 @@ namespace OpenSim.Region.PhysicsModule.ubOde
898 y = tx * sin + y * cos; 1012 y = tx * sin + y * cos;
899 } 1013 }
900 1014
901 public bool Collide(IntPtr me, IntPtr other, bool reverse, ref d.ContactGeom contact, 1015 internal bool Collide(IntPtr me,IntPtr other,bool reverse,ref SafeNativeMethods.ContactGeom contact,
902 ref d.ContactGeom altContact , ref bool useAltcontact, ref bool feetcollision) 1016 ref SafeNativeMethods.ContactGeom altContact,ref bool useAltcontact,ref bool feetcollision)
903 { 1017 {
904 feetcollision = false; 1018 feetcollision = false;
905 useAltcontact = false; 1019 useAltcontact = false;
906 1020
907 if (me == capsule) 1021 if(me == capsule)
908 { 1022 {
909 Vector3 offset; 1023 Vector3 offset;
910 1024
@@ -914,25 +1028,25 @@ namespace OpenSim.Region.PhysicsModule.ubOde
914 offset.X = contact.pos.X - _position.X; 1028 offset.X = contact.pos.X - _position.X;
915 offset.Y = contact.pos.Y - _position.Y; 1029 offset.Y = contact.pos.Y - _position.Y;
916 1030
917 d.GeomClassID gtype = d.GeomGetClass(other); 1031 SafeNativeMethods.GeomClassID gtype = SafeNativeMethods.GeomGetClass(other);
918 if (gtype == d.GeomClassID.CapsuleClass) 1032 if(gtype == SafeNativeMethods.GeomClassID.CapsuleClass)
919 { 1033 {
920 Vector3 roff = offset * Quaternion.Inverse(m_orientation2D); 1034 Vector3 roff = offset * Quaternion.Inverse(m_orientation2D);
921 float r = roff.X *roff.X / AvaAvaSizeXsq; 1035 float r = roff.X *roff.X / AvaAvaSizeXsq;
922 r += (roff.Y * roff.Y) / AvaAvaSizeYsq; 1036 r += (roff.Y * roff.Y) / AvaAvaSizeYsq;
923 if (r > 1.0f) 1037 if(r > 1.0f)
924 return false; 1038 return false;
925 1039
926 float dp = 1.0f -(float)Math.Sqrt((double)r); 1040 float dp = 1.0f -(float)Math.Sqrt((double)r);
927 if (dp > 0.05f) 1041 if(dp > 0.05f)
928 dp = 0.05f; 1042 dp = 0.05f;
929 1043
930 contact.depth = dp; 1044 contact.depth = dp;
931 1045
932 if (offset.Z < 0) 1046 if(offset.Z < 0)
933 { 1047 {
934 feetcollision = true; 1048 feetcollision = true;
935 if (h < boneOff) 1049 if(h < boneOff)
936 { 1050 {
937 m_collideNormal.X = contact.normal.X; 1051 m_collideNormal.X = contact.normal.X;
938 m_collideNormal.Y = contact.normal.Y; 1052 m_collideNormal.Y = contact.normal.Y;
@@ -943,18 +1057,18 @@ namespace OpenSim.Region.PhysicsModule.ubOde
943 return true; 1057 return true;
944 } 1058 }
945 1059
946 if (gtype == d.GeomClassID.SphereClass && d.GeomGetBody(other) != IntPtr.Zero) 1060 if(gtype == SafeNativeMethods.GeomClassID.SphereClass && SafeNativeMethods.GeomGetBody(other) != IntPtr.Zero)
947 { 1061 {
948 if(d.GeomSphereGetRadius(other) < 0.5) 1062 if(SafeNativeMethods.GeomSphereGetRadius(other) < 0.5)
949 return true; 1063 return true;
950 } 1064 }
951 1065
952 if (offset.Z > 0 || contact.normal.Z > 0.35f) 1066 if(offset.Z > 0 || contact.normal.Z > 0.35f)
953 { 1067 {
954 if (offset.Z <= 0) 1068 if(offset.Z <= 0)
955 { 1069 {
956 feetcollision = true; 1070 feetcollision = true;
957 if (h < boneOff) 1071 if(h < boneOff)
958 { 1072 {
959 m_collideNormal.X = contact.normal.X; 1073 m_collideNormal.X = contact.normal.X;
960 m_collideNormal.Y = contact.normal.Y; 1074 m_collideNormal.Y = contact.normal.Y;
@@ -969,7 +1083,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde
969 return true; 1083 return true;
970 1084
971 feetcollision = true; 1085 feetcollision = true;
972 if (h < boneOff) 1086 if(h < boneOff)
973 { 1087 {
974 m_collideNormal.X = contact.normal.X; 1088 m_collideNormal.X = contact.normal.X;
975 m_collideNormal.Y = contact.normal.Y; 1089 m_collideNormal.Y = contact.normal.Y;
@@ -989,18 +1103,18 @@ namespace OpenSim.Region.PhysicsModule.ubOde
989 t = Math.Abs(t); 1103 t = Math.Abs(t);
990 if(t > 1e-6) 1104 if(t > 1e-6)
991 { 1105 {
992 tdp /= t; 1106 tdp /= t;
993 tdp *= contact.normal.X; 1107 tdp *= contact.normal.X;
994 } 1108 }
995 else 1109 else
996 tdp *= 10; 1110 tdp *= 10;
997 1111
998 if (tdp > 0.25f) 1112 if(tdp > 0.25f)
999 tdp = 0.25f; 1113 tdp = 0.25f;
1000 1114
1001 altContact.depth = tdp; 1115 altContact.depth = tdp;
1002 1116
1003 if (reverse) 1117 if(reverse)
1004 { 1118 {
1005 altContact.normal.X = offset.X; 1119 altContact.normal.X = offset.X;
1006 altContact.normal.Y = offset.Y; 1120 altContact.normal.Y = offset.Y;
@@ -1024,28 +1138,28 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1024 /// <param name="timeStep"></param> 1138 /// <param name="timeStep"></param>
1025 public void Move(List<OdeCharacter> defects) 1139 public void Move(List<OdeCharacter> defects)
1026 { 1140 {
1027 if (Body == IntPtr.Zero) 1141 if(Body == IntPtr.Zero)
1028 return; 1142 return;
1029 1143
1030 d.Vector3 dtmp = d.BodyGetPosition(Body); 1144 SafeNativeMethods.Vector3 dtmp = SafeNativeMethods.BodyGetPosition(Body);
1031 Vector3 localpos = new Vector3(dtmp.X, dtmp.Y, dtmp.Z); 1145 Vector3 localpos = new Vector3(dtmp.X,dtmp.Y,dtmp.Z);
1032 1146
1033 // the Amotor still lets avatar rotation to drift during colisions 1147 // the Amotor still lets avatar rotation to drift during colisions
1034 // so force it back to identity 1148 // so force it back to identity
1035 1149
1036 d.Quaternion qtmp; 1150 SafeNativeMethods.Quaternion qtmp;
1037 qtmp.W = m_orientation2D.W; 1151 qtmp.W = m_orientation2D.W;
1038 qtmp.X = m_orientation2D.X; 1152 qtmp.X = m_orientation2D.X;
1039 qtmp.Y = m_orientation2D.Y; 1153 qtmp.Y = m_orientation2D.Y;
1040 qtmp.Z = m_orientation2D.Z; 1154 qtmp.Z = m_orientation2D.Z;
1041 d.BodySetQuaternion(Body, ref qtmp); 1155 SafeNativeMethods.BodySetQuaternion(Body,ref qtmp);
1042 1156
1043 if (m_pidControllerActive == false) 1157 if(m_pidControllerActive == false)
1044 { 1158 {
1045 _zeroPosition = localpos; 1159 _zeroPosition = localpos;
1046 } 1160 }
1047 1161
1048 if (!localpos.IsFinite()) 1162 if(!localpos.IsFinite())
1049 { 1163 {
1050 m_log.Warn("[PHYSICS]: Avatar Position is non-finite!"); 1164 m_log.Warn("[PHYSICS]: Avatar Position is non-finite!");
1051 defects.Add(this); 1165 defects.Add(this);
@@ -1058,44 +1172,44 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1058 1172
1059 // check outbounds forcing to be in world 1173 // check outbounds forcing to be in world
1060 bool fixbody = false; 1174 bool fixbody = false;
1061 if (localpos.X < 0.0f) 1175 if(localpos.X < 0.0f)
1062 { 1176 {
1063 fixbody = true; 1177 fixbody = true;
1064 localpos.X = 0.1f; 1178 localpos.X = 0.1f;
1065 } 1179 }
1066 else if (localpos.X > m_parent_scene.WorldExtents.X - 0.1f) 1180 else if(localpos.X > m_parent_scene.WorldExtents.X - 0.1f)
1067 { 1181 {
1068 fixbody = true; 1182 fixbody = true;
1069 localpos.X = m_parent_scene.WorldExtents.X - 0.1f; 1183 localpos.X = m_parent_scene.WorldExtents.X - 0.1f;
1070 } 1184 }
1071 if (localpos.Y < 0.0f) 1185 if(localpos.Y < 0.0f)
1072 { 1186 {
1073 fixbody = true; 1187 fixbody = true;
1074 localpos.Y = 0.1f; 1188 localpos.Y = 0.1f;
1075 } 1189 }
1076 else if (localpos.Y > m_parent_scene.WorldExtents.Y - 0.1) 1190 else if(localpos.Y > m_parent_scene.WorldExtents.Y - 0.1)
1077 { 1191 {
1078 fixbody = true; 1192 fixbody = true;
1079 localpos.Y = m_parent_scene.WorldExtents.Y - 0.1f; 1193 localpos.Y = m_parent_scene.WorldExtents.Y - 0.1f;
1080 } 1194 }
1081 if (fixbody) 1195 if(fixbody)
1082 { 1196 {
1083 m_freemove = false; 1197 m_freemove = false;
1084 d.BodySetPosition(Body, localpos.X, localpos.Y, localpos.Z); 1198 SafeNativeMethods.BodySetPosition(Body,localpos.X,localpos.Y,localpos.Z);
1085 } 1199 }
1086 1200
1087 float breakfactor; 1201 float breakfactor;
1088 1202
1089 Vector3 vec = Vector3.Zero; 1203 Vector3 vec = Vector3.Zero;
1090 dtmp = d.BodyGetLinearVel(Body); 1204 dtmp = SafeNativeMethods.BodyGetLinearVel(Body);
1091 Vector3 vel = new Vector3(dtmp.X, dtmp.Y, dtmp.Z); 1205 Vector3 vel = new Vector3(dtmp.X,dtmp.Y,dtmp.Z);
1092 float velLengthSquared = vel.LengthSquared(); 1206 float velLengthSquared = vel.LengthSquared();
1093 1207
1094 Vector3 ctz = _target_velocity; 1208 Vector3 ctz = _target_velocity;
1095 1209
1096 float movementdivisor = 1f; 1210 float movementdivisor = 1f;
1097 //Ubit change divisions into multiplications below 1211 //Ubit change divisions into multiplications below
1098 if (!m_alwaysRun) 1212 if(!m_alwaysRun)
1099 movementdivisor = 1 / walkDivisor; 1213 movementdivisor = 1 / walkDivisor;
1100 else 1214 else
1101 movementdivisor = 1 / runDivisor; 1215 movementdivisor = 1 / runDivisor;
@@ -1106,25 +1220,25 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1106 //****************************************** 1220 //******************************************
1107 // colide with land 1221 // colide with land
1108 1222
1109 d.AABB aabb; 1223 SafeNativeMethods.AABB aabb;
1110// d.GeomGetAABB(feetbox, out aabb); 1224 // d.GeomGetAABB(feetbox, out aabb);
1111 d.GeomGetAABB(capsule, out aabb); 1225 SafeNativeMethods.GeomGetAABB(capsule,out aabb);
1112 float chrminZ = aabb.MinZ; // move up a bit 1226 float chrminZ = aabb.MinZ; // move up a bit
1113 Vector3 posch = localpos; 1227 Vector3 posch = localpos;
1114 1228
1115 float ftmp; 1229 float ftmp;
1116 1230
1117 if (m_flying) 1231 if(m_flying)
1118 { 1232 {
1119 ftmp = timeStep; 1233 ftmp = timeStep;
1120 posch.X += vel.X * ftmp; 1234 posch.X += vel.X * ftmp;
1121 posch.Y += vel.Y * ftmp; 1235 posch.Y += vel.Y * ftmp;
1122 } 1236 }
1123 1237
1124 float terrainheight = m_parent_scene.GetTerrainHeightAtXY(posch.X, posch.Y); 1238 float terrainheight = m_parent_scene.GetTerrainHeightAtXY(posch.X,posch.Y);
1125 if (chrminZ < terrainheight) 1239 if(chrminZ < terrainheight)
1126 { 1240 {
1127 if (ctz.Z < 0) 1241 if(ctz.Z < 0)
1128 ctz.Z = 0; 1242 ctz.Z = 0;
1129 1243
1130 if(!m_haveLastFallVel) 1244 if(!m_haveLastFallVel)
@@ -1133,12 +1247,12 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1133 m_haveLastFallVel = true; 1247 m_haveLastFallVel = true;
1134 } 1248 }
1135 1249
1136 Vector3 n = m_parent_scene.GetTerrainNormalAtXY(posch.X, posch.Y); 1250 Vector3 n = m_parent_scene.GetTerrainNormalAtXY(posch.X,posch.Y);
1137 float depth = terrainheight - chrminZ; 1251 float depth = terrainheight - chrminZ;
1138 1252
1139 vec.Z = depth * PID_P * 50; 1253 vec.Z = depth * PID_P * 50;
1140 1254
1141 if (!m_flying) 1255 if(!m_flying)
1142 { 1256 {
1143 vec.Z += -vel.Z * PID_D; 1257 vec.Z += -vel.Z * PID_D;
1144 if(n.Z < 0.4f) 1258 if(n.Z < 0.4f)
@@ -1154,19 +1268,19 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1154 n.X = 0f; 1268 n.X = 0f;
1155 n.Y = 0f; 1269 n.Y = 0f;
1156 n.Z = 1.0f; 1270 n.Z = 1.0f;
1157 } 1271 }
1158 } 1272 }
1159 } 1273 }
1160 1274
1161 if (depth < 0.2f) 1275 if(depth < 0.2f)
1162 { 1276 {
1163 m_colliderGroundfilter++; 1277 m_colliderGroundfilter++;
1164 if (m_colliderGroundfilter > 2) 1278 if(m_colliderGroundfilter > 2)
1165 { 1279 {
1166 m_iscolliding = true; 1280 m_iscolliding = true;
1167 m_colliderfilter = 2; 1281 m_colliderfilter = 2;
1168 1282
1169 if (m_colliderGroundfilter > 10) 1283 if(m_colliderGroundfilter > 10)
1170 { 1284 {
1171 m_colliderGroundfilter = 10; 1285 m_colliderGroundfilter = 10;
1172 m_freemove = false; 1286 m_freemove = false;
@@ -1186,19 +1300,19 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1186 contact.SurfaceNormal.X = -n.X; 1300 contact.SurfaceNormal.X = -n.X;
1187 contact.SurfaceNormal.Y = -n.Y; 1301 contact.SurfaceNormal.Y = -n.Y;
1188 contact.SurfaceNormal.Z = -n.Z; 1302 contact.SurfaceNormal.Z = -n.Z;
1189 contact.RelativeSpeed = Vector3.Dot(m_lastFallVel, n); 1303 contact.RelativeSpeed = Vector3.Dot(m_lastFallVel,n);
1190 contact.CharacterFeet = true; 1304 contact.CharacterFeet = true;
1191 AddCollisionEvent(0, contact); 1305 AddCollisionEvent(0,contact);
1192 m_lastFallVel = vel; 1306 m_lastFallVel = vel;
1193 1307
1194// vec.Z *= 0.5f; 1308 // vec.Z *= 0.5f;
1195 } 1309 }
1196 } 1310 }
1197 1311
1198 else 1312 else
1199 { 1313 {
1200 m_colliderGroundfilter -= 5; 1314 m_colliderGroundfilter -= 5;
1201 if (m_colliderGroundfilter <= 0) 1315 if(m_colliderGroundfilter <= 0)
1202 { 1316 {
1203 m_colliderGroundfilter = 0; 1317 m_colliderGroundfilter = 0;
1204 m_iscollidingGround = false; 1318 m_iscollidingGround = false;
@@ -1209,7 +1323,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1209 { 1323 {
1210 m_haveLastFallVel = false; 1324 m_haveLastFallVel = false;
1211 m_colliderGroundfilter -= 5; 1325 m_colliderGroundfilter -= 5;
1212 if (m_colliderGroundfilter <= 0) 1326 if(m_colliderGroundfilter <= 0)
1213 { 1327 {
1214 m_colliderGroundfilter = 0; 1328 m_colliderGroundfilter = 0;
1215 m_iscollidingGround = false; 1329 m_iscollidingGround = false;
@@ -1218,11 +1332,11 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1218 1332
1219 bool hoverPIDActive = false; 1333 bool hoverPIDActive = false;
1220 1334
1221 if (m_useHoverPID && m_PIDHoverTau != 0 && m_PIDHoverHeight != 0) 1335 if(m_useHoverPID && m_PIDHoverTau != 0 && m_PIDHoverHeight != 0)
1222 { 1336 {
1223 hoverPIDActive = true; 1337 hoverPIDActive = true;
1224 1338
1225 switch (m_PIDHoverType) 1339 switch(m_PIDHoverType)
1226 { 1340 {
1227 case PIDHoverType.Ground: 1341 case PIDHoverType.Ground:
1228 m_targetHoverHeight = terrainheight + m_PIDHoverHeight; 1342 m_targetHoverHeight = terrainheight + m_PIDHoverHeight;
@@ -1230,20 +1344,20 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1230 1344
1231 case PIDHoverType.GroundAndWater: 1345 case PIDHoverType.GroundAndWater:
1232 float waterHeight = m_parent_scene.GetWaterLevel(); 1346 float waterHeight = m_parent_scene.GetWaterLevel();
1233 if (terrainheight > waterHeight) 1347 if(terrainheight > waterHeight)
1234 m_targetHoverHeight = terrainheight + m_PIDHoverHeight; 1348 m_targetHoverHeight = terrainheight + m_PIDHoverHeight;
1235 else 1349 else
1236 m_targetHoverHeight = waterHeight + m_PIDHoverHeight; 1350 m_targetHoverHeight = waterHeight + m_PIDHoverHeight;
1237 break; 1351 break;
1238 } // end switch (m_PIDHoverType) 1352 } // end switch (m_PIDHoverType)
1239 1353
1240 // don't go underground 1354 // don't go underground
1241 if (m_targetHoverHeight > terrainheight + 0.5f * (aabb.MaxZ - aabb.MinZ)) 1355 if(m_targetHoverHeight > terrainheight + 0.5f * (aabb.MaxZ - aabb.MinZ))
1242 { 1356 {
1243 float fz = (m_targetHoverHeight - localpos.Z); 1357 float fz = (m_targetHoverHeight - localpos.Z);
1244 1358
1245 // if error is zero, use position control; otherwise, velocity control 1359 // if error is zero, use position control; otherwise, velocity control
1246 if (Math.Abs(fz) < 0.01f) 1360 if(Math.Abs(fz) < 0.01f)
1247 { 1361 {
1248 ctz.Z = 0; 1362 ctz.Z = 0;
1249 } 1363 }
@@ -1253,9 +1367,9 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1253 fz /= m_PIDHoverTau; 1367 fz /= m_PIDHoverTau;
1254 1368
1255 float tmp = Math.Abs(fz); 1369 float tmp = Math.Abs(fz);
1256 if (tmp > 50) 1370 if(tmp > 50)
1257 fz = 50 * Math.Sign(fz); 1371 fz = 50 * Math.Sign(fz);
1258 else if (tmp < 0.1) 1372 else if(tmp < 0.1)
1259 fz = 0.1f * Math.Sign(fz); 1373 fz = 0.1f * Math.Sign(fz);
1260 1374
1261 ctz.Z = fz; 1375 ctz.Z = fz;
@@ -1264,43 +1378,43 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1264 } 1378 }
1265 1379
1266 //****************************************** 1380 //******************************************
1267 if (!m_iscolliding) 1381 if(!m_iscolliding)
1268 m_collideNormal.Z = 0; 1382 m_collideNormal.Z = 0;
1269 1383
1270 bool tviszero = (ctz.X == 0.0f && ctz.Y == 0.0f && ctz.Z == 0.0f); 1384 bool tviszero = (ctz.X == 0.0f && ctz.Y == 0.0f && ctz.Z == 0.0f);
1271 1385
1272 if (!tviszero) 1386 if(!tviszero)
1273 { 1387 {
1274 m_freemove = false; 1388 m_freemove = false;
1275 1389
1276 // movement relative to surface if moving on it 1390 // movement relative to surface if moving on it
1277 // dont disturbe vertical movement, ie jumps 1391 // dont disturbe vertical movement, ie jumps
1278 if (m_iscolliding && !m_flying && ctz.Z == 0 && m_collideNormal.Z > 0.2f && m_collideNormal.Z < 0.94f) 1392 if(m_iscolliding && !m_flying && ctz.Z == 0 && m_collideNormal.Z > 0.2f && m_collideNormal.Z < 0.94f)
1279 { 1393 {
1280 float p = ctz.X * m_collideNormal.X + ctz.Y * m_collideNormal.Y; 1394 float p = ctz.X * m_collideNormal.X + ctz.Y * m_collideNormal.Y;
1281 ctz.X *= (float)Math.Sqrt(1 - m_collideNormal.X * m_collideNormal.X); 1395 ctz.X *= (float)Math.Sqrt(1 - m_collideNormal.X * m_collideNormal.X);
1282 ctz.Y *= (float)Math.Sqrt(1 - m_collideNormal.Y * m_collideNormal.Y); 1396 ctz.Y *= (float)Math.Sqrt(1 - m_collideNormal.Y * m_collideNormal.Y);
1283 ctz.Z -= p; 1397 ctz.Z -= p;
1284 if (ctz.Z < 0) 1398 if(ctz.Z < 0)
1285 ctz.Z *= 2; 1399 ctz.Z *= 2;
1286 1400
1287 } 1401 }
1288 1402
1289 } 1403 }
1290 1404
1291 if (!m_freemove) 1405 if(!m_freemove)
1292 { 1406 {
1293 1407
1294 // if velocity is zero, use position control; otherwise, velocity control 1408 // if velocity is zero, use position control; otherwise, velocity control
1295 if (tviszero && m_iscolliding && !m_flying) 1409 if(tviszero && m_iscolliding && !m_flying)
1296 { 1410 {
1297 // keep track of where we stopped. No more slippin' & slidin' 1411 // keep track of where we stopped. No more slippin' & slidin'
1298 if (!_zeroFlag) 1412 if(!_zeroFlag)
1299 { 1413 {
1300 _zeroFlag = true; 1414 _zeroFlag = true;
1301 _zeroPosition = localpos; 1415 _zeroPosition = localpos;
1302 } 1416 }
1303 if (m_pidControllerActive) 1417 if(m_pidControllerActive)
1304 { 1418 {
1305 // We only want to deactivate the PID Controller if we think we want to have our surrogate 1419 // We only want to deactivate the PID Controller if we think we want to have our surrogate
1306 // react to the physics scene by moving it's position. 1420 // react to the physics scene by moving it's position.
@@ -1313,12 +1427,12 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1313 vec.Z += -vel.Z * PID_D + (_zeroPosition.Z - localpos.Z) * PID_P; 1427 vec.Z += -vel.Z * PID_D + (_zeroPosition.Z - localpos.Z) * PID_P;
1314 else 1428 else
1315 vec.Z += (-vel.Z * PID_D + (_zeroPosition.Z - localpos.Z) * PID_P) * 0.2f; 1429 vec.Z += (-vel.Z * PID_D + (_zeroPosition.Z - localpos.Z) * PID_P) * 0.2f;
1316/* 1430 /*
1317 if (flying) 1431 if (flying)
1318 { 1432 {
1319 vec.Z += -vel.Z * PID_D + (_zeroPosition.Z - localpos.Z) * PID_P; 1433 vec.Z += -vel.Z * PID_D + (_zeroPosition.Z - localpos.Z) * PID_P;
1320 } 1434 }
1321*/ 1435 */
1322 } 1436 }
1323 //PidStatus = true; 1437 //PidStatus = true;
1324 } 1438 }
@@ -1327,12 +1441,12 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1327 m_pidControllerActive = true; 1441 m_pidControllerActive = true;
1328 _zeroFlag = false; 1442 _zeroFlag = false;
1329 1443
1330 if (m_iscolliding) 1444 if(m_iscolliding)
1331 { 1445 {
1332 if (!m_flying) 1446 if(!m_flying)
1333 { 1447 {
1334 // we are on a surface 1448 // we are on a surface
1335 if (ctz.Z > 0f) 1449 if(ctz.Z > 0f)
1336 { 1450 {
1337 // moving up or JUMPING 1451 // moving up or JUMPING
1338 vec.Z += (ctz.Z - vel.Z) * PID_D * 2f; 1452 vec.Z += (ctz.Z - vel.Z) * PID_D * 2f;
@@ -1342,9 +1456,9 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1342 else 1456 else
1343 { 1457 {
1344 // we are moving down on a surface 1458 // we are moving down on a surface
1345 if (ctz.Z == 0) 1459 if(ctz.Z == 0)
1346 { 1460 {
1347 if (vel.Z > 0) 1461 if(vel.Z > 0)
1348 vec.Z -= vel.Z * PID_D * 2f; 1462 vec.Z -= vel.Z * PID_D * 2f;
1349 vec.X += (ctz.X - vel.X) * (PID_D); 1463 vec.X += (ctz.X - vel.X) * (PID_D);
1350 vec.Y += (ctz.Y - vel.Y) * (PID_D); 1464 vec.Y += (ctz.Y - vel.Y) * (PID_D);
@@ -1352,15 +1466,15 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1352 // intencionally going down 1466 // intencionally going down
1353 else 1467 else
1354 { 1468 {
1355 if (ctz.Z < vel.Z) 1469 if(ctz.Z < vel.Z)
1356 vec.Z += (ctz.Z - vel.Z) * PID_D; 1470 vec.Z += (ctz.Z - vel.Z) * PID_D;
1357 else 1471 else
1358 { 1472 {
1359 } 1473 }
1360 1474
1361 if (Math.Abs(ctz.X) > Math.Abs(vel.X)) 1475 if(Math.Abs(ctz.X) > Math.Abs(vel.X))
1362 vec.X += (ctz.X - vel.X) * (PID_D); 1476 vec.X += (ctz.X - vel.X) * (PID_D);
1363 if (Math.Abs(ctz.Y) > Math.Abs(vel.Y)) 1477 if(Math.Abs(ctz.Y) > Math.Abs(vel.Y))
1364 vec.Y += (ctz.Y - vel.Y) * (PID_D); 1478 vec.Y += (ctz.Y - vel.Y) * (PID_D);
1365 } 1479 }
1366 } 1480 }
@@ -1377,7 +1491,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1377 } 1491 }
1378 else // ie not colliding 1492 else // ie not colliding
1379 { 1493 {
1380 if (m_flying || hoverPIDActive) //(!m_iscolliding && flying) 1494 if(m_flying || hoverPIDActive) //(!m_iscolliding && flying)
1381 { 1495 {
1382 // we're in mid air suspended 1496 // we're in mid air suspended
1383 vec.X += (ctz.X - vel.X) * (PID_D); 1497 vec.X += (ctz.X - vel.X) * (PID_D);
@@ -1394,13 +1508,13 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1394 vec.X += (ctz.X - vel.X) * PID_D * 0.833f; 1508 vec.X += (ctz.X - vel.X) * PID_D * 0.833f;
1395 vec.Y += (ctz.Y - vel.Y) * PID_D * 0.833f; 1509 vec.Y += (ctz.Y - vel.Y) * PID_D * 0.833f;
1396 // hack for breaking on fall 1510 // hack for breaking on fall
1397 if (ctz.Z == -9999f) 1511 if(ctz.Z == -9999f)
1398 vec.Z += -vel.Z * PID_D - m_parent_scene.gravityz * m_mass; 1512 vec.Z += -vel.Z * PID_D - m_parent_scene.gravityz * m_mass;
1399 } 1513 }
1400 } 1514 }
1401 } 1515 }
1402 1516
1403 if (velLengthSquared > 2500.0f) // 50m/s apply breaks 1517 if(velLengthSquared > 2500.0f) // 50m/s apply breaks
1404 { 1518 {
1405 breakfactor = 0.16f * m_mass; 1519 breakfactor = 0.16f * m_mass;
1406 vec.X -= breakfactor * vel.X; 1520 vec.X -= breakfactor * vel.X;
@@ -1413,13 +1527,13 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1413 breakfactor = m_mass; 1527 breakfactor = m_mass;
1414 vec.X -= breakfactor * vel.X; 1528 vec.X -= breakfactor * vel.X;
1415 vec.Y -= breakfactor * vel.Y; 1529 vec.Y -= breakfactor * vel.Y;
1416 if (m_flying) 1530 if(m_flying)
1417 vec.Z -= 0.5f * breakfactor * vel.Z; 1531 vec.Z -= 0.5f * breakfactor * vel.Z;
1418 else 1532 else
1419 vec.Z -= .16f* m_mass * vel.Z; 1533 vec.Z -= .16f* m_mass * vel.Z;
1420 } 1534 }
1421 1535
1422 if (m_flying || hoverPIDActive) 1536 if(m_flying || hoverPIDActive)
1423 { 1537 {
1424 vec.Z -= m_parent_scene.gravityz * m_mass; 1538 vec.Z -= m_parent_scene.gravityz * m_mass;
1425 1539
@@ -1428,18 +1542,18 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1428 //Added for auto fly height. Kitto Flora 1542 //Added for auto fly height. Kitto Flora
1429 float target_altitude = terrainheight + MinimumGroundFlightOffset; 1543 float target_altitude = terrainheight + MinimumGroundFlightOffset;
1430 1544
1431 if (localpos.Z < target_altitude) 1545 if(localpos.Z < target_altitude)
1432 { 1546 {
1433 vec.Z += (target_altitude - localpos.Z) * PID_P * 5.0f; 1547 vec.Z += (target_altitude - localpos.Z) * PID_P * 5.0f;
1434 } 1548 }
1435 // end add Kitto Flora 1549 // end add Kitto Flora
1436 } 1550 }
1437 } 1551 }
1438 1552
1439 if (vec.IsFinite()) 1553 if(vec.IsFinite())
1440 { 1554 {
1441 if (vec.X != 0 || vec.Y !=0 || vec.Z !=0) 1555 if(vec.X != 0 || vec.Y !=0 || vec.Z !=0)
1442 d.BodyAddForce(Body, vec.X, vec.Y, vec.Z); 1556 SafeNativeMethods.BodyAddForce(Body,vec.X,vec.Y,vec.Z);
1443 } 1557 }
1444 else 1558 else
1445 { 1559 {
@@ -1456,7 +1570,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1456 // _position = localpos; 1570 // _position = localpos;
1457 _position = localpos; 1571 _position = localpos;
1458 1572
1459 if (_zeroFlag) 1573 if(_zeroFlag)
1460 { 1574 {
1461 _velocity = Vector3.Zero; 1575 _velocity = Vector3.Zero;
1462 _acceleration = Vector3.Zero; 1576 _acceleration = Vector3.Zero;
@@ -1464,12 +1578,12 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1464 } 1578 }
1465 else 1579 else
1466 { 1580 {
1467 Vector3 a =_velocity; // previus velocity 1581 Vector3 a = _velocity; // previus velocity
1468 SetSmooth(ref _velocity, ref vel, 2); 1582 SetSmooth(ref _velocity,ref vel,2);
1469 a = (_velocity - a) * invtimeStep; 1583 a = (_velocity - a) * invtimeStep;
1470 SetSmooth(ref _acceleration, ref a, 2); 1584 SetSmooth(ref _acceleration,ref a,2);
1471 1585
1472 dtmp = d.BodyGetAngularVel(Body); 1586 dtmp = SafeNativeMethods.BodyGetAngularVel(Body);
1473 m_rotationalVelocity.X = 0f; 1587 m_rotationalVelocity.X = 0f;
1474 m_rotationalVelocity.Y = 0f; 1588 m_rotationalVelocity.Y = 0f;
1475 m_rotationalVelocity.Z = dtmp.Z; 1589 m_rotationalVelocity.Z = dtmp.Z;
@@ -1477,30 +1591,30 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1477 } 1591 }
1478 } 1592 }
1479 1593
1480 public void round(ref Vector3 v, int digits) 1594 public void round(ref Vector3 v,int digits)
1481 { 1595 {
1482 v.X = (float)Math.Round(v.X, digits); 1596 v.X = (float)Math.Round(v.X,digits);
1483 v.Y = (float)Math.Round(v.Y, digits); 1597 v.Y = (float)Math.Round(v.Y,digits);
1484 v.Z = (float)Math.Round(v.Z, digits); 1598 v.Z = (float)Math.Round(v.Z,digits);
1485 } 1599 }
1486 1600
1487 public void SetSmooth(ref Vector3 dst, ref Vector3 value) 1601 public void SetSmooth(ref Vector3 dst,ref Vector3 value)
1488 { 1602 {
1489 dst.X = 0.1f * dst.X + 0.9f * value.X; 1603 dst.X = 0.1f * dst.X + 0.9f * value.X;
1490 dst.Y = 0.1f * dst.Y + 0.9f * value.Y; 1604 dst.Y = 0.1f * dst.Y + 0.9f * value.Y;
1491 dst.Z = 0.1f * dst.Z + 0.9f * value.Z; 1605 dst.Z = 0.1f * dst.Z + 0.9f * value.Z;
1492 } 1606 }
1493 1607
1494 public void SetSmooth(ref Vector3 dst, ref Vector3 value, int rounddigits) 1608 public void SetSmooth(ref Vector3 dst,ref Vector3 value,int rounddigits)
1495 { 1609 {
1496 dst.X = 0.4f * dst.X + 0.6f * value.X; 1610 dst.X = 0.4f * dst.X + 0.6f * value.X;
1497 dst.X = (float)Math.Round(dst.X, rounddigits); 1611 dst.X = (float)Math.Round(dst.X,rounddigits);
1498 1612
1499 dst.Y = 0.4f * dst.Y + 0.6f * value.Y; 1613 dst.Y = 0.4f * dst.Y + 0.6f * value.Y;
1500 dst.Y = (float)Math.Round(dst.Y, rounddigits); 1614 dst.Y = (float)Math.Round(dst.Y,rounddigits);
1501 1615
1502 dst.Z = 0.4f * dst.Z + 0.6f * value.Z; 1616 dst.Z = 0.4f * dst.Z + 0.6f * value.Z;
1503 dst.Z = (float)Math.Round(dst.Z, rounddigits); 1617 dst.Z = (float)Math.Round(dst.Z,rounddigits);
1504 } 1618 }
1505 1619
1506 1620
@@ -1515,8 +1629,8 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1515 { 1629 {
1516 return; 1630 return;
1517 1631
1518// if (Body == IntPtr.Zero) 1632 // if (Body == IntPtr.Zero)
1519// return; 1633 // return;
1520 1634
1521 } 1635 }
1522 1636
@@ -1525,16 +1639,38 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1525 /// </summary> 1639 /// </summary>
1526 public void Destroy() 1640 public void Destroy()
1527 { 1641 {
1528 AddChange(changes.Remove, null); 1642 AddChange(changes.Remove,null);
1529 } 1643 }
1530 1644
1531 public override void CrossingFailure() 1645 public override void CrossingFailure()
1532 { 1646 {
1533 } 1647 }
1534 1648
1535 public override Vector3 PIDTarget { set { return; } } 1649 public override Vector3 PIDTarget
1536 public override bool PIDActive {get {return m_pidControllerActive;} set { return; } } 1650 {
1537 public override float PIDTau { set { return; } } 1651 set
1652 {
1653 return;
1654 }
1655 }
1656 public override bool PIDActive
1657 {
1658 get
1659 {
1660 return m_pidControllerActive;
1661 }
1662 set
1663 {
1664 return;
1665 }
1666 }
1667 public override float PIDTau
1668 {
1669 set
1670 {
1671 return;
1672 }
1673 }
1538 1674
1539 public override float PIDHoverHeight 1675 public override float PIDHoverHeight
1540 { 1676 {
@@ -1547,11 +1683,11 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1547 { 1683 {
1548 get 1684 get
1549 { 1685 {
1550 return m_useHoverPID; 1686 return m_useHoverPID;
1551 } 1687 }
1552 set 1688 set
1553 { 1689 {
1554 AddChange(changes.PIDHoverActive, value); 1690 AddChange(changes.PIDHoverActive,value);
1555 } 1691 }
1556 } 1692 }
1557 1693
@@ -1567,26 +1703,50 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1567 { 1703 {
1568 set 1704 set
1569 { 1705 {
1570 float tmp =0; 1706 float tmp = 0;
1571 if (value > 0) 1707 if(value > 0)
1572 { 1708 {
1573 float mint = (0.05f > timeStep ? 0.05f : timeStep); 1709 float mint = (0.05f > timeStep ? 0.05f : timeStep);
1574 if (value < mint) 1710 if(value < mint)
1575 tmp = mint; 1711 tmp = mint;
1576 else 1712 else
1577 tmp = value; 1713 tmp = value;
1578 } 1714 }
1579 AddChange(changes.PIDHoverTau, tmp); 1715 AddChange(changes.PIDHoverTau,tmp);
1580 } 1716 }
1581 } 1717 }
1582 1718
1583 public override Quaternion APIDTarget { set { return; } } 1719 public override Quaternion APIDTarget
1720 {
1721 set
1722 {
1723 return;
1724 }
1725 }
1584 1726
1585 public override bool APIDActive { set { return; } } 1727 public override bool APIDActive
1728 {
1729 set
1730 {
1731 return;
1732 }
1733 }
1586 1734
1587 public override float APIDStrength { set { return; } } 1735 public override float APIDStrength
1736 {
1737 set
1738 {
1739 return;
1740 }
1741 }
1588 1742
1589 public override float APIDDamping { set { return; } } 1743 public override float APIDDamping
1744 {
1745 set
1746 {
1747 return;
1748 }
1749 }
1590 1750
1591 public override void SubscribeEvents(int ms) 1751 public override void SubscribeEvents(int ms)
1592 { 1752 {
@@ -1604,34 +1764,34 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1604 CollisionEventsThisFrame.Clear(); 1764 CollisionEventsThisFrame.Clear();
1605 } 1765 }
1606 1766
1607 public override void AddCollisionEvent(uint CollidedWith, ContactPoint contact) 1767 public override void AddCollisionEvent(uint CollidedWith,ContactPoint contact)
1608 { 1768 {
1609 lock(CollisionEventsThisFrame) 1769 lock(CollisionEventsThisFrame)
1610 CollisionEventsThisFrame.AddCollider(CollidedWith, contact); 1770 CollisionEventsThisFrame.AddCollider(CollidedWith,contact);
1611 m_parent_scene.AddCollisionEventReporting(this); 1771 m_parent_scene.AddCollisionEventReporting(this);
1612 } 1772 }
1613 1773
1614 public void SendCollisions(int timestep) 1774 public void SendCollisions(int timestep)
1615 { 1775 {
1616 if (m_cureventsubscription < 50000) 1776 if(m_cureventsubscription < 50000)
1617 m_cureventsubscription += timestep; 1777 m_cureventsubscription += timestep;
1618 1778
1619 if (m_cureventsubscription < m_eventsubscription) 1779 if(m_cureventsubscription < m_eventsubscription)
1620 return; 1780 return;
1621 1781
1622 lock(CollisionEventsThisFrame) 1782 lock(CollisionEventsThisFrame)
1623 { 1783 {
1624 int ncolisions = CollisionEventsThisFrame.m_objCollisionList.Count; 1784 int ncolisions = CollisionEventsThisFrame.m_objCollisionList.Count;
1625 1785
1626 if (!SentEmptyCollisionsEvent || ncolisions > 0) 1786 if(!SentEmptyCollisionsEvent || ncolisions > 0)
1627 { 1787 {
1628 base.SendCollisionUpdate(CollisionEventsThisFrame); 1788 base.SendCollisionUpdate(CollisionEventsThisFrame);
1629 m_cureventsubscription = 0; 1789 m_cureventsubscription = 0;
1630 1790
1631 if (ncolisions == 0) 1791 if(ncolisions == 0)
1632 { 1792 {
1633 SentEmptyCollisionsEvent = true; 1793 SentEmptyCollisionsEvent = true;
1634 // _parent_scene.RemoveCollisionEventReporting(this); 1794 // _parent_scene.RemoveCollisionEventReporting(this);
1635 } 1795 }
1636 else 1796 else
1637 { 1797 {
@@ -1644,20 +1804,20 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1644 1804
1645 public override bool SubscribedEvents() 1805 public override bool SubscribedEvents()
1646 { 1806 {
1647 if (m_eventsubscription > 0) 1807 if(m_eventsubscription > 0)
1648 return true; 1808 return true;
1649 return false; 1809 return false;
1650 } 1810 }
1651 1811
1652 private void changePhysicsStatus(bool NewStatus) 1812 private void changePhysicsStatus(bool NewStatus)
1653 { 1813 {
1654 if (NewStatus != m_isPhysical) 1814 if(NewStatus != m_isPhysical)
1655 { 1815 {
1656 if (NewStatus) 1816 if(NewStatus)
1657 { 1817 {
1658 AvatarGeomAndBodyDestroy(); 1818 AvatarGeomAndBodyDestroy();
1659 1819
1660 AvatarGeomAndBodyCreation(_position.X, _position.Y, _position.Z); 1820 AvatarGeomAndBodyCreation(_position.X,_position.Y,_position.Z);
1661 1821
1662 m_parent_scene.actor_name_map[collider] = (PhysicsActor)this; 1822 m_parent_scene.actor_name_map[collider] = (PhysicsActor)this;
1663 m_parent_scene.actor_name_map[capsule] = (PhysicsActor)this; 1823 m_parent_scene.actor_name_map[capsule] = (PhysicsActor)this;
@@ -1697,20 +1857,20 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1697 1857
1698 private void changeSize(Vector3 pSize) 1858 private void changeSize(Vector3 pSize)
1699 { 1859 {
1700 if (pSize.IsFinite()) 1860 if(pSize.IsFinite())
1701 { 1861 {
1702 // for now only look to Z changes since viewers also don't change X and Y 1862 // for now only look to Z changes since viewers also don't change X and Y
1703 if (pSize.Z != m_size.Z) 1863 if(pSize.Z != m_size.Z)
1704 { 1864 {
1705 AvatarGeomAndBodyDestroy(); 1865 AvatarGeomAndBodyDestroy();
1706 1866
1707 float oldsz = m_size.Z; 1867 float oldsz = m_size.Z;
1708 m_size = pSize; 1868 m_size = pSize;
1709 1869
1710 AvatarGeomAndBodyCreation(_position.X, _position.Y, 1870 AvatarGeomAndBodyCreation(_position.X,_position.Y,
1711 _position.Z + (m_size.Z - oldsz) * 0.5f); 1871 _position.Z + (m_size.Z - oldsz) * 0.5f);
1712 1872
1713// Velocity = Vector3.Zero; 1873 // Velocity = Vector3.Zero;
1714 m_targetVelocity = Vector3.Zero; 1874 m_targetVelocity = Vector3.Zero;
1715 1875
1716 m_parent_scene.actor_name_map[collider] = (PhysicsActor)this; 1876 m_parent_scene.actor_name_map[collider] = (PhysicsActor)this;
@@ -1725,18 +1885,18 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1725 } 1885 }
1726 } 1886 }
1727 1887
1728 private void changePosition( Vector3 newPos) 1888 private void changePosition(Vector3 newPos)
1729 { 1889 {
1730 if (Body != IntPtr.Zero) 1890 if(Body != IntPtr.Zero)
1731 d.BodySetPosition(Body, newPos.X, newPos.Y, newPos.Z); 1891 SafeNativeMethods.BodySetPosition(Body,newPos.X,newPos.Y,newPos.Z);
1732 _position = newPos; 1892 _position = newPos;
1733 m_freemove = false; 1893 m_freemove = false;
1734 m_pidControllerActive = true; 1894 m_pidControllerActive = true;
1735 } 1895 }
1736 1896
1737 private void changeOrientation(Quaternion newOri) 1897 private void changeOrientation(Quaternion newOri)
1738 { 1898 {
1739 if (m_orientation != newOri) 1899 if(m_orientation != newOri)
1740 { 1900 {
1741 m_orientation = newOri; // keep a copy for core use 1901 m_orientation = newOri; // keep a copy for core use
1742 // but only use rotations around Z 1902 // but only use rotations around Z
@@ -1745,7 +1905,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1745 m_orientation2D.Z = newOri.Z; 1905 m_orientation2D.Z = newOri.Z;
1746 1906
1747 float t = m_orientation2D.W * m_orientation2D.W + m_orientation2D.Z * m_orientation2D.Z; 1907 float t = m_orientation2D.W * m_orientation2D.W + m_orientation2D.Z * m_orientation2D.Z;
1748 if (t > 0) 1908 if(t > 0)
1749 { 1909 {
1750 t = 1.0f / (float)Math.Sqrt(t); 1910 t = 1.0f / (float)Math.Sqrt(t);
1751 m_orientation2D.W *= t; 1911 m_orientation2D.W *= t;
@@ -1759,12 +1919,12 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1759 m_orientation2D.Y = 0f; 1919 m_orientation2D.Y = 0f;
1760 m_orientation2D.X = 0f; 1920 m_orientation2D.X = 0f;
1761 1921
1762 d.Quaternion myrot = new d.Quaternion(); 1922 SafeNativeMethods.Quaternion myrot = new SafeNativeMethods.Quaternion();
1763 myrot.X = m_orientation2D.X; 1923 myrot.X = m_orientation2D.X;
1764 myrot.Y = m_orientation2D.Y; 1924 myrot.Y = m_orientation2D.Y;
1765 myrot.Z = m_orientation2D.Z; 1925 myrot.Z = m_orientation2D.Z;
1766 myrot.W = m_orientation2D.W; 1926 myrot.W = m_orientation2D.W;
1767 d.BodySetQuaternion(Body, ref myrot); 1927 SafeNativeMethods.BodySetQuaternion(Body,ref myrot);
1768 } 1928 }
1769 } 1929 }
1770 1930
@@ -1773,8 +1933,8 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1773 _velocity = newVel; 1933 _velocity = newVel;
1774 setFreeMove(); 1934 setFreeMove();
1775 1935
1776 if (Body != IntPtr.Zero) 1936 if(Body != IntPtr.Zero)
1777 d.BodySetLinearVel(Body, newVel.X, newVel.Y, newVel.Z); 1937 SafeNativeMethods.BodySetLinearVel(Body,newVel.X,newVel.Y,newVel.Z);
1778 } 1938 }
1779 1939
1780 private void changeTargetVelocity(Vector3 newVel) 1940 private void changeTargetVelocity(Vector3 newVel)
@@ -1841,10 +2001,10 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1841 { 2001 {
1842 setFreeMove(); 2002 setFreeMove();
1843 2003
1844 if (Body != IntPtr.Zero) 2004 if(Body != IntPtr.Zero)
1845 { 2005 {
1846 if (newForce.X != 0f || newForce.Y != 0f || newForce.Z != 0) 2006 if(newForce.X != 0f || newForce.Y != 0f || newForce.Z != 0)
1847 d.BodyAddForce(Body, newForce.X, newForce.Y, newForce.Z); 2007 SafeNativeMethods.BodyAddForce(Body,newForce.X,newForce.Y,newForce.Z);
1848 } 2008 }
1849 } 2009 }
1850 2010
@@ -1854,15 +2014,15 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1854 _velocity = newmomentum; 2014 _velocity = newmomentum;
1855 setFreeMove(); 2015 setFreeMove();
1856 2016
1857 if (Body != IntPtr.Zero) 2017 if(Body != IntPtr.Zero)
1858 d.BodySetLinearVel(Body, newmomentum.X, newmomentum.Y, newmomentum.Z); 2018 SafeNativeMethods.BodySetLinearVel(Body,newmomentum.X,newmomentum.Y,newmomentum.Z);
1859 } 2019 }
1860 2020
1861 private void changePIDHoverHeight(float val) 2021 private void changePIDHoverHeight(float val)
1862 { 2022 {
1863 m_PIDHoverHeight = val; 2023 m_PIDHoverHeight = val;
1864 if (val == 0) 2024 if(val == 0)
1865 m_useHoverPID = false; 2025 m_useHoverPID = false;
1866 } 2026 }
1867 2027
1868 private void changePIDHoverType(PIDHoverType type) 2028 private void changePIDHoverType(PIDHoverType type)
@@ -1884,15 +2044,15 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1884 { 2044 {
1885 } 2045 }
1886 2046
1887 public bool DoAChange(changes what, object arg) 2047 public bool DoAChange(changes what,object arg)
1888 { 2048 {
1889 if (collider == IntPtr.Zero && what != changes.Add && what != changes.Remove) 2049 if(collider == IntPtr.Zero && what != changes.Add && what != changes.Remove)
1890 { 2050 {
1891 return false; 2051 return false;
1892 } 2052 }
1893 2053
1894 // nasty switch 2054 // nasty switch
1895 switch (what) 2055 switch(what)
1896 { 2056 {
1897 case changes.Add: 2057 case changes.Add:
1898 changeAdd(); 2058 changeAdd();
@@ -1980,35 +2140,35 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1980 changePIDHoverActive((bool)arg); 2140 changePIDHoverActive((bool)arg);
1981 break; 2141 break;
1982 2142
1983/* not in use for now 2143 /* not in use for now
1984 case changes.Shape: 2144 case changes.Shape:
1985 changeShape((PrimitiveBaseShape)arg); 2145 changeShape((PrimitiveBaseShape)arg);
1986 break; 2146 break;
1987 2147
1988 case changes.CollidesWater: 2148 case changes.CollidesWater:
1989 changeFloatOnWater((bool)arg); 2149 changeFloatOnWater((bool)arg);
1990 break; 2150 break;
1991 2151
1992 case changes.VolumeDtc: 2152 case changes.VolumeDtc:
1993 changeVolumedetetion((bool)arg); 2153 changeVolumedetetion((bool)arg);
1994 break; 2154 break;
1995 2155
1996 case changes.Physical: 2156 case changes.Physical:
1997 changePhysicsStatus((bool)arg); 2157 changePhysicsStatus((bool)arg);
1998 break; 2158 break;
1999 2159
2000 case changes.Selected: 2160 case changes.Selected:
2001 changeSelectedStatus((bool)arg); 2161 changeSelectedStatus((bool)arg);
2002 break; 2162 break;
2003 2163
2004 case changes.disabled: 2164 case changes.disabled:
2005 changeDisable((bool)arg); 2165 changeDisable((bool)arg);
2006 break; 2166 break;
2007 2167
2008 case changes.building: 2168 case changes.building:
2009 changeBuilding((bool)arg); 2169 changeBuilding((bool)arg);
2010 break; 2170 break;
2011*/ 2171 */
2012 case changes.Null: 2172 case changes.Null:
2013 donullchange(); 2173 donullchange();
2014 break; 2174 break;
@@ -2020,9 +2180,9 @@ namespace OpenSim.Region.PhysicsModule.ubOde
2020 return false; 2180 return false;
2021 } 2181 }
2022 2182
2023 public void AddChange(changes what, object arg) 2183 public void AddChange(changes what,object arg)
2024 { 2184 {
2025 m_parent_scene.AddChange((PhysicsActor)this, what, arg); 2185 m_parent_scene.AddChange((PhysicsActor)this,what,arg);
2026 } 2186 }
2027 2187
2028 private struct strAvatarSize 2188 private struct strAvatarSize