aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/Physics/BulletSPlugin/BSScene.cs
diff options
context:
space:
mode:
authorRobert Adams2012-11-02 17:22:34 -0700
committerRobert Adams2012-11-03 21:15:46 -0700
commit498ea76e637961d8b4e3d39b758f7f2dea2fe998 (patch)
treef943e0ece2a7e9d7381a555c7e95b56a170d5728 /OpenSim/Region/Physics/BulletSPlugin/BSScene.cs
parentBulletSim: parameterize selection of linkset implementation (diff)
downloadopensim-SC_OLD-498ea76e637961d8b4e3d39b758f7f2dea2fe998.zip
opensim-SC_OLD-498ea76e637961d8b4e3d39b758f7f2dea2fe998.tar.gz
opensim-SC_OLD-498ea76e637961d8b4e3d39b758f7f2dea2fe998.tar.bz2
opensim-SC_OLD-498ea76e637961d8b4e3d39b758f7f2dea2fe998.tar.xz
BulletSim: Move construction of compound linkset from ShapeCollection
into LinksetCompound where it should be. Create meshes for native shapes when part of a compound linkset because scale is currently per object and not per collision shape. Don't schedule a LinksetCompound refresh if just changing properties.
Diffstat (limited to 'OpenSim/Region/Physics/BulletSPlugin/BSScene.cs')
-rw-r--r--OpenSim/Region/Physics/BulletSPlugin/BSScene.cs24
1 files changed, 22 insertions, 2 deletions
diff --git a/OpenSim/Region/Physics/BulletSPlugin/BSScene.cs b/OpenSim/Region/Physics/BulletSPlugin/BSScene.cs
index 13aa860..de35359 100644
--- a/OpenSim/Region/Physics/BulletSPlugin/BSScene.cs
+++ b/OpenSim/Region/Physics/BulletSPlugin/BSScene.cs
@@ -116,6 +116,10 @@ public sealed class BSScene : PhysicsScene, IPhysicsParameters
116 // True if initialized and ready to do simulation steps 116 // True if initialized and ready to do simulation steps
117 private bool m_initialized = false; 117 private bool m_initialized = false;
118 118
119 // Flag which is true when processing taints.
120 // Not guaranteed to be correct all the time (don't depend on this) but good for debugging.
121 public bool InTaintTime { get; private set; }
122
119 // Pinned memory used to pass step information between managed and unmanaged 123 // Pinned memory used to pass step information between managed and unmanaged
120 private int m_maxCollisionsPerFrame; 124 private int m_maxCollisionsPerFrame;
121 private CollisionDesc[] m_collisionArray; 125 private CollisionDesc[] m_collisionArray;
@@ -270,6 +274,9 @@ public sealed class BSScene : PhysicsScene, IPhysicsParameters
270 TerrainManager = new BSTerrainManager(this); 274 TerrainManager = new BSTerrainManager(this);
271 TerrainManager.CreateInitialGroundPlaneAndTerrain(); 275 TerrainManager.CreateInitialGroundPlaneAndTerrain();
272 276
277 m_log.WarnFormat("{0} Linksets implemented with {1}", LogHeader, (BSLinkset.LinksetImplementation)Params.linksetImplementation);
278
279 InTaintTime = false;
273 m_initialized = true; 280 m_initialized = true;
274 } 281 }
275 282
@@ -707,8 +714,10 @@ public sealed class BSScene : PhysicsScene, IPhysicsParameters
707 // here just before the physics engine is called to step the simulation. 714 // here just before the physics engine is called to step the simulation.
708 public void ProcessTaints() 715 public void ProcessTaints()
709 { 716 {
717 InTaintTime = true;
710 ProcessRegularTaints(); 718 ProcessRegularTaints();
711 ProcessPostTaintTaints(); 719 ProcessPostTaintTaints();
720 InTaintTime = false;
712 } 721 }
713 722
714 private void ProcessRegularTaints() 723 private void ProcessRegularTaints()
@@ -851,6 +860,17 @@ public sealed class BSScene : PhysicsScene, IPhysicsParameters
851 } 860 }
852 } 861 }
853 862
863 public bool AssertInTaintTime(string whereFrom)
864 {
865 if (!InTaintTime)
866 {
867 DetailLog("{0},BSScene.AssertInTaintTime,NOT IN TAINT TIME,Region={1},Where={2}", DetailLogZero, RegionName, whereFrom);
868 m_log.ErrorFormat("{0} NOT IN TAINT TIME!! Region={1}, Where={2}", LogHeader, RegionName, whereFrom);
869 Util.PrintCallStack();
870 }
871 return InTaintTime;
872 }
873
854 #endregion // Taints 874 #endregion // Taints
855 875
856 #region Vehicles 876 #region Vehicles
@@ -1214,8 +1234,8 @@ public sealed class BSScene : PhysicsScene, IPhysicsParameters
1214 (s) => { return s.m_params[0].numberOfSolverIterations; }, 1234 (s) => { return s.m_params[0].numberOfSolverIterations; },
1215 (s,p,l,v) => { s.m_params[0].numberOfSolverIterations = v; } ), 1235 (s,p,l,v) => { s.m_params[0].numberOfSolverIterations = v; } ),
1216 1236
1217 new ParameterDefn("LinksetImplementation", "Type of linkset implementation (0=Constraint, 1=Compound)", 1237 new ParameterDefn("LinksetImplementation", "Type of linkset implementation (0=Constraint, 1=Compound, 2=Manual)",
1218 (float)BSLinkset.LinksetImplementation.Constraint, 1238 (float)BSLinkset.LinksetImplementation.Compound,
1219 (s,cf,p,v) => { s.m_params[0].linksetImplementation = cf.GetFloat(p,v); }, 1239 (s,cf,p,v) => { s.m_params[0].linksetImplementation = cf.GetFloat(p,v); },
1220 (s) => { return s.m_params[0].linksetImplementation; }, 1240 (s) => { return s.m_params[0].linksetImplementation; },
1221 (s,p,l,v) => { s.m_params[0].linksetImplementation = v; } ), 1241 (s,p,l,v) => { s.m_params[0].linksetImplementation = v; } ),