aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rwxr-xr-xOpenSim/Region/Physics/BulletSPlugin/BSConstraint6Dof.cs9
-rwxr-xr-xOpenSim/Region/Physics/BulletSPlugin/BSLinkset.cs2
-rwxr-xr-xOpenSim/Region/Physics/BulletSPlugin/BSLinksetConstraints.cs81
3 files changed, 77 insertions, 15 deletions
diff --git a/OpenSim/Region/Physics/BulletSPlugin/BSConstraint6Dof.cs b/OpenSim/Region/Physics/BulletSPlugin/BSConstraint6Dof.cs
index d0949f5..5008ff7 100755
--- a/OpenSim/Region/Physics/BulletSPlugin/BSConstraint6Dof.cs
+++ b/OpenSim/Region/Physics/BulletSPlugin/BSConstraint6Dof.cs
@@ -32,12 +32,19 @@ using OpenMetaverse;
32namespace OpenSim.Region.Physics.BulletSPlugin 32namespace OpenSim.Region.Physics.BulletSPlugin
33{ 33{
34 34
35public sealed class BSConstraint6Dof : BSConstraint 35public class BSConstraint6Dof : BSConstraint
36{ 36{
37 private static string LogHeader = "[BULLETSIM 6DOF CONSTRAINT]"; 37 private static string LogHeader = "[BULLETSIM 6DOF CONSTRAINT]";
38 38
39 public override ConstraintType Type { get { return ConstraintType.D6_CONSTRAINT_TYPE; } } 39 public override ConstraintType Type { get { return ConstraintType.D6_CONSTRAINT_TYPE; } }
40 40
41 public BSConstraint6Dof(BulletWorld world, BulletBody obj1, BulletBody obj2) :base(world)
42 {
43 m_body1 = obj1;
44 m_body2 = obj2;
45 m_enabled = false;
46 }
47
41 // Create a btGeneric6DofConstraint 48 // Create a btGeneric6DofConstraint
42 public BSConstraint6Dof(BulletWorld world, BulletBody obj1, BulletBody obj2, 49 public BSConstraint6Dof(BulletWorld world, BulletBody obj1, BulletBody obj2,
43 Vector3 frame1, Quaternion frame1rot, 50 Vector3 frame1, Quaternion frame1rot,
diff --git a/OpenSim/Region/Physics/BulletSPlugin/BSLinkset.cs b/OpenSim/Region/Physics/BulletSPlugin/BSLinkset.cs
index a051002..d4b1c1e 100755
--- a/OpenSim/Region/Physics/BulletSPlugin/BSLinkset.cs
+++ b/OpenSim/Region/Physics/BulletSPlugin/BSLinkset.cs
@@ -77,6 +77,8 @@ public abstract class BSLinkset
77 { 77 {
78 member = pMember; 78 member = pMember;
79 } 79 }
80 public virtual void ResetLink() { }
81 public virtual void SetLinkParameters(BSConstraint constrain) { }
80 } 82 }
81 83
82 public LinksetImplementation LinksetImpl { get; protected set; } 84 public LinksetImplementation LinksetImpl { get; protected set; }
diff --git a/OpenSim/Region/Physics/BulletSPlugin/BSLinksetConstraints.cs b/OpenSim/Region/Physics/BulletSPlugin/BSLinksetConstraints.cs
index d4ee27d..f3b70c3 100755
--- a/OpenSim/Region/Physics/BulletSPlugin/BSLinksetConstraints.cs
+++ b/OpenSim/Region/Physics/BulletSPlugin/BSLinksetConstraints.cs
@@ -51,16 +51,26 @@ public sealed class BSLinksetConstraints : BSLinkset
51 public float cfm; 51 public float cfm;
52 public float erp; 52 public float erp;
53 public float solverIterations; 53 public float solverIterations;
54 //
55 public OMV.Vector3 frameInAloc;
56 public OMV.Quaternion frameInArot;
57 public OMV.Vector3 frameInBloc;
58 public OMV.Quaternion frameInBrot;
59 // Spring
60 public float springDamping;
61 public float springStiffness;
62
63
54 64
55 public BSLinkInfoConstraint(BSPrimLinkable pMember) 65 public BSLinkInfoConstraint(BSPrimLinkable pMember)
56 : base(pMember) 66 : base(pMember)
57 { 67 {
58 constraint = null; 68 constraint = null;
59 ResetToFixedConstraint(); 69 ResetLink();
60 } 70 }
61 71
62 // Set all the parameters for this constraint to a fixed, non-movable constraint. 72 // Set all the parameters for this constraint to a fixed, non-movable constraint.
63 public void ResetToFixedConstraint() 73 public override void ResetLink()
64 { 74 {
65 constraintType = ConstraintType.D6_CONSTRAINT_TYPE; 75 constraintType = ConstraintType.D6_CONSTRAINT_TYPE;
66 linearLimitLow = OMV.Vector3.Zero; 76 linearLimitLow = OMV.Vector3.Zero;
@@ -74,10 +84,16 @@ public sealed class BSLinksetConstraints : BSLinkset
74 cfm = BSParam.LinkConstraintCFM; 84 cfm = BSParam.LinkConstraintCFM;
75 erp = BSParam.LinkConstraintERP; 85 erp = BSParam.LinkConstraintERP;
76 solverIterations = BSParam.LinkConstraintSolverIterations; 86 solverIterations = BSParam.LinkConstraintSolverIterations;
87 frameInAloc = OMV.Vector3.Zero;
88 frameInArot = OMV.Quaternion.Identity;
89 frameInBloc = OMV.Vector3.Zero;
90 frameInBrot = OMV.Quaternion.Identity;
91 springDamping = -1f;
92 springStiffness = -1f;
77 } 93 }
78 94
79 // Given a constraint, apply the current constraint parameters to same. 95 // Given a constraint, apply the current constraint parameters to same.
80 public void SetConstraintParameters(BSConstraint constrain) 96 public override void SetLinkParameters(BSConstraint constrain)
81 { 97 {
82 switch (constraintType) 98 switch (constraintType)
83 { 99 {
@@ -85,6 +101,7 @@ public sealed class BSLinksetConstraints : BSLinkset
85 BSConstraint6Dof constrain6dof = constrain as BSConstraint6Dof; 101 BSConstraint6Dof constrain6dof = constrain as BSConstraint6Dof;
86 if (constrain6dof != null) 102 if (constrain6dof != null)
87 { 103 {
104 // NOTE: D6_SPRING_CONSTRAINT_TYPE should be updated if you change any of this code.
88 // zero linear and angular limits makes the objects unable to move in relation to each other 105 // zero linear and angular limits makes the objects unable to move in relation to each other
89 constrain6dof.SetLinearLimits(linearLimitLow, linearLimitHigh); 106 constrain6dof.SetLinearLimits(linearLimitLow, linearLimitHigh);
90 constrain6dof.SetAngularLimits(angularLimitLow, angularLimitHigh); 107 constrain6dof.SetAngularLimits(angularLimitLow, angularLimitHigh);
@@ -99,6 +116,31 @@ public sealed class BSLinksetConstraints : BSLinkset
99 } 116 }
100 } 117 }
101 break; 118 break;
119 case ConstraintType.D6_SPRING_CONSTRAINT_TYPE:
120 BSConstraintSpring constrainSpring = constrain as BSConstraintSpring;
121 if (constrainSpring != null)
122 {
123 // zero linear and angular limits makes the objects unable to move in relation to each other
124 constrainSpring.SetLinearLimits(linearLimitLow, linearLimitHigh);
125 constrainSpring.SetAngularLimits(angularLimitLow, angularLimitHigh);
126
127 // tweek the constraint to increase stability
128 constrainSpring.UseFrameOffset(useFrameOffset);
129 constrainSpring.TranslationalLimitMotor(enableTransMotor, transMotorMaxVel, transMotorMaxForce);
130 constrainSpring.SetCFMAndERP(cfm, erp);
131 if (solverIterations != 0f)
132 {
133 constrainSpring.SetSolverIterations(solverIterations);
134 }
135 for (int ii = 0; ii < 6; ii++)
136 {
137 if (springDamping != -1)
138 constrainSpring.SetDamping(ii, springDamping);
139 if (springStiffness != -1)
140 constrainSpring.SetStiffness(ii, springStiffness);
141 }
142 }
143 break;
102 default: 144 default:
103 break; 145 break;
104 } 146 }
@@ -262,8 +304,8 @@ public sealed class BSLinksetConstraints : BSLinkset
262 // Create a static constraint between the two passed objects 304 // Create a static constraint between the two passed objects
263 private BSConstraint BuildConstraint(BSPrimLinkable rootPrim, BSLinkInfo li) 305 private BSConstraint BuildConstraint(BSPrimLinkable rootPrim, BSLinkInfo li)
264 { 306 {
265 BSLinkInfoConstraint liConstraint = li as BSLinkInfoConstraint; 307 BSLinkInfoConstraint linkInfo = li as BSLinkInfoConstraint;
266 if (liConstraint == null) 308 if (linkInfo == null)
267 return null; 309 return null;
268 310
269 // Zero motion for children so they don't interpolate 311 // Zero motion for children so they don't interpolate
@@ -271,27 +313,25 @@ public sealed class BSLinksetConstraints : BSLinkset
271 313
272 BSConstraint constrain = null; 314 BSConstraint constrain = null;
273 315
274 switch (liConstraint.constraintType) 316 switch (linkInfo.constraintType)
275 { 317 {
276 case ConstraintType.D6_CONSTRAINT_TYPE: 318 case ConstraintType.D6_CONSTRAINT_TYPE:
277 // Relative position normalized to the root prim 319 // Relative position normalized to the root prim
278 // Essentually a vector pointing from center of rootPrim to center of li.member 320 // Essentually a vector pointing from center of rootPrim to center of li.member
279 OMV.Vector3 childRelativePosition = liConstraint.member.Position - rootPrim.Position; 321 OMV.Vector3 childRelativePosition = linkInfo.member.Position - rootPrim.Position;
280 322
281 // real world coordinate of midpoint between the two objects 323 // real world coordinate of midpoint between the two objects
282 OMV.Vector3 midPoint = rootPrim.Position + (childRelativePosition / 2); 324 OMV.Vector3 midPoint = rootPrim.Position + (childRelativePosition / 2);
283 325
284 DetailLog("{0},BSLinksetConstraint.BuildConstraint,taint,root={1},rBody={2},child={3},cBody={4},rLoc={5},cLoc={6},midLoc={7}", 326 DetailLog("{0},BSLinksetConstraint.BuildConstraint,6Dof,rBody={1},cBody={2},rLoc={3},cLoc={4},midLoc={7}",
285 rootPrim.LocalID, 327 rootPrim.LocalID, rootPrim.PhysBody, linkInfo.member.PhysBody,
286 rootPrim.LocalID, rootPrim.PhysBody.AddrString, 328 rootPrim.Position, linkInfo.member.Position, midPoint);
287 liConstraint.member.LocalID, liConstraint.member.PhysBody.AddrString,
288 rootPrim.Position, liConstraint.member.Position, midPoint);
289 329
290 // create a constraint that allows no freedom of movement between the two objects 330 // create a constraint that allows no freedom of movement between the two objects
291 // http://bulletphysics.org/Bullet/phpBB3/viewtopic.php?t=4818 331 // http://bulletphysics.org/Bullet/phpBB3/viewtopic.php?t=4818
292 332
293 constrain = new BSConstraint6Dof( 333 constrain = new BSConstraint6Dof(
294 m_physicsScene.World, rootPrim.PhysBody, liConstraint.member.PhysBody, midPoint, true, true ); 334 m_physicsScene.World, rootPrim.PhysBody, linkInfo.member.PhysBody, midPoint, true, true );
295 335
296 /* NOTE: below is an attempt to build constraint with full frame computation, etc. 336 /* NOTE: below is an attempt to build constraint with full frame computation, etc.
297 * Using the midpoint is easier since it lets the Bullet code manipulate the transforms 337 * Using the midpoint is easier since it lets the Bullet code manipulate the transforms
@@ -320,11 +360,23 @@ public sealed class BSLinksetConstraints : BSLinkset
320 */ 360 */
321 361
322 break; 362 break;
363 case ConstraintType.D6_SPRING_CONSTRAINT_TYPE:
364 constrain = new BSConstraintSpring(m_physicsScene.World, rootPrim.PhysBody, linkInfo.member.PhysBody,
365 linkInfo.frameInAloc, linkInfo.frameInArot, linkInfo.frameInBloc, linkInfo.frameInBrot,
366 true /*useLinearReferenceFrameA*/,
367 true /*disableCollisionsBetweenLinkedBodies*/);
368 DetailLog("{0},BSLinksetConstraint.BuildConstraint,spring,root={1},rBody={2},child={3},cBody={4},rLoc={5},cLoc={6},midLoc={7}",
369 rootPrim.LocalID,
370 rootPrim.LocalID, rootPrim.PhysBody.AddrString,
371 linkInfo.member.LocalID, linkInfo.member.PhysBody.AddrString,
372 rootPrim.Position, linkInfo.member.Position);
373
374 break;
323 default: 375 default:
324 break; 376 break;
325 } 377 }
326 378
327 liConstraint.SetConstraintParameters(constrain); 379 linkInfo.SetLinkParameters(constrain);
328 380
329 m_physicsScene.Constraints.AddConstraint(constrain); 381 m_physicsScene.Constraints.AddConstraint(constrain);
330 382
@@ -401,6 +453,7 @@ public sealed class BSLinksetConstraints : BSLinkset
401 // If constraint doesn't exist yet, create it. 453 // If constraint doesn't exist yet, create it.
402 constrain = BuildConstraint(LinksetRoot, li); 454 constrain = BuildConstraint(LinksetRoot, li);
403 } 455 }
456 li.SetLinkParameters(constrain);
404 constrain.RecomputeConstraintVariables(linksetMass); 457 constrain.RecomputeConstraintVariables(linksetMass);
405 458
406 // PhysicsScene.PE.DumpConstraint(PhysicsScene.World, constrain.Constraint); // DEBUG DEBUG 459 // PhysicsScene.PE.DumpConstraint(PhysicsScene.World, constrain.Constraint); // DEBUG DEBUG