BulletSim: Add non-static BSShape.GetReference for getting another reference
to an existing shape instance. BSShapeNative rebuilds shape for all references. BSShapeCompound returns another reference copy if the compound shape already exists (for linksets).user_profiles
parent
15a3f80e2e
commit
d322625f90
|
@ -47,26 +47,31 @@ public abstract class BSShape
|
||||||
|
|
||||||
public BSShape()
|
public BSShape()
|
||||||
{
|
{
|
||||||
referenceCount = 0;
|
referenceCount = 1;
|
||||||
lastReferenced = DateTime.Now;
|
lastReferenced = DateTime.Now;
|
||||||
physShapeInfo = new BulletShape();
|
physShapeInfo = new BulletShape();
|
||||||
}
|
}
|
||||||
public BSShape(BulletShape pShape)
|
public BSShape(BulletShape pShape)
|
||||||
{
|
{
|
||||||
referenceCount = 0;
|
referenceCount = 1;
|
||||||
lastReferenced = DateTime.Now;
|
lastReferenced = DateTime.Now;
|
||||||
physShapeInfo = pShape;
|
physShapeInfo = pShape;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Get another reference to this shape.
|
||||||
|
public abstract BSShape GetReference(BSScene pPhysicsScene, BSPhysObject pPrim);
|
||||||
|
|
||||||
// Called when this shape is being used again.
|
// Called when this shape is being used again.
|
||||||
public virtual void IncrementReference()
|
// Used internally. External callers should call instance.GetReference() to properly copy/reference
|
||||||
|
// the shape.
|
||||||
|
protected virtual void IncrementReference()
|
||||||
{
|
{
|
||||||
referenceCount++;
|
referenceCount++;
|
||||||
lastReferenced = DateTime.Now;
|
lastReferenced = DateTime.Now;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Called when this shape is being used again.
|
// Called when this shape is being used again.
|
||||||
public virtual void DecrementReference()
|
protected virtual void DecrementReference()
|
||||||
{
|
{
|
||||||
referenceCount--;
|
referenceCount--;
|
||||||
lastReferenced = DateTime.Now;
|
lastReferenced = DateTime.Now;
|
||||||
|
@ -99,12 +104,19 @@ public abstract class BSShape
|
||||||
// Returns a string for debugging that uniquily identifies the memory used by this instance
|
// Returns a string for debugging that uniquily identifies the memory used by this instance
|
||||||
public virtual string AddrString
|
public virtual string AddrString
|
||||||
{
|
{
|
||||||
get { return "unknown"; }
|
get
|
||||||
|
{
|
||||||
|
if (physShapeInfo != null)
|
||||||
|
return physShapeInfo.AddrString;
|
||||||
|
return "unknown";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public override string ToString()
|
public override string ToString()
|
||||||
{
|
{
|
||||||
StringBuilder buff = new StringBuilder();
|
StringBuilder buff = new StringBuilder();
|
||||||
|
buff.Append("<t=");
|
||||||
|
buff.Append(ShapeType.ToString());
|
||||||
buff.Append("<p=");
|
buff.Append("<p=");
|
||||||
buff.Append(AddrString);
|
buff.Append(AddrString);
|
||||||
buff.Append(",c=");
|
buff.Append(",c=");
|
||||||
|
@ -113,6 +125,7 @@ public abstract class BSShape
|
||||||
return buff.ToString();
|
return buff.ToString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#region Common shape routines
|
||||||
// Create a hash of all the shape parameters to be used as a key for this particular shape.
|
// Create a hash of all the shape parameters to be used as a key for this particular shape.
|
||||||
public static System.UInt64 ComputeShapeKey(OMV.Vector3 size, PrimitiveBaseShape pbs, out float retLod)
|
public static System.UInt64 ComputeShapeKey(OMV.Vector3 size, PrimitiveBaseShape pbs, out float retLod)
|
||||||
{
|
{
|
||||||
|
@ -225,6 +238,7 @@ public abstract class BSShape
|
||||||
return fillShape.physShapeInfo;
|
return fillShape.physShapeInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endregion // Common shape routines
|
||||||
}
|
}
|
||||||
|
|
||||||
// ============================================================================================================
|
// ============================================================================================================
|
||||||
|
@ -234,6 +248,7 @@ public class BSShapeNull : BSShape
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
public static BSShape GetReference() { return new BSShapeNull(); }
|
public static BSShape GetReference() { return new BSShapeNull(); }
|
||||||
|
public override BSShape GetReference(BSScene pPhysicsScene, BSPhysObject pPrim) { return new BSShapeNull(); }
|
||||||
public override void Dereference(BSScene physicsScene) { /* The magic of garbage collection will make this go away */ }
|
public override void Dereference(BSScene physicsScene) { /* The magic of garbage collection will make this go away */ }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -252,10 +267,19 @@ public class BSShapeNative : BSShape
|
||||||
return new BSShapeNative(CreatePhysicalNativeShape(physicsScene, prim, shapeType, shapeKey));
|
return new BSShapeNative(CreatePhysicalNativeShape(physicsScene, prim, shapeType, shapeKey));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override BSShape GetReference(BSScene pPhysicsScene, BSPhysObject pPrim)
|
||||||
|
{
|
||||||
|
// Native shapes are not shared so we return a new shape.
|
||||||
|
return new BSShapeNative(CreatePhysicalNativeShape(pPhysicsScene, pPrim,
|
||||||
|
physShapeInfo.shapeType, (FixedShapeKey)physShapeInfo.shapeKey) );
|
||||||
|
}
|
||||||
|
|
||||||
// Make this reference to the physical shape go away since native shapes are not shared.
|
// Make this reference to the physical shape go away since native shapes are not shared.
|
||||||
public override void Dereference(BSScene physicsScene)
|
public override void Dereference(BSScene physicsScene)
|
||||||
{
|
{
|
||||||
// Native shapes are not tracked and are released immediately
|
// Native shapes are not tracked and are released immediately
|
||||||
|
lock (physShapeInfo)
|
||||||
|
{
|
||||||
if (physShapeInfo.HasPhysicalShape)
|
if (physShapeInfo.HasPhysicalShape)
|
||||||
{
|
{
|
||||||
physicsScene.DetailLog("{0},BSShapeNative.DereferenceShape,deleteNativeShape,shape={1}", BSScene.DetailLogZero, this);
|
physicsScene.DetailLog("{0},BSShapeNative.DereferenceShape,deleteNativeShape,shape={1}", BSScene.DetailLogZero, this);
|
||||||
|
@ -264,6 +288,7 @@ public class BSShapeNative : BSShape
|
||||||
physShapeInfo.Clear();
|
physShapeInfo.Clear();
|
||||||
// Garbage collection will free up this instance.
|
// Garbage collection will free up this instance.
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private static BulletShape CreatePhysicalNativeShape(BSScene physicsScene, BSPhysObject prim,
|
private static BulletShape CreatePhysicalNativeShape(BSScene physicsScene, BSPhysObject prim,
|
||||||
BSPhysicsShapeType shapeType, FixedShapeKey shapeKey)
|
BSPhysicsShapeType shapeType, FixedShapeKey shapeKey)
|
||||||
|
@ -345,6 +370,12 @@ public class BSShapeMesh : BSShape
|
||||||
}
|
}
|
||||||
return retMesh;
|
return retMesh;
|
||||||
}
|
}
|
||||||
|
public override BSShape GetReference(BSScene pPhysicsScene, BSPhysObject pPrim)
|
||||||
|
{
|
||||||
|
// Another reference to this shape is just counted.
|
||||||
|
IncrementReference();
|
||||||
|
return this;
|
||||||
|
}
|
||||||
public override void Dereference(BSScene physicsScene)
|
public override void Dereference(BSScene physicsScene)
|
||||||
{
|
{
|
||||||
lock (Meshes)
|
lock (Meshes)
|
||||||
|
@ -487,8 +518,19 @@ public class BSShapeHull : BSShape
|
||||||
}
|
}
|
||||||
return retHull;
|
return retHull;
|
||||||
}
|
}
|
||||||
|
public override BSShape GetReference(BSScene pPhysicsScene, BSPhysObject pPrim)
|
||||||
|
{
|
||||||
|
// Another reference to this shape is just counted.
|
||||||
|
IncrementReference();
|
||||||
|
return this;
|
||||||
|
}
|
||||||
public override void Dereference(BSScene physicsScene)
|
public override void Dereference(BSScene physicsScene)
|
||||||
{
|
{
|
||||||
|
lock (Hulls)
|
||||||
|
{
|
||||||
|
this.DecrementReference();
|
||||||
|
// TODO: schedule aging and destruction of unused meshes.
|
||||||
|
}
|
||||||
}
|
}
|
||||||
List<ConvexResult> m_hulls;
|
List<ConvexResult> m_hulls;
|
||||||
private BulletShape CreatePhysicalHull(BSScene physicsScene, BSPhysObject prim, System.UInt64 newHullKey,
|
private BulletShape CreatePhysicalHull(BSScene physicsScene, BSPhysObject prim, System.UInt64 newHullKey,
|
||||||
|
@ -520,7 +562,7 @@ public class BSShapeHull : BSShape
|
||||||
physicsScene.DetailLog("{0},BSShapeHull.CreatePhysicalHull,hullFromMesh,hasBody={1}", prim.LocalID, newShape.HasPhysicalShape);
|
physicsScene.DetailLog("{0},BSShapeHull.CreatePhysicalHull,hullFromMesh,hasBody={1}", prim.LocalID, newShape.HasPhysicalShape);
|
||||||
}
|
}
|
||||||
// Now done with the mesh shape.
|
// Now done with the mesh shape.
|
||||||
meshShape.DecrementReference();
|
meshShape.Dereference(physicsScene);
|
||||||
physicsScene.DetailLog("{0},BSShapeHull.CreatePhysicalHull,shouldUseBulletHACD,exit,hasBody={1}", prim.LocalID, newShape.HasPhysicalShape);
|
physicsScene.DetailLog("{0},BSShapeHull.CreatePhysicalHull,shouldUseBulletHACD,exit,hasBody={1}", prim.LocalID, newShape.HasPhysicalShape);
|
||||||
}
|
}
|
||||||
if (!newShape.HasPhysicalShape)
|
if (!newShape.HasPhysicalShape)
|
||||||
|
@ -671,13 +713,26 @@ public class BSShapeCompound : BSShape
|
||||||
public BSShapeCompound(BulletShape pShape) : base(pShape)
|
public BSShapeCompound(BulletShape pShape) : base(pShape)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
public static BSShape GetReference(BSScene physicsScene, BSPhysObject prim)
|
public static BSShape GetReference(BSScene physicsScene)
|
||||||
{
|
{
|
||||||
// Compound shapes are not shared so a new one is created every time.
|
// Base compound shapes are not shared so this returns a raw shape.
|
||||||
return new BSShapeCompound(CreatePhysicalCompoundShape(physicsScene, prim));
|
// A built compound shape can be reused in linksets.
|
||||||
|
return new BSShapeCompound(CreatePhysicalCompoundShape(physicsScene));
|
||||||
|
}
|
||||||
|
public override BSShape GetReference(BSScene physicsScene, BSPhysObject prim)
|
||||||
|
{
|
||||||
|
// Calling this reference means we want another handle to an existing compound shape
|
||||||
|
// (usually linksets) so return this copy.
|
||||||
|
IncrementReference();
|
||||||
|
return this;
|
||||||
}
|
}
|
||||||
// Dereferencing a compound shape releases the hold on all the child shapes.
|
// Dereferencing a compound shape releases the hold on all the child shapes.
|
||||||
public override void Dereference(BSScene physicsScene)
|
public override void Dereference(BSScene physicsScene)
|
||||||
|
{
|
||||||
|
lock (physShapeInfo)
|
||||||
|
{
|
||||||
|
Dereference(physicsScene);
|
||||||
|
if (referenceCount <= 0)
|
||||||
{
|
{
|
||||||
if (!physicsScene.PE.IsCompound(physShapeInfo))
|
if (!physicsScene.PE.IsCompound(physShapeInfo))
|
||||||
{
|
{
|
||||||
|
@ -701,7 +756,9 @@ public class BSShapeCompound : BSShape
|
||||||
}
|
}
|
||||||
physicsScene.PE.DeleteCollisionShape(physicsScene.World, physShapeInfo);
|
physicsScene.PE.DeleteCollisionShape(physicsScene.World, physShapeInfo);
|
||||||
}
|
}
|
||||||
private static BulletShape CreatePhysicalCompoundShape(BSScene physicsScene, BSPhysObject prim)
|
}
|
||||||
|
}
|
||||||
|
private static BulletShape CreatePhysicalCompoundShape(BSScene physicsScene)
|
||||||
{
|
{
|
||||||
BulletShape cShape = physicsScene.PE.CreateCompoundShape(physicsScene.World, false);
|
BulletShape cShape = physicsScene.PE.CreateCompoundShape(physicsScene.World, false);
|
||||||
return cShape;
|
return cShape;
|
||||||
|
@ -754,6 +811,10 @@ public class BSShapeAvatar : BSShape
|
||||||
{
|
{
|
||||||
return new BSShapeNull();
|
return new BSShapeNull();
|
||||||
}
|
}
|
||||||
|
public override BSShape GetReference(BSScene pPhysicsScene, BSPhysObject pPrim)
|
||||||
|
{
|
||||||
|
return new BSShapeNull();
|
||||||
|
}
|
||||||
public override void Dereference(BSScene physicsScene) { }
|
public override void Dereference(BSScene physicsScene) { }
|
||||||
|
|
||||||
// From the front:
|
// From the front:
|
||||||
|
|
|
@ -1,3 +1,12 @@
|
||||||
|
PROBLEMS TO LOOK INTO
|
||||||
|
=================================================
|
||||||
|
Nebadon vehicle ride, get up, ride again. Second time vehicle does not act correctly.
|
||||||
|
Have to rez new vehicle and delete the old to fix situation.
|
||||||
|
Hitting RESET on Nebadon's vehicle while riding causes vehicle to get into odd
|
||||||
|
position state where it will not settle onto ground properly, etc
|
||||||
|
Two of Nebadon vehicles in a sim max the CPU. This is new.
|
||||||
|
A sitting, active vehicle bobs up and down a small amount.
|
||||||
|
|
||||||
CURRENT PRIORITIES
|
CURRENT PRIORITIES
|
||||||
=================================================
|
=================================================
|
||||||
Use the HACD convex hull routine in Bullet rather than the C# version.
|
Use the HACD convex hull routine in Bullet rather than the C# version.
|
||||||
|
|
Loading…
Reference in New Issue