aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/Physics/UbitOdePlugin/OdeScene.cs
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/Physics/UbitOdePlugin/OdeScene.cs')
-rw-r--r--OpenSim/Region/Physics/UbitOdePlugin/OdeScene.cs59
1 files changed, 27 insertions, 32 deletions
diff --git a/OpenSim/Region/Physics/UbitOdePlugin/OdeScene.cs b/OpenSim/Region/Physics/UbitOdePlugin/OdeScene.cs
index 129db5d..884a5a7 100644
--- a/OpenSim/Region/Physics/UbitOdePlugin/OdeScene.cs
+++ b/OpenSim/Region/Physics/UbitOdePlugin/OdeScene.cs
@@ -163,8 +163,6 @@ namespace OpenSim.Region.Physics.OdePlugin
163 const float comumSoftContactERP = 0.1f; 163 const float comumSoftContactERP = 0.1f;
164 const float comumContactCFM = 0.0001f; 164 const float comumContactCFM = 0.0001f;
165 165
166 float frictionScale = 1.0f;
167
168 float frictionMovementMult = 0.3f; 166 float frictionMovementMult = 0.3f;
169 167
170 float TerrainBounce = 0.1f; 168 float TerrainBounce = 0.1f;
@@ -450,33 +448,30 @@ namespace OpenSim.Region.Physics.OdePlugin
450 ContactgeomsArray = Marshal.AllocHGlobal(contactsPerCollision * d.ContactGeom.unmanagedSizeOf); 448 ContactgeomsArray = Marshal.AllocHGlobal(contactsPerCollision * d.ContactGeom.unmanagedSizeOf);
451 GlobalContactsArray = GlobalContactsArray = Marshal.AllocHGlobal(maxContactsbeforedeath * d.Contact.unmanagedSizeOf); 449 GlobalContactsArray = GlobalContactsArray = Marshal.AllocHGlobal(maxContactsbeforedeath * d.Contact.unmanagedSizeOf);
452 450
453 m_materialContactsData[(int)Material.Stone].mu = frictionScale * 0.8f; 451 m_materialContactsData[(int)Material.Stone].mu = 0.8f;
454 m_materialContactsData[(int)Material.Stone].bounce = 0.4f; 452 m_materialContactsData[(int)Material.Stone].bounce = 0.4f;
455 453
456 m_materialContactsData[(int)Material.Metal].mu = frictionScale * 0.3f; 454 m_materialContactsData[(int)Material.Metal].mu = 0.3f;
457 m_materialContactsData[(int)Material.Metal].bounce = 0.4f; 455 m_materialContactsData[(int)Material.Metal].bounce = 0.4f;
458 456
459 m_materialContactsData[(int)Material.Glass].mu = frictionScale * 0.2f; 457 m_materialContactsData[(int)Material.Glass].mu = 0.2f;
460 m_materialContactsData[(int)Material.Glass].bounce = 0.7f; 458 m_materialContactsData[(int)Material.Glass].bounce = 0.7f;
461 459
462 m_materialContactsData[(int)Material.Wood].mu = frictionScale * 0.6f; 460 m_materialContactsData[(int)Material.Wood].mu = 0.6f;
463 m_materialContactsData[(int)Material.Wood].bounce = 0.5f; 461 m_materialContactsData[(int)Material.Wood].bounce = 0.5f;
464 462
465 m_materialContactsData[(int)Material.Flesh].mu = frictionScale * 0.9f; 463 m_materialContactsData[(int)Material.Flesh].mu = 0.9f;
466 m_materialContactsData[(int)Material.Flesh].bounce = 0.3f; 464 m_materialContactsData[(int)Material.Flesh].bounce = 0.3f;
467 465
468 m_materialContactsData[(int)Material.Plastic].mu = frictionScale * 0.4f; 466 m_materialContactsData[(int)Material.Plastic].mu = 0.4f;
469 m_materialContactsData[(int)Material.Plastic].bounce = 0.7f; 467 m_materialContactsData[(int)Material.Plastic].bounce = 0.7f;
470 468
471 m_materialContactsData[(int)Material.Rubber].mu = frictionScale * 0.9f; 469 m_materialContactsData[(int)Material.Rubber].mu = 0.9f;
472 m_materialContactsData[(int)Material.Rubber].bounce = 0.95f; 470 m_materialContactsData[(int)Material.Rubber].bounce = 0.95f;
473 471
474 m_materialContactsData[(int)Material.light].mu = 0.0f; 472 m_materialContactsData[(int)Material.light].mu = 0.0f;
475 m_materialContactsData[(int)Material.light].bounce = 0.0f; 473 m_materialContactsData[(int)Material.light].bounce = 0.0f;
476 474
477 TerrainFriction *= frictionScale;
478// AvatarFriction *= frictionScale;
479
480 // Set the gravity,, don't disable things automatically (we set it explicitly on some things) 475 // Set the gravity,, don't disable things automatically (we set it explicitly on some things)
481 476
482 d.WorldSetGravity(world, gravityx, gravityy, gravityz); 477 d.WorldSetGravity(world, gravityx, gravityy, gravityz);
@@ -562,13 +557,6 @@ namespace OpenSim.Region.Physics.OdePlugin
562 } 557 }
563 558
564 559
565 /// <summary>
566 /// This is our near callback. A geometry is near a body
567 /// </summary>
568 /// <param name="space">The space that contains the geoms. Remember, spaces are also geoms</param>
569 /// <param name="g1">a geometry or space</param>
570 /// <param name="g2">another geometry or space</param>
571 ///
572 560
573 private bool GetCurContactGeom(int index, ref d.ContactGeom newcontactgeom) 561 private bool GetCurContactGeom(int index, ref d.ContactGeom newcontactgeom)
574 { 562 {
@@ -580,7 +568,13 @@ namespace OpenSim.Region.Physics.OdePlugin
580 return true; 568 return true;
581 } 569 }
582 570
583 571 /// <summary>
572 /// This is our near callback. A geometry is near a body
573 /// </summary>
574 /// <param name="space">The space that contains the geoms. Remember, spaces are also geoms</param>
575 /// <param name="g1">a geometry or space</param>
576 /// <param name="g2">another geometry or space</param>
577 ///
584 578
585 private void near(IntPtr space, IntPtr g1, IntPtr g2) 579 private void near(IntPtr space, IntPtr g1, IntPtr g2)
586 { 580 {
@@ -699,8 +693,8 @@ namespace OpenSim.Region.Physics.OdePlugin
699 // big messy collision analises 693 // big messy collision analises
700 float mu = 0; 694 float mu = 0;
701 float bounce = 0; 695 float bounce = 0;
702 ContactData contactdata1; 696 ContactData contactdata1 = new ContactData(0, 0);
703 ContactData contactdata2; 697 ContactData contactdata2 = new ContactData(0, 0);
704 bool erpSoft = false; 698 bool erpSoft = false;
705 699
706 String name = null; 700 String name = null;
@@ -714,8 +708,9 @@ namespace OpenSim.Region.Physics.OdePlugin
714 switch (p2.PhysicsActorType) 708 switch (p2.PhysicsActorType)
715 { 709 {
716 case (int)ActorTypes.Agent: 710 case (int)ActorTypes.Agent:
717 contactdata1 = p1.ContactData; 711 p1.getContactData(ref contactdata1);
718 contactdata2 = p2.ContactData; 712 p2.getContactData(ref contactdata2);
713
719 bounce = contactdata1.bounce * contactdata2.bounce; 714 bounce = contactdata1.bounce * contactdata2.bounce;
720 715
721 mu = (float)Math.Sqrt(contactdata1.mu * contactdata2.mu); 716 mu = (float)Math.Sqrt(contactdata1.mu * contactdata2.mu);
@@ -727,8 +722,8 @@ namespace OpenSim.Region.Physics.OdePlugin
727 p2.CollidingObj = true; 722 p2.CollidingObj = true;
728 break; 723 break;
729 case (int)ActorTypes.Prim: 724 case (int)ActorTypes.Prim:
730 contactdata1 = p1.ContactData; 725 p1.getContactData(ref contactdata1);
731 contactdata2 = p2.ContactData; 726 p2.getContactData(ref contactdata2);
732 bounce = contactdata1.bounce * contactdata2.bounce; 727 bounce = contactdata1.bounce * contactdata2.bounce;
733 728
734 mu = (float)Math.Sqrt(contactdata1.mu * contactdata2.mu); 729 mu = (float)Math.Sqrt(contactdata1.mu * contactdata2.mu);
@@ -749,8 +744,8 @@ namespace OpenSim.Region.Physics.OdePlugin
749 switch (p2.PhysicsActorType) 744 switch (p2.PhysicsActorType)
750 { 745 {
751 case (int)ActorTypes.Agent: 746 case (int)ActorTypes.Agent:
752 contactdata1 = p1.ContactData; 747 p1.getContactData(ref contactdata1);
753 contactdata2 = p2.ContactData; 748 p2.getContactData(ref contactdata2);
754 bounce = contactdata1.bounce * contactdata2.bounce; 749 bounce = contactdata1.bounce * contactdata2.bounce;
755 750
756 mu = (float)Math.Sqrt(contactdata1.mu * contactdata2.mu); 751 mu = (float)Math.Sqrt(contactdata1.mu * contactdata2.mu);
@@ -768,8 +763,8 @@ namespace OpenSim.Region.Physics.OdePlugin
768 p1.CollidingObj = true; 763 p1.CollidingObj = true;
769 p2.CollidingObj = true; 764 p2.CollidingObj = true;
770 } 765 }
771 contactdata1 = p1.ContactData; 766 p1.getContactData(ref contactdata1);
772 contactdata2 = p2.ContactData; 767 p2.getContactData(ref contactdata2);
773 bounce = contactdata1.bounce * contactdata2.bounce; 768 bounce = contactdata1.bounce * contactdata2.bounce;
774 erpSoft = true; 769 erpSoft = true;
775 mu = (float)Math.Sqrt(contactdata1.mu * contactdata2.mu); 770 mu = (float)Math.Sqrt(contactdata1.mu * contactdata2.mu);
@@ -784,7 +779,7 @@ namespace OpenSim.Region.Physics.OdePlugin
784 if (name == "Terrain") 779 if (name == "Terrain")
785 { 780 {
786 erpSoft = true; 781 erpSoft = true;
787 contactdata1 = p1.ContactData; 782 p1.getContactData(ref contactdata1);
788 bounce = contactdata1.bounce * TerrainBounce; 783 bounce = contactdata1.bounce * TerrainBounce;
789 mu = (float)Math.Sqrt(contactdata1.mu * TerrainFriction); 784 mu = (float)Math.Sqrt(contactdata1.mu * TerrainFriction);
790 if (Math.Abs(p1.Velocity.X) > 0.1f || Math.Abs(p1.Velocity.Y) > 0.1f) 785 if (Math.Abs(p1.Velocity.X) > 0.1f || Math.Abs(p1.Velocity.Y) > 0.1f)
@@ -811,7 +806,7 @@ namespace OpenSim.Region.Physics.OdePlugin
811 { 806 {
812 erpSoft = true; 807 erpSoft = true;
813 p2.CollidingGround = true; 808 p2.CollidingGround = true;
814 contactdata2 = p2.ContactData; 809 p2.getContactData(ref contactdata2);
815 bounce = contactdata2.bounce * TerrainBounce; 810 bounce = contactdata2.bounce * TerrainBounce;
816 mu = (float)Math.Sqrt(contactdata2.mu * TerrainFriction); 811 mu = (float)Math.Sqrt(contactdata2.mu * TerrainFriction);
817 812