aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/PhysicsModules
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/PhysicsModules')
-rw-r--r--OpenSim/Region/PhysicsModules/ubOde/ODEDynamics.cs142
1 files changed, 103 insertions, 39 deletions
diff --git a/OpenSim/Region/PhysicsModules/ubOde/ODEDynamics.cs b/OpenSim/Region/PhysicsModules/ubOde/ODEDynamics.cs
index d8a2272..456d9e9 100644
--- a/OpenSim/Region/PhysicsModules/ubOde/ODEDynamics.cs
+++ b/OpenSim/Region/PhysicsModules/ubOde/ODEDynamics.cs
@@ -648,6 +648,10 @@ namespace OpenSim.Region.PhysicsModule.ubOde
648 break; 648 break;
649 649
650 } 650 }
651 // disable mouse steering
652 m_flags &= ~(VehicleFlag.MOUSELOOK_STEER |
653 VehicleFlag.MOUSELOOK_BANK |
654 VehicleFlag.CAMERA_DECOUPLED);
651 655
652 m_lmDecay = (1.0f - 1.0f / m_linearMotorDecayTimescale); 656 m_lmDecay = (1.0f - 1.0f / m_linearMotorDecayTimescale);
653 m_amDecay = 1.0f - 1.0f / m_angularMotorDecayTimescale; 657 m_amDecay = 1.0f - 1.0f / m_angularMotorDecayTimescale;
@@ -794,6 +798,16 @@ namespace OpenSim.Region.PhysicsModule.ubOde
794 798
795 float ldampZ = 0; 799 float ldampZ = 0;
796 800
801 bool mousemode = false;
802 if((m_flags & (VehicleFlag.MOUSELOOK_STEER |VehicleFlag.MOUSELOOK_BANK)) != 0 )
803 mousemode = true;
804
805 float bankingEfficiency;
806 if(mousemode)
807 bankingEfficiency = 0;
808 else
809 bankingEfficiency = m_bankingEfficiency;
810
797 // linear motor 811 // linear motor
798 if (m_lmEfect > 0.01 && m_linearMotorTimescale < 1000) 812 if (m_lmEfect > 0.01 && m_linearMotorTimescale < 1000)
799 { 813 {
@@ -967,7 +981,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde
967 torque.Y += effpitch * ftmp; 981 torque.Y += effpitch * ftmp;
968 } 982 }
969 983
970 if (m_bankingEfficiency != 0 && Math.Abs(effroll) > 0.01) 984 if (bankingEfficiency != 0 && Math.Abs(effroll) > 0.01)
971 { 985 {
972 986
973 float broll = effroll; 987 float broll = effroll;
@@ -1018,58 +1032,108 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1018 m_amdampZ = 1 / m_angularFrictionTimescale.Z; 1032 m_amdampZ = 1 / m_angularFrictionTimescale.Z;
1019 } 1033 }
1020 1034
1021 // angular motor 1035 if(mousemode)
1022 if (m_amEfect > 0.01 && m_angularMotorTimescale < 1000)
1023 { 1036 {
1024 tmpV = m_angularMotorDirection - curLocalAngVel; // velocity error 1037 CameraData cam = rootPrim.TryGetCameraData();
1025 tmpV *= m_amEfect / m_angularMotorTimescale; // error to correct in this timestep 1038 if(cam.Valid && cam.MouseLook)
1026 torque.X += tmpV.X * m_ampwr; 1039 {
1027 torque.Y += tmpV.Y * m_ampwr; 1040 Vector3 dirv = cam.CameraAtAxis * irotq;
1028 torque.Z += tmpV.Z;
1029 1041
1030 m_amEfect *= m_amDecay; 1042 float tmp;
1043 if(Math.Abs(dirv.X) > 0.01f)
1044 {
1045 if (Math.Abs(dirv.Z) > 0.01)
1046 {
1047 tmp = -(float)Math.Atan2(dirv.Z, dirv.X) * m_angularMotorDirection.Y;
1048 if(tmp < -4f)
1049 tmp = -4f;
1050 else if(tmp > 4f)
1051 tmp = 4f;
1052 torque.Y += (tmp - curLocalAngVel.Y) / m_angularMotorTimescale;
1053 }
1054
1055 if (Math.Abs(dirv.Y) > 0.01)
1056 {
1057 tmp = (float)Math.Atan2(dirv.Y, dirv.X) * m_angularMotorDirection.Z;
1058 if(tmp < -4f)
1059 tmp = -4f;
1060 else if(tmp > 4f)
1061 tmp = 4f;
1062 torque.Z += (tmp - curLocalAngVel.Z) / m_angularMotorTimescale;
1063 }
1064 }
1065 // angular friction
1066 if (curLocalAngVel.X != 0 || curLocalAngVel.Y != 0 || curLocalAngVel.Z != 0)
1067 {
1068 torque.X -= curLocalAngVel.X * m_amdampX;
1069 torque.Y -= curLocalAngVel.Y * m_amdampY;
1070 torque.Z -= curLocalAngVel.Z * m_amdampZ;
1071 }
1072 }
1073 else
1074 {
1075 if (curLocalAngVel.X != 0 || curLocalAngVel.Y != 0 || curLocalAngVel.Z != 0)
1076 {
1077 torque.X -= curLocalAngVel.X * 10f;
1078 torque.Y -= curLocalAngVel.Y * 10f;
1079 torque.Z -= curLocalAngVel.Z * 10f;
1080 }
1081 }
1031 } 1082 }
1032 else 1083 else
1033 m_amEfect = 0;
1034
1035 // angular deflection
1036 if (m_angularDeflectionEfficiency > 0)
1037 { 1084 {
1038 Vector3 dirv; 1085 // angular motor
1039 1086 if (m_amEfect > 0.01 && m_angularMotorTimescale < 1000)
1040 if (curLocalVel.X > 0.01f)
1041 dirv = curLocalVel;
1042 else if (curLocalVel.X < -0.01f)
1043 // use oposite
1044 dirv = -curLocalVel;
1045 else
1046 { 1087 {
1047 // make it fall into small positive x case 1088 tmpV = m_angularMotorDirection - curLocalAngVel; // velocity error
1048 dirv.X = 0.01f; 1089 tmpV *= m_amEfect / m_angularMotorTimescale; // error to correct in this timestep
1049 dirv.Y = curLocalVel.Y; 1090 torque.X += tmpV.X * m_ampwr;
1050 dirv.Z = curLocalVel.Z; 1091 torque.Y += tmpV.Y * m_ampwr;
1051 } 1092 torque.Z += tmpV.Z;
1052 1093
1053 float ftmp = m_angularDeflectionEfficiency / m_angularDeflectionTimescale; 1094 m_amEfect *= m_amDecay;
1095 }
1096 else
1097 m_amEfect = 0;
1054 1098
1055 if (Math.Abs(dirv.Z) > 0.01) 1099 // angular deflection
1100 if (m_angularDeflectionEfficiency > 0)
1056 { 1101 {
1057 torque.Y += - (float)Math.Atan2(dirv.Z, dirv.X) * ftmp; 1102 Vector3 dirv;
1103
1104 if (curLocalVel.X > 0.01f)
1105 dirv = curLocalVel;
1106 else if (curLocalVel.X < -0.01f)
1107 // use oposite
1108 dirv = -curLocalVel;
1109 else
1110 {
1111 // make it fall into small positive x case
1112 dirv.X = 0.01f;
1113 dirv.Y = curLocalVel.Y;
1114 dirv.Z = curLocalVel.Z;
1115 }
1116
1117 float ftmp = m_angularDeflectionEfficiency / m_angularDeflectionTimescale;
1118
1119 if (Math.Abs(dirv.Z) > 0.01)
1120 {
1121 torque.Y += - (float)Math.Atan2(dirv.Z, dirv.X) * ftmp;
1122 }
1123
1124 if (Math.Abs(dirv.Y) > 0.01)
1125 {
1126 torque.Z += (float)Math.Atan2(dirv.Y, dirv.X) * ftmp;
1127 }
1058 } 1128 }
1059 1129
1060 if (Math.Abs(dirv.Y) > 0.01) 1130 if (curLocalAngVel.X != 0 || curLocalAngVel.Y != 0 || curLocalAngVel.Z != 0)
1061 { 1131 {
1062 torque.Z += (float)Math.Atan2(dirv.Y, dirv.X) * ftmp; 1132 torque.X -= curLocalAngVel.X * m_amdampX;
1133 torque.Y -= curLocalAngVel.Y * m_amdampY;
1134 torque.Z -= curLocalAngVel.Z * m_amdampZ;
1063 } 1135 }
1064 } 1136 }
1065
1066 // angular friction
1067 if (curLocalAngVel.X != 0 || curLocalAngVel.Y != 0 || curLocalAngVel.Z != 0)
1068 {
1069 torque.X -= curLocalAngVel.X * m_amdampX;
1070 torque.Y -= curLocalAngVel.Y * m_amdampY;
1071 torque.Z -= curLocalAngVel.Z * m_amdampZ;
1072 }
1073 1137
1074 force *= dmass.mass; 1138 force *= dmass.mass;
1075 1139