diff options
author | Robert Adams | 2012-10-17 08:30:10 -0700 |
---|---|---|
committer | Robert Adams | 2012-10-19 10:52:23 -0700 |
commit | e87a179c893ef246dae8338e0f56c3fe20458fbc (patch) | |
tree | 1699e1fc26a47ba000bbd2392df894dc3247f956 /OpenSim/Region/Physics/BulletSPlugin | |
parent | BulletSim: remove code in ShapeCollection that hinted at shape sharing. (diff) | |
download | opensim-SC_OLD-e87a179c893ef246dae8338e0f56c3fe20458fbc.zip opensim-SC_OLD-e87a179c893ef246dae8338e0f56c3fe20458fbc.tar.gz opensim-SC_OLD-e87a179c893ef246dae8338e0f56c3fe20458fbc.tar.bz2 opensim-SC_OLD-e87a179c893ef246dae8338e0f56c3fe20458fbc.tar.xz |
BulletSim: change nonimal physics frame rate to 55 to give same numbers as ODE.
Change character scaling to represent size of capsule (diameter rather than radius)
Modify create capsule call to pass radius and height.
Eliminate errors when calculating shape inertia (should have some type checking).
Diffstat (limited to 'OpenSim/Region/Physics/BulletSPlugin')
6 files changed, 57 insertions, 52 deletions
diff --git a/OpenSim/Region/Physics/BulletSPlugin/BSCharacter.cs b/OpenSim/Region/Physics/BulletSPlugin/BSCharacter.cs index 8e1171a..e7bff6e 100644 --- a/OpenSim/Region/Physics/BulletSPlugin/BSCharacter.cs +++ b/OpenSim/Region/Physics/BulletSPlugin/BSCharacter.cs | |||
@@ -89,13 +89,15 @@ public class BSCharacter : BSPhysObject | |||
89 | _appliedVelocity = OMV.Vector3.Zero; | 89 | _appliedVelocity = OMV.Vector3.Zero; |
90 | _buoyancy = ComputeBuoyancyFromFlying(isFlying); | 90 | _buoyancy = ComputeBuoyancyFromFlying(isFlying); |
91 | _currentFriction = PhysicsScene.Params.avatarStandingFriction; | 91 | _currentFriction = PhysicsScene.Params.avatarStandingFriction; |
92 | _avatarDensity = PhysicsScene.Params.avatarDensity; | ||
92 | 93 | ||
93 | // The dimensions of the avatar capsule are kept in the scale. | 94 | // The dimensions of the avatar capsule are kept in the scale. |
94 | // Physics creates a unit capsule which is scaled by the physics engine. | 95 | // Physics creates a unit capsule which is scaled by the physics engine. |
95 | ComputeAvatarScale(_size); | 96 | ComputeAvatarScale(_size); |
96 | _avatarDensity = PhysicsScene.Params.avatarDensity; | ||
97 | // set _avatarVolume and _mass based on capsule size, _density and Scale | 97 | // set _avatarVolume and _mass based on capsule size, _density and Scale |
98 | ComputeAvatarVolumeAndMass(); | 98 | ComputeAvatarVolumeAndMass(); |
99 | DetailLog("{0},BSCharacter.create,call,size={1},scale={2},density={3},volume={4},mass={5}", | ||
100 | LocalID, _size, Scale, _avatarDensity, _avatarVolume, MassRaw); | ||
99 | 101 | ||
100 | ShapeData shapeData = new ShapeData(); | 102 | ShapeData shapeData = new ShapeData(); |
101 | shapeData.ID = LocalID; | 103 | shapeData.ID = LocalID; |
@@ -103,6 +105,7 @@ public class BSCharacter : BSPhysObject | |||
103 | shapeData.Position = _position; | 105 | shapeData.Position = _position; |
104 | shapeData.Rotation = _orientation; | 106 | shapeData.Rotation = _orientation; |
105 | shapeData.Velocity = _velocity; | 107 | shapeData.Velocity = _velocity; |
108 | shapeData.Size = Scale; | ||
106 | shapeData.Scale = Scale; | 109 | shapeData.Scale = Scale; |
107 | shapeData.Mass = _mass; | 110 | shapeData.Mass = _mass; |
108 | shapeData.Buoyancy = _buoyancy; | 111 | shapeData.Buoyancy = _buoyancy; |
@@ -114,8 +117,9 @@ public class BSCharacter : BSPhysObject | |||
114 | PhysicsScene.TaintedObject("BSCharacter.create", delegate() | 117 | PhysicsScene.TaintedObject("BSCharacter.create", delegate() |
115 | { | 118 | { |
116 | DetailLog("{0},BSCharacter.create,taint", LocalID); | 119 | DetailLog("{0},BSCharacter.create,taint", LocalID); |
117 | PhysicsScene.Shapes.GetBodyAndShape(true, PhysicsScene.World, this, shapeData, null, null, null); | 120 | // New body and shape into BSBody and BSShape |
118 | 121 | PhysicsScene.Shapes.GetBodyAndShape(true, PhysicsScene.World, this, shapeData, null, null, null); | |
122 | |||
119 | SetPhysicalProperties(); | 123 | SetPhysicalProperties(); |
120 | }); | 124 | }); |
121 | return; | 125 | return; |
@@ -138,7 +142,7 @@ public class BSCharacter : BSPhysObject | |||
138 | 142 | ||
139 | ZeroMotion(); | 143 | ZeroMotion(); |
140 | 144 | ||
141 | OMV.Vector3 localInertia = BulletSimAPI.CalculateLocalInertia2(BSShape.ptr, MassRaw); | 145 | OMV.Vector3 localInertia = BulletSimAPI.CalculateLocalInertia2(BSShape.ptr, MassRaw); |
142 | BulletSimAPI.SetMassProps2(BSBody.ptr, MassRaw, localInertia); | 146 | BulletSimAPI.SetMassProps2(BSBody.ptr, MassRaw, localInertia); |
143 | 147 | ||
144 | ForcePosition = _position; | 148 | ForcePosition = _position; |
@@ -151,13 +155,13 @@ public class BSCharacter : BSPhysObject | |||
151 | { | 155 | { |
152 | BulletSimAPI.SetCcdMotionThreshold2(BSBody.ptr, PhysicsScene.Params.ccdMotionThreshold); | 156 | BulletSimAPI.SetCcdMotionThreshold2(BSBody.ptr, PhysicsScene.Params.ccdMotionThreshold); |
153 | BulletSimAPI.SetCcdSweepSphereRadius2(BSBody.ptr, PhysicsScene.Params.ccdSweptSphereRadius); | 157 | BulletSimAPI.SetCcdSweepSphereRadius2(BSBody.ptr, PhysicsScene.Params.ccdSweptSphereRadius); |
154 | } | 158 | } |
155 | 159 | ||
156 | BulletSimAPI.AddToCollisionFlags2(BSBody.ptr, CollisionFlags.CF_CHARACTER_OBJECT); | 160 | BulletSimAPI.AddToCollisionFlags2(BSBody.ptr, CollisionFlags.CF_CHARACTER_OBJECT); |
157 | 161 | ||
158 | BulletSimAPI.AddObjectToWorld2(PhysicsScene.World.ptr, BSBody.ptr); | 162 | BulletSimAPI.AddObjectToWorld2(PhysicsScene.World.ptr, BSBody.ptr); |
159 | 163 | ||
160 | BulletSimAPI.ForceActivationState2(BSBody.ptr, ActivationState.DISABLE_DEACTIVATION); | 164 | BulletSimAPI.ForceActivationState2(BSBody.ptr, ActivationState.ACTIVE_TAG); |
161 | BulletSimAPI.UpdateSingleAabb2(PhysicsScene.World.ptr, BSBody.ptr); | 165 | BulletSimAPI.UpdateSingleAabb2(PhysicsScene.World.ptr, BSBody.ptr); |
162 | 166 | ||
163 | // Do this after the object has been added to the world | 167 | // Do this after the object has been added to the world |
@@ -176,7 +180,7 @@ public class BSCharacter : BSPhysObject | |||
176 | get | 180 | get |
177 | { | 181 | { |
178 | // Avatar capsule size is kept in the scale parameter. | 182 | // Avatar capsule size is kept in the scale parameter. |
179 | return new OMV.Vector3(Scale.X * 2, Scale.Y * 2, Scale.Z); | 183 | return _size; |
180 | } | 184 | } |
181 | 185 | ||
182 | set { | 186 | set { |
@@ -184,11 +188,13 @@ public class BSCharacter : BSPhysObject | |||
184 | _size = value; | 188 | _size = value; |
185 | ComputeAvatarScale(_size); | 189 | ComputeAvatarScale(_size); |
186 | ComputeAvatarVolumeAndMass(); | 190 | ComputeAvatarVolumeAndMass(); |
191 | DetailLog("{0},BSCharacter.setSize,call,scale={1},density={2},volume={3},mass={4}", | ||
192 | LocalID, Scale, _avatarDensity, _avatarVolume, MassRaw); | ||
187 | 193 | ||
188 | PhysicsScene.TaintedObject("BSCharacter.setSize", delegate() | 194 | PhysicsScene.TaintedObject("BSCharacter.setSize", delegate() |
189 | { | 195 | { |
190 | BulletSimAPI.SetLocalScaling2(BSShape.ptr, Scale); | 196 | BulletSimAPI.SetLocalScaling2(BSShape.ptr, Scale); |
191 | OMV.Vector3 localInertia = BulletSimAPI.CalculateLocalInertia2(BSBody.ptr, MassRaw); | 197 | OMV.Vector3 localInertia = BulletSimAPI.CalculateLocalInertia2(BSShape.ptr, MassRaw); |
192 | BulletSimAPI.SetMassProps2(BSBody.ptr, MassRaw, localInertia); | 198 | BulletSimAPI.SetMassProps2(BSBody.ptr, MassRaw, localInertia); |
193 | }); | 199 | }); |
194 | 200 | ||
@@ -578,13 +584,13 @@ public class BSCharacter : BSPhysObject | |||
578 | private void ComputeAvatarScale(OMV.Vector3 size) | 584 | private void ComputeAvatarScale(OMV.Vector3 size) |
579 | { | 585 | { |
580 | OMV.Vector3 newScale = OMV.Vector3.Zero; | 586 | OMV.Vector3 newScale = OMV.Vector3.Zero; |
581 | newScale.X = PhysicsScene.Params.avatarCapsuleRadius; | 587 | // Scale wants the diameter so mult radius by two |
582 | newScale.Y = PhysicsScene.Params.avatarCapsuleRadius; | 588 | newScale.X = PhysicsScene.Params.avatarCapsuleRadius * 2f; |
589 | newScale.Y = PhysicsScene.Params.avatarCapsuleRadius * 2f; | ||
583 | 590 | ||
584 | // The 1.15 came from ODE but it seems to cause the avatar to float off the ground | 591 | // From the total height, add the capsule half spheres that are at each end |
585 | // Scale.Z = (_size.Z * 1.15f) - (Scale.X + Scale.Y); | 592 | // newScale.Z = (size.Z) - Math.Min(newScale.X, newScale.Y); |
586 | // From the total height, remove the capsule half spheres that are at each end | 593 | newScale.Z = (size.Z * 2f); |
587 | newScale.Z = (size.Z) - (Math.Min(newScale.X, newScale.Y) * 2f); | ||
588 | Scale = newScale; | 594 | Scale = newScale; |
589 | } | 595 | } |
590 | 596 | ||
@@ -593,14 +599,14 @@ public class BSCharacter : BSPhysObject | |||
593 | { | 599 | { |
594 | _avatarVolume = (float)( | 600 | _avatarVolume = (float)( |
595 | Math.PI | 601 | Math.PI |
596 | * Scale.X | 602 | * (Scale.X / 2f) |
597 | * Scale.Y // the area of capsule cylinder | 603 | * (Scale.Y / 2f) // the area of capsule cylinder |
598 | * Scale.Z // times height of capsule cylinder | 604 | * Scale.Z // times height of capsule cylinder |
599 | + 1.33333333f | 605 | + 1.33333333f |
600 | * Math.PI | 606 | * Math.PI |
601 | * Scale.X | 607 | * (Scale.X / 2f) |
602 | * Math.Min(Scale.X, Scale.Y) | 608 | * (Math.Min(Scale.X, Scale.Y) / 2f) |
603 | * Scale.Y // plus the volume of the capsule end caps | 609 | * (Scale.Y / 2f) // plus the volume of the capsule end caps |
604 | ); | 610 | ); |
605 | _mass = _avatarDensity * _avatarVolume; | 611 | _mass = _avatarDensity * _avatarVolume; |
606 | } | 612 | } |
diff --git a/OpenSim/Region/Physics/BulletSPlugin/BSPhysObject.cs b/OpenSim/Region/Physics/BulletSPlugin/BSPhysObject.cs index 34dec26..b8ef338 100755 --- a/OpenSim/Region/Physics/BulletSPlugin/BSPhysObject.cs +++ b/OpenSim/Region/Physics/BulletSPlugin/BSPhysObject.cs | |||
@@ -141,18 +141,15 @@ public abstract class BSPhysObject : PhysicsActor | |||
141 | // if someone has subscribed for collision events.... | 141 | // if someone has subscribed for collision events.... |
142 | if (SubscribedEvents()) { | 142 | if (SubscribedEvents()) { |
143 | CollisionCollection.AddCollider(collidingWith, new ContactPoint(contactPoint, contactNormal, pentrationDepth)); | 143 | CollisionCollection.AddCollider(collidingWith, new ContactPoint(contactPoint, contactNormal, pentrationDepth)); |
144 | // DetailLog("{0},{1}.Collison.AddCollider,call,with={2},point={3},normal={4},depth={5}", | 144 | DetailLog("{0},{1}.Collison.AddCollider,call,with={2},point={3},normal={4},depth={5}", |
145 | // LocalID, TypeName, collidingWith, contactPoint, contactNormal, pentrationDepth); | 145 | LocalID, TypeName, collidingWith, contactPoint, contactNormal, pentrationDepth); |
146 | 146 | ||
147 | ret = true; | 147 | ret = true; |
148 | } | 148 | } |
149 | return ret; | 149 | return ret; |
150 | } | 150 | } |
151 | 151 | ||
152 | // Routine to send the collected collisions into the simulator. | 152 | // Send the collected collisions into the simulator. |
153 | // Also handles removal of this from the collection of objects with collisions if | ||
154 | // there are no collisions from this object. Mechanism is create one last | ||
155 | // collision event to make collision_end work. | ||
156 | // Called at taint time from within the Step() function thus no locking problems | 153 | // Called at taint time from within the Step() function thus no locking problems |
157 | // with CollisionCollection and ObjectsWithNoMoreCollisions. | 154 | // with CollisionCollection and ObjectsWithNoMoreCollisions. |
158 | // Return 'true' if there were some actual collisions passed up | 155 | // Return 'true' if there were some actual collisions passed up |
@@ -161,10 +158,9 @@ public abstract class BSPhysObject : PhysicsActor | |||
161 | bool ret = true; | 158 | bool ret = true; |
162 | 159 | ||
163 | // throttle the collisions to the number of milliseconds specified in the subscription | 160 | // throttle the collisions to the number of milliseconds specified in the subscription |
164 | int nowTime = PhysicsScene.SimulationNowTime; | 161 | if (PhysicsScene.SimulationNowTime >= NextCollisionOkTime) |
165 | if (nowTime >= NextCollisionOkTime) | ||
166 | { | 162 | { |
167 | NextCollisionOkTime = nowTime + SubscribedEventsMs; | 163 | NextCollisionOkTime = PhysicsScene.SimulationNowTime + SubscribedEventsMs; |
168 | 164 | ||
169 | // We are called if we previously had collisions. If there are no collisions | 165 | // We are called if we previously had collisions. If there are no collisions |
170 | // this time, send up one last empty event so OpenSim can sense collision end. | 166 | // this time, send up one last empty event so OpenSim can sense collision end. |
diff --git a/OpenSim/Region/Physics/BulletSPlugin/BSPrim.cs b/OpenSim/Region/Physics/BulletSPlugin/BSPrim.cs index b9e1908..8013e68 100644 --- a/OpenSim/Region/Physics/BulletSPlugin/BSPrim.cs +++ b/OpenSim/Region/Physics/BulletSPlugin/BSPrim.cs | |||
@@ -48,10 +48,10 @@ public sealed class BSPrim : BSPhysObject | |||
48 | 48 | ||
49 | private PrimitiveBaseShape _pbs; | 49 | private PrimitiveBaseShape _pbs; |
50 | 50 | ||
51 | // _size is what the user passed. _scale is what we pass to the physics engine with the mesh. | 51 | // _size is what the user passed. Scale is what we pass to the physics engine with the mesh. |
52 | // Often _scale is unity because the meshmerizer will apply _size when creating the mesh. | 52 | // Often Scale is unity because the meshmerizer will apply _size when creating the mesh. |
53 | private OMV.Vector3 _size; // the multiplier for each mesh dimension as passed by the user | 53 | private OMV.Vector3 _size; // the multiplier for each mesh dimension as passed by the user |
54 | private OMV.Vector3 _scale; // the multiplier for each mesh dimension for the mesh as created by the meshmerizer | 54 | // private OMV.Vector3 _scale; // the multiplier for each mesh dimension for the mesh as created by the meshmerizer |
55 | 55 | ||
56 | private bool _grabbed; | 56 | private bool _grabbed; |
57 | private bool _isSelected; | 57 | private bool _isSelected; |
@@ -98,7 +98,7 @@ public sealed class BSPrim : BSPhysObject | |||
98 | _physicsActorType = (int)ActorTypes.Prim; | 98 | _physicsActorType = (int)ActorTypes.Prim; |
99 | _position = pos; | 99 | _position = pos; |
100 | _size = size; | 100 | _size = size; |
101 | _scale = new OMV.Vector3(1f, 1f, 1f); // the scale will be set by CreateGeom depending on object type | 101 | Scale = new OMV.Vector3(1f, 1f, 1f); // the scale will be set by CreateGeom depending on object type |
102 | _orientation = rotation; | 102 | _orientation = rotation; |
103 | _buoyancy = 1f; | 103 | _buoyancy = 1f; |
104 | _velocity = OMV.Vector3.Zero; | 104 | _velocity = OMV.Vector3.Zero; |
@@ -166,7 +166,7 @@ public sealed class BSPrim : BSPhysObject | |||
166 | // Since _size changed, the mesh needs to be rebuilt. If rebuilt, all the correct | 166 | // Since _size changed, the mesh needs to be rebuilt. If rebuilt, all the correct |
167 | // scale and margins are set. | 167 | // scale and margins are set. |
168 | CreateGeomAndObject(true); | 168 | CreateGeomAndObject(true); |
169 | // DetailLog("{0},BSPrim.setSize,size={1},scale={2},mass={3},physical={4}", LocalID, _size, _scale, _mass, IsPhysical); | 169 | // DetailLog("{0},BSPrim.setSize,size={1},scale={2},mass={3},physical={4}", LocalID, _size, Scale, _mass, IsPhysical); |
170 | }); | 170 | }); |
171 | } | 171 | } |
172 | } | 172 | } |
@@ -1224,7 +1224,8 @@ public sealed class BSPrim : BSPhysObject | |||
1224 | shape.Position = _position; | 1224 | shape.Position = _position; |
1225 | shape.Rotation = _orientation; | 1225 | shape.Rotation = _orientation; |
1226 | shape.Velocity = _velocity; | 1226 | shape.Velocity = _velocity; |
1227 | shape.Scale = _scale; | 1227 | shape.Size = _size; |
1228 | shape.Scale = Scale; | ||
1228 | shape.Mass = _isPhysical ? _mass : 0f; | 1229 | shape.Mass = _isPhysical ? _mass : 0f; |
1229 | shape.Buoyancy = _buoyancy; | 1230 | shape.Buoyancy = _buoyancy; |
1230 | shape.HullKey = 0; | 1231 | shape.HullKey = 0; |
@@ -1234,7 +1235,6 @@ public sealed class BSPrim : BSPhysObject | |||
1234 | shape.Collidable = (!IsPhantom) ? ShapeData.numericTrue : ShapeData.numericFalse; | 1235 | shape.Collidable = (!IsPhantom) ? ShapeData.numericTrue : ShapeData.numericFalse; |
1235 | shape.Static = _isPhysical ? ShapeData.numericFalse : ShapeData.numericTrue; | 1236 | shape.Static = _isPhysical ? ShapeData.numericFalse : ShapeData.numericTrue; |
1236 | shape.Solid = IsSolid ? ShapeData.numericFalse : ShapeData.numericTrue; | 1237 | shape.Solid = IsSolid ? ShapeData.numericFalse : ShapeData.numericTrue; |
1237 | shape.Size = _size; | ||
1238 | } | 1238 | } |
1239 | // Rebuild the geometry and object. | 1239 | // Rebuild the geometry and object. |
1240 | // This is called when the shape changes so we need to recreate the mesh/hull. | 1240 | // This is called when the shape changes so we need to recreate the mesh/hull. |
diff --git a/OpenSim/Region/Physics/BulletSPlugin/BSScene.cs b/OpenSim/Region/Physics/BulletSPlugin/BSScene.cs index c6e8bc4..ab2835c 100644 --- a/OpenSim/Region/Physics/BulletSPlugin/BSScene.cs +++ b/OpenSim/Region/Physics/BulletSPlugin/BSScene.cs | |||
@@ -533,7 +533,7 @@ public class BSScene : PhysicsScene, IPhysicsParameters | |||
533 | } | 533 | } |
534 | 534 | ||
535 | // This is a kludge to get avatar movement updates. | 535 | // This is a kludge to get avatar movement updates. |
536 | // the simulator expects collisions for avatars even if there are have been no collisions. This updates | 536 | // The simulator expects collisions for avatars even if there are have been no collisions. This updates |
537 | // avatar animations and stuff. | 537 | // avatar animations and stuff. |
538 | // If you fix avatar animation updates, remove this overhead and let normal collision processing happen. | 538 | // If you fix avatar animation updates, remove this overhead and let normal collision processing happen. |
539 | foreach (BSPhysObject bsp in m_avatars) | 539 | foreach (BSPhysObject bsp in m_avatars) |
@@ -577,9 +577,9 @@ public class BSScene : PhysicsScene, IPhysicsParameters | |||
577 | 577 | ||
578 | // The physics engine returns the number of milliseconds it simulated this call. | 578 | // The physics engine returns the number of milliseconds it simulated this call. |
579 | // These are summed and normalized to one second and divided by 1000 to give the reported physics FPS. | 579 | // These are summed and normalized to one second and divided by 1000 to give the reported physics FPS. |
580 | // We multiply by 45 to give a recognizable running rate (45 or less). | 580 | // We multiply by 55 to give a recognizable running rate (55 or less). |
581 | return numSubSteps * m_fixedTimeStep * 1000 * 45; | 581 | return numSubSteps * m_fixedTimeStep * 1000 * 55; |
582 | // return timeStep * 1000 * 45; | 582 | // return timeStep * 1000 * 55; |
583 | } | 583 | } |
584 | 584 | ||
585 | // Something has collided | 585 | // Something has collided |
@@ -795,7 +795,7 @@ public class BSScene : PhysicsScene, IPhysicsParameters | |||
795 | 795 | ||
796 | delegate void ParamUser(BSScene scene, IConfig conf, string paramName, float val); | 796 | delegate void ParamUser(BSScene scene, IConfig conf, string paramName, float val); |
797 | delegate float ParamGet(BSScene scene); | 797 | delegate float ParamGet(BSScene scene); |
798 | delegate void ParamSet(BSScene scene, string paramName, uint localID, float val); | 798 | delegate void ParamSet(BSScene scene, string paramName, uint localID, float val); |
799 | delegate void SetOnObject(BSScene scene, BSPhysObject obj, float val); | 799 | delegate void SetOnObject(BSScene scene, BSPhysObject obj, float val); |
800 | 800 | ||
801 | private struct ParameterDefn | 801 | private struct ParameterDefn |
@@ -805,7 +805,7 @@ public class BSScene : PhysicsScene, IPhysicsParameters | |||
805 | public float defaultValue; // default value if not specified anywhere else | 805 | public float defaultValue; // default value if not specified anywhere else |
806 | public ParamUser userParam; // get the value from the configuration file | 806 | public ParamUser userParam; // get the value from the configuration file |
807 | public ParamGet getter; // return the current value stored for this parameter | 807 | public ParamGet getter; // return the current value stored for this parameter |
808 | public ParamSet setter; // set the current value for this parameter | 808 | public ParamSet setter; // set the current value for this parameter |
809 | public SetOnObject onObject; // set the value on an object in the physical domain | 809 | public SetOnObject onObject; // set the value on an object in the physical domain |
810 | public ParameterDefn(string n, string d, float v, ParamUser u, ParamGet g, ParamSet s) | 810 | public ParameterDefn(string n, string d, float v, ParamUser u, ParamGet g, ParamSet s) |
811 | { | 811 | { |
@@ -814,7 +814,7 @@ public class BSScene : PhysicsScene, IPhysicsParameters | |||
814 | defaultValue = v; | 814 | defaultValue = v; |
815 | userParam = u; | 815 | userParam = u; |
816 | getter = g; | 816 | getter = g; |
817 | setter = s; | 817 | setter = s; |
818 | onObject = null; | 818 | onObject = null; |
819 | } | 819 | } |
820 | public ParameterDefn(string n, string d, float v, ParamUser u, ParamGet g, ParamSet s, SetOnObject o) | 820 | public ParameterDefn(string n, string d, float v, ParamUser u, ParamGet g, ParamSet s, SetOnObject o) |
@@ -824,7 +824,7 @@ public class BSScene : PhysicsScene, IPhysicsParameters | |||
824 | defaultValue = v; | 824 | defaultValue = v; |
825 | userParam = u; | 825 | userParam = u; |
826 | getter = g; | 826 | getter = g; |
827 | setter = s; | 827 | setter = s; |
828 | onObject = o; | 828 | onObject = o; |
829 | } | 829 | } |
830 | } | 830 | } |
@@ -1266,13 +1266,13 @@ public class BSScene : PhysicsScene, IPhysicsParameters | |||
1266 | objectIDs.Add(TERRAIN_ID); | 1266 | objectIDs.Add(TERRAIN_ID); |
1267 | TaintedUpdateParameter(parm, objectIDs, val); | 1267 | TaintedUpdateParameter(parm, objectIDs, val); |
1268 | break; | 1268 | break; |
1269 | case PhysParameterEntry.APPLY_TO_ALL: | 1269 | case PhysParameterEntry.APPLY_TO_ALL: |
1270 | defaultLoc = val; // setting ALL also sets the default value | 1270 | defaultLoc = val; // setting ALL also sets the default value |
1271 | lock (PhysObjects) objectIDs = new List<uint>(PhysObjects.Keys); | 1271 | lock (PhysObjects) objectIDs = new List<uint>(PhysObjects.Keys); |
1272 | TaintedUpdateParameter(parm, objectIDs, val); | 1272 | TaintedUpdateParameter(parm, objectIDs, val); |
1273 | break; | 1273 | break; |
1274 | default: | 1274 | default: |
1275 | // setting only one localID | 1275 | // setting only one localID |
1276 | objectIDs.Add(localID); | 1276 | objectIDs.Add(localID); |
1277 | TaintedUpdateParameter(parm, objectIDs, val); | 1277 | TaintedUpdateParameter(parm, objectIDs, val); |
1278 | break; | 1278 | break; |
@@ -1282,8 +1282,8 @@ public class BSScene : PhysicsScene, IPhysicsParameters | |||
1282 | // schedule the actual updating of the paramter to when the phys engine is not busy | 1282 | // schedule the actual updating of the paramter to when the phys engine is not busy |
1283 | protected void TaintedUpdateParameter(string parm, List<uint> lIDs, float val) | 1283 | protected void TaintedUpdateParameter(string parm, List<uint> lIDs, float val) |
1284 | { | 1284 | { |
1285 | float xval = val; | 1285 | float xval = val; |
1286 | List<uint> xlIDs = lIDs; | 1286 | List<uint> xlIDs = lIDs; |
1287 | string xparm = parm; | 1287 | string xparm = parm; |
1288 | TaintedObject("BSScene.UpdateParameterSet", delegate() { | 1288 | TaintedObject("BSScene.UpdateParameterSet", delegate() { |
1289 | ParameterDefn thisParam; | 1289 | ParameterDefn thisParam; |
diff --git a/OpenSim/Region/Physics/BulletSPlugin/BSShapeCollection.cs b/OpenSim/Region/Physics/BulletSPlugin/BSShapeCollection.cs index bbfdac6..3d15eaa 100755 --- a/OpenSim/Region/Physics/BulletSPlugin/BSShapeCollection.cs +++ b/OpenSim/Region/Physics/BulletSPlugin/BSShapeCollection.cs | |||
@@ -417,7 +417,10 @@ public class BSShapeCollection : IDisposable | |||
417 | 417 | ||
418 | if (shapeType == ShapeData.PhysicsShapeType.SHAPE_AVATAR) | 418 | if (shapeType == ShapeData.PhysicsShapeType.SHAPE_AVATAR) |
419 | { | 419 | { |
420 | newShape = new BulletShape(BulletSimAPI.BuildCapsuleShape2(PhysicsScene.World.ptr, shapeData), shapeType); | 420 | // The radius is scaled by 1/2 because we scale by the diameter. |
421 | newShape = new BulletShape( | ||
422 | BulletSimAPI.BuildCapsuleShape2(PhysicsScene.World.ptr, 0.5f, 1.0f, shapeData.Scale), | ||
423 | shapeType); | ||
421 | newShape.shapeKey = (System.UInt64)shapeKey; | 424 | newShape.shapeKey = (System.UInt64)shapeKey; |
422 | newShape.isNativeShape = true; | 425 | newShape.isNativeShape = true; |
423 | } | 426 | } |
@@ -428,7 +431,7 @@ public class BSShapeCollection : IDisposable | |||
428 | newShape.isNativeShape = true; | 431 | newShape.isNativeShape = true; |
429 | } | 432 | } |
430 | 433 | ||
431 | // Don't need to do a 'ReferenceShape()' here because native shapes are not tracked. | 434 | // Don't need to do a 'ReferenceShape()' here because native shapes are not shared. |
432 | // DetailLog("{0},BSShapeCollection.AddNativeShapeToPrim,create,newshape={1}", shapeData.ID, newShape); | 435 | // DetailLog("{0},BSShapeCollection.AddNativeShapeToPrim,create,newshape={1}", shapeData.ID, newShape); |
433 | 436 | ||
434 | prim.BSShape = newShape; | 437 | prim.BSShape = newShape; |
diff --git a/OpenSim/Region/Physics/BulletSPlugin/BulletSimAPI.cs b/OpenSim/Region/Physics/BulletSPlugin/BulletSimAPI.cs index 30754a7..24d8db6 100644 --- a/OpenSim/Region/Physics/BulletSPlugin/BulletSimAPI.cs +++ b/OpenSim/Region/Physics/BulletSPlugin/BulletSimAPI.cs | |||
@@ -608,7 +608,7 @@ public static extern IntPtr BuildNativeShape2(IntPtr world, ShapeData shapeData) | |||
608 | public static extern bool IsNativeShape2(IntPtr shape); | 608 | public static extern bool IsNativeShape2(IntPtr shape); |
609 | 609 | ||
610 | [DllImport("BulletSim", CallingConvention = CallingConvention.Cdecl), SuppressUnmanagedCodeSecurity] | 610 | [DllImport("BulletSim", CallingConvention = CallingConvention.Cdecl), SuppressUnmanagedCodeSecurity] |
611 | public static extern IntPtr BuildCapsuleShape2(IntPtr world, ShapeData shapeData); | 611 | public static extern IntPtr BuildCapsuleShape2(IntPtr world, float radius, float height, Vector3 scale); |
612 | 612 | ||
613 | [DllImport("BulletSim", CallingConvention = CallingConvention.Cdecl), SuppressUnmanagedCodeSecurity] | 613 | [DllImport("BulletSim", CallingConvention = CallingConvention.Cdecl), SuppressUnmanagedCodeSecurity] |
614 | public static extern IntPtr CreateCompoundShape2(IntPtr sim); | 614 | public static extern IntPtr CreateCompoundShape2(IntPtr sim); |