aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim')
-rw-r--r--OpenSim/Region/PhysicsModules/ubOde/ODEPrim.cs199
1 files changed, 77 insertions, 122 deletions
diff --git a/OpenSim/Region/PhysicsModules/ubOde/ODEPrim.cs b/OpenSim/Region/PhysicsModules/ubOde/ODEPrim.cs
index bf0400b..7b77d2f 100644
--- a/OpenSim/Region/PhysicsModules/ubOde/ODEPrim.cs
+++ b/OpenSim/Region/PhysicsModules/ubOde/ODEPrim.cs
@@ -111,7 +111,6 @@ namespace OpenSim.Region.PhysicsModule.ubOde
111 111
112 private int m_body_autodisable_frames; 112 private int m_body_autodisable_frames;
113 public int m_bodydisablecontrol = 0; 113 public int m_bodydisablecontrol = 0;
114 public int m_bodyMoveCoolDown = 0;
115 private float m_gravmod = 1.0f; 114 private float m_gravmod = 1.0f;
116 115
117 // Default we're a Geometry 116 // Default we're a Geometry
@@ -1030,18 +1029,16 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1030 d.AllocateODEDataForThread(0); 1029 d.AllocateODEDataForThread(0);
1031 if(Body != IntPtr.Zero) 1030 if(Body != IntPtr.Zero)
1032 { 1031 {
1033 if(m_bodyMoveCoolDown >= 0) 1032 d.Vector3 dtmp = d.BodyGetAngularVel(Body);
1034 { 1033 m_rotationalVelocity.X = dtmp.X;
1035 d.Vector3 dtmp = d.BodyGetAngularVel(Body); 1034 m_rotationalVelocity.Y = dtmp.Y;
1036 m_rotationalVelocity.X = dtmp.X; 1035 m_rotationalVelocity.Z = dtmp.Z;
1037 m_rotationalVelocity.Y = dtmp.Y; 1036
1038 m_rotationalVelocity.Z = dtmp.Z; 1037 dtmp = d.BodyGetLinearVel(Body);
1038 _velocity.X = dtmp.X;
1039 _velocity.Y = dtmp.Y;
1040 _velocity.Z = dtmp.Z;
1039 1041
1040 dtmp = d.BodyGetLinearVel(Body);
1041 _velocity.X = dtmp.X;
1042 _velocity.Y = dtmp.Y;
1043 _velocity.Z = dtmp.Z;
1044 }
1045 d.BodySetLinearVel(Body, 0, 0, 0); // stop it 1042 d.BodySetLinearVel(Body, 0, 0, 0); // stop it
1046 d.BodySetAngularVel(Body, 0, 0, 0); 1043 d.BodySetAngularVel(Body, 0, 0, 0);
1047 } 1044 }
@@ -1345,7 +1342,6 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1345 bounce = parent_scene.m_materialContactsData[(int)Material.Wood].bounce; 1342 bounce = parent_scene.m_materialContactsData[(int)Material.Wood].bounce;
1346 1343
1347 m_building = true; // control must set this to false when done 1344 m_building = true; // control must set this to false when done
1348 m_bodyMoveCoolDown = 0;
1349 1345
1350 AddChange(changes.Add, null); 1346 AddChange(changes.Add, null);
1351 1347
@@ -2144,14 +2140,12 @@ namespace OpenSim.Region.PhysicsModule.ubOde
2144 } 2140 }
2145 else 2141 else
2146 { 2142 {
2147 /*
2148 d.BodySetAngularVel(Body, m_rotationalVelocity.X, m_rotationalVelocity.Y, m_rotationalVelocity.Z); 2143 d.BodySetAngularVel(Body, m_rotationalVelocity.X, m_rotationalVelocity.Y, m_rotationalVelocity.Z);
2149 d.BodySetLinearVel(Body, _velocity.X, _velocity.Y, _velocity.Z); 2144 d.BodySetLinearVel(Body, _velocity.X, _velocity.Y, _velocity.Z);
2150 */ 2145
2151 _zeroFlag = false; 2146 _zeroFlag = false;
2152 m_bodydisablecontrol = 0; 2147 m_bodydisablecontrol = 0;
2153 } 2148 }
2154 m_bodyMoveCoolDown = -5;
2155 _parent_scene.addActiveGroups(this); 2149 _parent_scene.addActiveGroups(this);
2156 } 2150 }
2157 2151
@@ -2244,7 +2238,6 @@ namespace OpenSim.Region.PhysicsModule.ubOde
2244 } 2238 }
2245 m_mass = primMass; 2239 m_mass = primMass;
2246 m_collisionscore = 0; 2240 m_collisionscore = 0;
2247 m_bodyMoveCoolDown = 0;
2248 } 2241 }
2249 2242
2250 private void FixInertia(Vector3 NewPos,Quaternion newrot) 2243 private void FixInertia(Vector3 NewPos,Quaternion newrot)
@@ -2907,7 +2900,6 @@ namespace OpenSim.Region.PhysicsModule.ubOde
2907 { 2900 {
2908 _zeroFlag = true; 2901 _zeroFlag = true;
2909 d.BodyEnable(Body); 2902 d.BodyEnable(Body);
2910 m_bodyMoveCoolDown = -5;
2911 } 2903 }
2912 } 2904 }
2913// else if (_parent != null) 2905// else if (_parent != null)
@@ -2950,8 +2942,6 @@ namespace OpenSim.Region.PhysicsModule.ubOde
2950 { 2942 {
2951 d.GeomSetPosition(prim_geom, newPos.X, newPos.Y, newPos.Z); 2943 d.GeomSetPosition(prim_geom, newPos.X, newPos.Y, newPos.Z);
2952 _position = newPos; 2944 _position = newPos;
2953 if (Body != IntPtr.Zero && !m_disabled)
2954 m_bodyMoveCoolDown = -5;
2955 } 2945 }
2956 if (Body != IntPtr.Zero && !d.BodyIsEnabled(Body)) 2946 if (Body != IntPtr.Zero && !d.BodyIsEnabled(Body))
2957 { 2947 {
@@ -3016,7 +3006,6 @@ namespace OpenSim.Region.PhysicsModule.ubOde
3016 { 3006 {
3017 if(m_angularlocks != 0) 3007 if(m_angularlocks != 0)
3018 createAMotor(m_angularlocks); 3008 createAMotor(m_angularlocks);
3019 m_bodyMoveCoolDown = -5;
3020 } 3009 }
3021 } 3010 }
3022 if (Body != IntPtr.Zero && !d.BodyIsEnabled(Body)) 3011 if (Body != IntPtr.Zero && !d.BodyIsEnabled(Body))
@@ -3391,8 +3380,6 @@ namespace OpenSim.Region.PhysicsModule.ubOde
3391 enableBodySoft(); 3380 enableBodySoft();
3392 else if (!d.BodyIsEnabled(Body)) 3381 else if (!d.BodyIsEnabled(Body))
3393 d.BodyEnable(Body); 3382 d.BodyEnable(Body);
3394 if(m_bodyMoveCoolDown >= 0)
3395 d.BodySetLinearVel(Body, newVel.X, newVel.Y, newVel.Z);
3396 } 3383 }
3397 //resetCollisionAccounting(); 3384 //resetCollisionAccounting();
3398 } 3385 }
@@ -3416,9 +3403,6 @@ namespace OpenSim.Region.PhysicsModule.ubOde
3416 enableBodySoft(); 3403 enableBodySoft();
3417 else if (!d.BodyIsEnabled(Body)) 3404 else if (!d.BodyIsEnabled(Body))
3418 d.BodyEnable(Body); 3405 d.BodyEnable(Body);
3419
3420 if(m_bodyMoveCoolDown >= 0);
3421 d.BodySetAngularVel(Body, newAngVel.X, newAngVel.Y, newAngVel.Z);
3422 } 3406 }
3423 //resetCollisionAccounting(); 3407 //resetCollisionAccounting();
3424 } 3408 }
@@ -3569,26 +3553,6 @@ namespace OpenSim.Region.PhysicsModule.ubOde
3569 if (!childPrim && m_isphysical && Body != IntPtr.Zero && 3553 if (!childPrim && m_isphysical && Body != IntPtr.Zero &&
3570 !m_disabled && !m_isSelected && !m_building && !m_outbounds) 3554 !m_disabled && !m_isSelected && !m_building && !m_outbounds)
3571 { 3555 {
3572 if(m_bodyMoveCoolDown < 0)
3573 {
3574 m_bodyMoveCoolDown++;
3575// if(!IsColliding)
3576// m_bodyCoolDown +=2;
3577 if(m_bodyMoveCoolDown >= 0)
3578 {
3579 d.BodySetAngularVel(Body, m_rotationalVelocity.X, m_rotationalVelocity.Y, m_rotationalVelocity.Z);
3580 d.BodySetLinearVel(Body, _velocity.X, _velocity.Y, _velocity.Z);
3581 }
3582 else
3583 {
3584 d.BodySetAngularVel(Body, 0, 0, 0);
3585 d.BodySetLinearVel(Body, 0, 0, 0);
3586 m_forceacc = Vector3.Zero;
3587 m_angularForceacc = Vector3.Zero;
3588 _zeroFlag = false;
3589 return;
3590 }
3591 }
3592 if (!d.BodyIsEnabled(Body)) 3556 if (!d.BodyIsEnabled(Body))
3593 { 3557 {
3594 // let vehicles sleep 3558 // let vehicles sleep
@@ -3844,18 +3808,15 @@ namespace OpenSim.Region.PhysicsModule.ubOde
3844 m_lastposition = _position; 3808 m_lastposition = _position;
3845 m_lastorientation = _orientation; 3809 m_lastorientation = _orientation;
3846 3810
3847 if(m_bodyMoveCoolDown >= 0) 3811 d.Vector3 dtmp = d.BodyGetAngularVel(Body);
3848 { 3812 m_rotationalVelocity.X = dtmp.X;
3849 d.Vector3 dtmp = d.BodyGetAngularVel(Body); 3813 m_rotationalVelocity.Y = dtmp.Y;
3850 m_rotationalVelocity.X = dtmp.X; 3814 m_rotationalVelocity.Z = dtmp.Z;
3851 m_rotationalVelocity.Y = dtmp.Y; 3815
3852 m_rotationalVelocity.Z = dtmp.Z; 3816 dtmp = d.BodyGetLinearVel(Body);
3853 3817 _velocity.X = dtmp.X;
3854 dtmp = d.BodyGetLinearVel(Body); 3818 _velocity.Y = dtmp.Y;
3855 _velocity.X = dtmp.X; 3819 _velocity.Z = dtmp.Z;
3856 _velocity.Y = dtmp.Y;
3857 _velocity.Z = dtmp.Z;
3858 }
3859 3820
3860 d.BodySetLinearVel(Body, 0, 0, 0); // stop it 3821 d.BodySetLinearVel(Body, 0, 0, 0); // stop it
3861 d.BodySetAngularVel(Body, 0, 0, 0); 3822 d.BodySetAngularVel(Body, 0, 0, 0);
@@ -3880,33 +3841,30 @@ namespace OpenSim.Region.PhysicsModule.ubOde
3880 } 3841 }
3881 else 3842 else
3882 { 3843 {
3883 if(m_bodyMoveCoolDown >= 0) 3844 float poserror;
3845 float angerror;
3846 if(_zeroFlag)
3884 { 3847 {
3885 float poserror; 3848 poserror = 0.01f;
3886 float angerror; 3849 angerror = 0.001f;
3887 if(_zeroFlag)
3888 {
3889 poserror = 0.01f;
3890 angerror = 0.001f;
3891 }
3892 else
3893 {
3894 poserror = 0.005f;
3895 angerror = 0.0005f;
3896 }
3897
3898 if (
3899 (Math.Abs(_position.X - lpos.X) < poserror)
3900 && (Math.Abs(_position.Y - lpos.Y) < poserror)
3901 && (Math.Abs(_position.Z - lpos.Z) < poserror)
3902 && (Math.Abs(_orientation.X - ori.X) < angerror)
3903 && (Math.Abs(_orientation.Y - ori.Y) < angerror)
3904 && (Math.Abs(_orientation.Z - ori.Z) < angerror) // ignore W
3905 )
3906 _zeroFlag = true;
3907 else
3908 _zeroFlag = false;
3909 } 3850 }
3851 else
3852 {
3853 poserror = 0.005f;
3854 angerror = 0.0005f;
3855 }
3856
3857 if (
3858 (Math.Abs(_position.X - lpos.X) < poserror)
3859 && (Math.Abs(_position.Y - lpos.Y) < poserror)
3860 && (Math.Abs(_position.Z - lpos.Z) < poserror)
3861 && (Math.Abs(_orientation.X - ori.X) < angerror)
3862 && (Math.Abs(_orientation.Y - ori.Y) < angerror)
3863 && (Math.Abs(_orientation.Z - ori.Z) < angerror) // ignore W
3864 )
3865 _zeroFlag = true;
3866 else
3867 _zeroFlag = false;
3910 } 3868 }
3911 3869
3912 // update position 3870 // update position
@@ -3932,49 +3890,46 @@ namespace OpenSim.Region.PhysicsModule.ubOde
3932 } 3890 }
3933 else 3891 else
3934 { 3892 {
3935 if(m_bodyMoveCoolDown >= 0) 3893 d.Vector3 vel = d.BodyGetLinearVel(Body);
3936 {
3937 d.Vector3 vel = d.BodyGetLinearVel(Body);
3938 3894
3939 m_acceleration = _velocity; 3895 m_acceleration = _velocity;
3940 3896
3941 if ((Math.Abs(vel.X) < 0.005f) && 3897 if ((Math.Abs(vel.X) < 0.005f) &&
3942 (Math.Abs(vel.Y) < 0.005f) && 3898 (Math.Abs(vel.Y) < 0.005f) &&
3943 (Math.Abs(vel.Z) < 0.005f)) 3899 (Math.Abs(vel.Z) < 0.005f))
3944 { 3900 {
3945 _velocity = Vector3.Zero; 3901 _velocity = Vector3.Zero;
3946 float t = -m_invTimeStep; 3902 float t = -m_invTimeStep;
3947 m_acceleration = m_acceleration * t; 3903 m_acceleration = m_acceleration * t;
3948 } 3904 }
3949 else 3905 else
3950 { 3906 {
3951 _velocity.X = vel.X; 3907 _velocity.X = vel.X;
3952 _velocity.Y = vel.Y; 3908 _velocity.Y = vel.Y;
3953 _velocity.Z = vel.Z; 3909 _velocity.Z = vel.Z;
3954 m_acceleration = (_velocity - m_acceleration) * m_invTimeStep; 3910 m_acceleration = (_velocity - m_acceleration) * m_invTimeStep;
3955 } 3911 }
3956 3912
3957 if ((Math.Abs(m_acceleration.X) < 0.01f) && 3913 if ((Math.Abs(m_acceleration.X) < 0.01f) &&
3958 (Math.Abs(m_acceleration.Y) < 0.01f) && 3914 (Math.Abs(m_acceleration.Y) < 0.01f) &&
3959 (Math.Abs(m_acceleration.Z) < 0.01f)) 3915 (Math.Abs(m_acceleration.Z) < 0.01f))
3960 { 3916 {
3961 m_acceleration = Vector3.Zero; 3917 m_acceleration = Vector3.Zero;
3962 } 3918 }
3963 3919
3964 vel = d.BodyGetAngularVel(Body); 3920 vel = d.BodyGetAngularVel(Body);
3965 if ((Math.Abs(vel.X) < 0.0001) && 3921 if ((Math.Abs(vel.X) < 0.0001) &&
3966 (Math.Abs(vel.Y) < 0.0001) && 3922 (Math.Abs(vel.Y) < 0.0001) &&
3967 (Math.Abs(vel.Z) < 0.0001) 3923 (Math.Abs(vel.Z) < 0.0001)
3968 ) 3924 )
3969 { 3925 {
3970 m_rotationalVelocity = Vector3.Zero; 3926 m_rotationalVelocity = Vector3.Zero;
3971 } 3927 }
3972 else 3928 else
3973 { 3929 {
3974 m_rotationalVelocity.X = vel.X; 3930 m_rotationalVelocity.X = vel.X;
3975 m_rotationalVelocity.Y = vel.Y; 3931 m_rotationalVelocity.Y = vel.Y;
3976 m_rotationalVelocity.Z = vel.Z; 3932 m_rotationalVelocity.Z = vel.Z;
3977 }
3978 } 3933 }
3979 } 3934 }
3980 3935