aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/Physics/BulletSPlugin/BSLinksetCompound.cs
diff options
context:
space:
mode:
Diffstat (limited to '')
-rwxr-xr-xOpenSim/Region/Physics/BulletSPlugin/BSLinksetCompound.cs48
1 files changed, 34 insertions, 14 deletions
diff --git a/OpenSim/Region/Physics/BulletSPlugin/BSLinksetCompound.cs b/OpenSim/Region/Physics/BulletSPlugin/BSLinksetCompound.cs
index 92f6ee2..6c6ca09 100755
--- a/OpenSim/Region/Physics/BulletSPlugin/BSLinksetCompound.cs
+++ b/OpenSim/Region/Physics/BulletSPlugin/BSLinksetCompound.cs
@@ -219,28 +219,45 @@ public sealed class BSLinksetCompound : BSLinkset
219 { 219 {
220 // Gather the child info. It might not be there if the linkset is in transition. 220 // Gather the child info. It might not be there if the linkset is in transition.
221 BSLinksetCompoundInfo lsi = updated.LinksetInfo as BSLinksetCompoundInfo; 221 BSLinksetCompoundInfo lsi = updated.LinksetInfo as BSLinksetCompoundInfo;
222
223 // The linksetInfo will need to be rebuilt either here or when the linkset is rebuilt
222 if (LinksetRoot.PhysShape.HasPhysicalShape && lsi != null) 224 if (LinksetRoot.PhysShape.HasPhysicalShape && lsi != null)
223 { 225 {
224 if (PhysicsScene.PE.IsCompound(LinksetRoot.PhysShape)) 226 if (PhysicsScene.PE.IsCompound(LinksetRoot.PhysShape))
225 { 227 {
226 BulletShape linksetChildShape = PhysicsScene.PE.GetChildShapeFromCompoundShapeIndex(LinksetRoot.PhysShape, lsi.Index); 228 int numLinksetChildren = PhysicsScene.PE.GetNumberOfCompoundChildren(LinksetRoot.PhysShape);
227 if (linksetChildShape.HasPhysicalShape) 229 if (lsi.Index < numLinksetChildren)
228 { 230 {
229 // Compute the offset from the center-of-gravity 231 // It is possible that the linkset is still under construction and the child is not yet
230 BSLinksetCompoundInfo newLsi = new BSLinksetCompoundInfo(lsi.Index, LinksetRoot, updated, LinksetRoot.PositionDisplacement); 232 // inserted into the compound shape. A rebuild of the linkset in a pre-step action will
231 PhysicsScene.PE.UpdateChildTransform(LinksetRoot.PhysShape, lsi.Index, 233 // build the whole thing with the new position or rotation.
232 newLsi.OffsetFromCenterOfMass, 234 // This must be checked for because Bullet references the child array but does no validity
233 newLsi.OffsetRot, 235 // checking of the child index passed.
234 true /* shouldRecalculateLocalAabb */); 236 BulletShape linksetChildShape = PhysicsScene.PE.GetChildShapeFromCompoundShapeIndex(LinksetRoot.PhysShape, lsi.Index);
235 DetailLog("{0},BSLinksetCompound.UpdateProperties,changeChildPosRot,whichUpdated={1},newLsi={2}", 237 if (linksetChildShape.HasPhysicalShape)
236 updated.LocalID, whichUpdated, newLsi); 238 {
237 updated.LinksetInfo = newLsi; 239 // Compute the offset from the center-of-gravity
238 updatedChild = true; 240 BSLinksetCompoundInfo newLsi = new BSLinksetCompoundInfo(lsi.Index, LinksetRoot, updated, LinksetRoot.PositionDisplacement);
241 PhysicsScene.PE.UpdateChildTransform(LinksetRoot.PhysShape, lsi.Index,
242 newLsi.OffsetFromCenterOfMass,
243 newLsi.OffsetRot,
244 true /* shouldRecalculateLocalAabb */);
245 updated.LinksetInfo = newLsi;
246 updatedChild = true;
247 DetailLog("{0},BSLinksetCompound.UpdateProperties,changeChildPosRot,whichUpdated={1},newLsi={2}",
248 updated.LocalID, whichUpdated, newLsi);
249 }
250 else // DEBUG DEBUG
251 { // DEBUG DEBUG
252 DetailLog("{0},BSLinksetCompound.UpdateProperties,couldNotUpdateChild,noChildShape,shape={1}",
253 updated.LocalID, linksetChildShape);
254 } // DEBUG DEBUG
239 } 255 }
240 else // DEBUG DEBUG 256 else // DEBUG DEBUG
241 { // DEBUG DEBUG 257 { // DEBUG DEBUG
242 DetailLog("{0},BSLinksetCompound.UpdateProperties,couldNotUpdateChild,noChildShape,shape={1}", 258 // the child is not yet in the compound shape. This is non-fatal.
243 updated.LocalID, linksetChildShape); 259 DetailLog("{0},BSLinksetCompound.UpdateProperties,couldNotUpdateChild,childNotInCompoundShape,numChildren={1},index={2}",
260 updated.LocalID, numLinksetChildren, lsi.Index);
244 } // DEBUG DEBUG 261 } // DEBUG DEBUG
245 } 262 }
246 else // DEBUG DEBUG 263 else // DEBUG DEBUG
@@ -256,6 +273,9 @@ public sealed class BSLinksetCompound : BSLinkset
256 if (!updatedChild) 273 if (!updatedChild)
257 { 274 {
258 // If couldn't do the individual child, the linkset needs a rebuild to incorporate the new child info. 275 // If couldn't do the individual child, the linkset needs a rebuild to incorporate the new child info.
276 // Note that there are several ways through this code that will not update the child that can
277 // occur if the linkset is being rebuilt. In this case, scheduling a rebuild is a NOOP since
278 // there will already be a rebuild scheduled.
259 DetailLog("{0},BSLinksetCompound.UpdateProperties,couldNotUpdateChild.schedulingRebuild,whichUpdated={1}", 279 DetailLog("{0},BSLinksetCompound.UpdateProperties,couldNotUpdateChild.schedulingRebuild,whichUpdated={1}",
260 updated.LocalID, whichUpdated); 280 updated.LocalID, whichUpdated);
261 updated.LinksetInfo = null; // setting to 'null' causes relative position to be recomputed. 281 updated.LinksetInfo = null; // setting to 'null' causes relative position to be recomputed.