aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/Physics/UbitOdePlugin/ODEPrim.cs
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/Region/Physics/UbitOdePlugin/ODEPrim.cs39
1 files changed, 19 insertions, 20 deletions
diff --git a/OpenSim/Region/Physics/UbitOdePlugin/ODEPrim.cs b/OpenSim/Region/Physics/UbitOdePlugin/ODEPrim.cs
index e5fa1d7..db07565 100644
--- a/OpenSim/Region/Physics/UbitOdePlugin/ODEPrim.cs
+++ b/OpenSim/Region/Physics/UbitOdePlugin/ODEPrim.cs
@@ -187,7 +187,8 @@ namespace OpenSim.Region.Physics.OdePlugin
187 public ODEDynamics m_vehicle; 187 public ODEDynamics m_vehicle;
188 188
189 internal int m_material = (int)Material.Wood; 189 internal int m_material = (int)Material.Wood;
190 protected ContactData primContactData = new ContactData { mu = 0f, bounce = 0.1f }; 190 private float mu;
191 private float bounce;
191 192
192 /// <summary> 193 /// <summary>
193 /// Is this prim subject to physics? Even if not, it's still solid for collision purposes. 194 /// Is this prim subject to physics? Even if not, it's still solid for collision purposes.
@@ -218,25 +219,23 @@ namespace OpenSim.Region.Physics.OdePlugin
218 } 219 }
219 } 220 }
220 221
221 public override ContactData ContactData 222 public override void getContactData(ref ContactData cdata)
222 { 223 {
223 get 224 cdata.mu = mu;
225 cdata.bounce = bounce;
226
227 if (m_isphysical)
224 { 228 {
225 if (m_isphysical) 229 ODEDynamics veh;
226 { 230 if (_parent != null)
227 ODEDynamics veh; 231 veh = ((OdePrim)_parent).m_vehicle;
228 if (_parent != null) 232 else
229 veh = ((OdePrim)_parent).m_vehicle; 233 veh = m_vehicle;
230 else
231 veh = m_vehicle;
232 234
233 if (veh != null) 235 if (veh != null && veh.Type != Vehicle.TYPE_NONE)
234 if (veh.Type != Vehicle.TYPE_NONE && veh.EngineActive) 236 cdata.mu *= veh.FrictionFactor;
235 return new ContactData(0, 0);
236 }
237 return primContactData;
238 } 237 }
239 } 238 }
240 239
241 public override int PhysicsActorType 240 public override int PhysicsActorType
242 { 241 {
@@ -745,8 +744,8 @@ namespace OpenSim.Region.Physics.OdePlugin
745 public override void SetMaterial(int pMaterial) 744 public override void SetMaterial(int pMaterial)
746 { 745 {
747 m_material = pMaterial; 746 m_material = pMaterial;
748 primContactData.mu = _parent_scene.m_materialContactsData[pMaterial].mu; 747 mu = _parent_scene.m_materialContactsData[pMaterial].mu;
749 primContactData.bounce = _parent_scene.m_materialContactsData[pMaterial].bounce; 748 bounce = _parent_scene.m_materialContactsData[pMaterial].bounce;
750 } 749 }
751 750
752 public void setPrimForRemoval() 751 public void setPrimForRemoval()
@@ -899,8 +898,8 @@ namespace OpenSim.Region.Physics.OdePlugin
899 m_isSelected = false; 898 m_isSelected = false;
900 m_delaySelect = false; 899 m_delaySelect = false;
901 900
902 primContactData.mu = parent_scene.m_materialContactsData[(int)Material.Wood].mu; 901 mu = parent_scene.m_materialContactsData[(int)Material.Wood].mu;
903 primContactData.bounce = parent_scene.m_materialContactsData[(int)Material.Wood].bounce; 902 bounce = parent_scene.m_materialContactsData[(int)Material.Wood].bounce;
904 903
905 CalcPrimBodyData(); 904 CalcPrimBodyData();
906 905