aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/Region/Physics/BulletXPlugin/BulletXPlugin.cs601
1 files changed, 312 insertions, 289 deletions
diff --git a/OpenSim/Region/Physics/BulletXPlugin/BulletXPlugin.cs b/OpenSim/Region/Physics/BulletXPlugin/BulletXPlugin.cs
index 8b05295..6960f4e 100644
--- a/OpenSim/Region/Physics/BulletXPlugin/BulletXPlugin.cs
+++ b/OpenSim/Region/Physics/BulletXPlugin/BulletXPlugin.cs
@@ -633,35 +633,227 @@ namespace OpenSim.Region.Physics.BulletXPlugin
633 } 633 }
634 634
635 /// <summary> 635 /// <summary>
636 /// PhysicsActor Character Class for BulletX 636 /// Generic Physics Actor for BulletX inherit from PhysicActor
637 /// </summary> 637 /// </summary>
638 public class BulletXCharacter : PhysicsActor 638 public class BulletXActor : PhysicsActor
639 { 639 {
640 private PhysicsVector _position; 640 protected bool flying = false;
641 private PhysicsVector _velocity; 641 protected bool _physical = true;
642 private PhysicsVector _size; 642 protected PhysicsVector _position;
643 private PhysicsVector _acceleration; 643 protected PhysicsVector _velocity;
644 private AxiomQuaternion _orientation; 644 protected PhysicsVector _size;
645 private bool flying; 645 protected PhysicsVector _acceleration;
646 private bool iscolliding = false; 646 protected AxiomQuaternion _orientation;
647 private RigidBody rigidBody; 647 protected RigidBody rigidBody;
648 private Boolean iscolliding = false;
649
650 public BulletXActor()
651 {
652 }
653
654 public override PhysicsVector Position
655 {
656 get
657 {
658 return _position;
659 }
660 set
661 {
662 lock (BulletXScene.BulletXLock)
663 {
664 _position = value;
665 Translate();
666 }
667 }
668 }
669 public override PhysicsVector Velocity
670 {
671 get
672 {
673 return _velocity;
674 }
675 set
676 {
677 lock (BulletXScene.BulletXLock)
678 {
679 //Static objects don' have linear velocity
680 if (_physical)
681 {
682 _velocity = value;
683 Speed();
684 }
685 else
686 {
687 _velocity = new PhysicsVector();
688 }
689 }
690 }
691 }
692 public override PhysicsVector Size
693 {
694 get
695 {
696 return _size;
697 }
698 set
699 {
700 lock (BulletXScene.BulletXLock)
701 {
702 _size = value;
703 }
704 }
705 }
706 public override PhysicsVector Acceleration
707 {
708 get
709 {
710 return _acceleration;
711 }
712 }
713 public override AxiomQuaternion Orientation
714 {
715 get
716 {
717 return _orientation;
718 }
719 set
720 {
721 lock (BulletXScene.BulletXLock)
722 {
723 _orientation = value;
724 ReOrient();
725 }
726 }
727 }
728 public virtual float Mass
729 { get { return 0; } }
730 public RigidBody RigidBody
731 {
732 get
733 {
734 return rigidBody;
735 }
736 }
737 public MonoXnaCompactMaths.Vector3 RigidBodyPosition
738 {
739 get { return this.rigidBody.CenterOfMassPosition; }
740 }
741 public override bool Flying
742 {
743 get
744 {
745 return flying;
746 }
747 set
748 {
749 flying = value;
750 }
751 }
752 public override bool IsColliding
753 {
754 get { return iscolliding; }
755 set { iscolliding = value; }
756 }
757 /*public override bool Physical
758 {
759 get
760 {
761 return _physical;
762 }
763 set
764 {
765 _physical = value;
766 }
767 }*/
768 public virtual void SetAcceleration(PhysicsVector accel)
769 {
770 lock (BulletXScene.BulletXLock)
771 {
772 _acceleration = accel;
773 }
774 }
775 public override bool Kinematic
776 {
777 get
778 {
779 return false;
780 }
781 set
782 {
783
784 }
785 }
786 public override void AddForce(PhysicsVector force)
787 {
648 788
649 public Vector3 RigidBodyPosition 789 }
790 public override void SetMomentum(PhysicsVector momentum)
791 {
792 }
793 internal virtual void ValidateHeight(float heighmapPositionValue)
794 {
795 }
796 internal virtual void UpdateKinetics()
650 { 797 {
651 get { return rigidBody.CenterOfMassPosition; }
652 } 798 }
653 799
800 #region Methods for updating values of RigidBody
801 internal protected void Translate()
802 {
803 Translate(this._position);
804 }
805 internal protected void Translate(PhysicsVector _newPos)
806 {
807 MonoXnaCompactMaths.Vector3 _translation;
808 _translation = BulletXMaths.PhysicsVectorToXnaVector3(_newPos) - rigidBody.CenterOfMassPosition;
809 rigidBody.Translate(_translation);
810 }
811 internal protected void Speed()
812 {
813 Speed(this._velocity);
814 }
815 internal protected void Speed(PhysicsVector _newSpeed)
816 {
817 MonoXnaCompactMaths.Vector3 _speed;
818 _speed = BulletXMaths.PhysicsVectorToXnaVector3(_newSpeed);
819 rigidBody.LinearVelocity = _speed;
820 }
821 internal protected void ReOrient()
822 {
823 ReOrient(this._orientation);
824 }
825 internal protected void ReOrient(AxiomQuaternion _newOrient)
826 {
827 MonoXnaCompactMaths.Quaternion _newOrientation;
828 _newOrientation = BulletXMaths.AxiomQuaternionToXnaQuaternion(_newOrient);
829 Matrix _comTransform = rigidBody.CenterOfMassTransform;
830 BulletXMaths.SetRotation(ref _comTransform, _newOrientation);
831 rigidBody.CenterOfMassTransform = _comTransform;
832 }
833 internal protected void ReSize()
834 {
835 ReSize(this._size);
836 }
837 internal protected virtual void ReSize(PhysicsVector _newSize)
838 {
839 }
840 #endregion
841 }
842
843 /// <summary>
844 /// PhysicsActor Character Class for BulletX
845 /// </summary>
846 public class BulletXCharacter : BulletXActor
847 {
654 public BulletXCharacter(BulletXScene parent_scene, PhysicsVector pos) 848 public BulletXCharacter(BulletXScene parent_scene, PhysicsVector pos)
655 : this("", parent_scene, pos) 849 : this("", parent_scene, pos)
656 { 850 {
657 } 851 }
658
659 public BulletXCharacter(String avName, BulletXScene parent_scene, PhysicsVector pos) 852 public BulletXCharacter(String avName, BulletXScene parent_scene, PhysicsVector pos)
660 : this(avName, parent_scene, pos, new PhysicsVector(), new PhysicsVector(), new PhysicsVector(), 853 : this(avName, parent_scene, pos, new PhysicsVector(), new PhysicsVector(), new PhysicsVector(),
661 AxiomQuaternion.Identity) 854 AxiomQuaternion.Identity)
662 { 855 {
663 } 856 }
664
665 public BulletXCharacter(String avName, BulletXScene parent_scene, PhysicsVector pos, PhysicsVector velocity, 857 public BulletXCharacter(String avName, BulletXScene parent_scene, PhysicsVector pos, PhysicsVector velocity,
666 PhysicsVector size, PhysicsVector acceleration, AxiomQuaternion orientation) 858 PhysicsVector size, PhysicsVector acceleration, AxiomQuaternion orientation)
667 { 859 {
@@ -711,95 +903,55 @@ namespace OpenSim.Region.Physics.BulletXPlugin
711 903
712 public override PhysicsVector Position 904 public override PhysicsVector Position
713 { 905 {
714 get { return _position; } 906 get { return base.Position; }
715 set 907 set { base.Position = value; }
716 {
717 lock (BulletXScene.BulletXLock)
718 {
719 _position = value;
720 Translate();
721 }
722 }
723 } 908 }
724
725 public override PhysicsVector Velocity 909 public override PhysicsVector Velocity
726 { 910 {
727 get { return _velocity; } 911 get { return base.Velocity; }
728 set 912 set { base.Velocity = value; }
729 {
730 lock (BulletXScene.BulletXLock)
731 {
732 _velocity = value;
733 Speed();
734 }
735 }
736 } 913 }
737
738 public override PhysicsVector Size 914 public override PhysicsVector Size
739 { 915 {
740 get { return _size; } 916 get { return base.Size; }
741 set 917 set { base.Size = value; }
742 {
743 lock (BulletXScene.BulletXLock)
744 {
745 _size = value;
746 }
747 }
748 } 918 }
749
750 public override PhysicsVector Acceleration 919 public override PhysicsVector Acceleration
751 { 920 {
752 get { return _acceleration; } 921 get { return base.Acceleration; }
753 } 922 }
754
755 public override AxiomQuaternion Orientation 923 public override AxiomQuaternion Orientation
756 { 924 {
757 get { return _orientation; } 925 get { return base.Orientation; }
758 set 926 set { base.Orientation = value; }
759 {
760 lock (BulletXScene.BulletXLock)
761 {
762 _orientation = value;
763 }
764 }
765 }
766
767 public RigidBody RigidBody
768 {
769 get { return rigidBody; }
770 } 927 }
771
772 public override bool Flying 928 public override bool Flying
773 { 929 {
774 get { return flying; } 930 get { return base.Flying; }
775 set { flying = value; } 931 set { base.Flying = value; }
776 } 932 }
777 public override bool IsColliding 933 public override bool IsColliding
778 { 934 {
779 get { return iscolliding; } 935 get { return base.IsColliding; }
780 set { iscolliding = value; } 936 set { base.IsColliding = value; }
781 } 937 }
782 938 public override bool Kinematic
783 public void SetAcceleration(PhysicsVector accel)
784 { 939 {
785 lock (BulletXScene.BulletXLock) 940 get { return base.Kinematic; }
786 { 941 set { base.Kinematic = value; }
787 _acceleration = accel;
788 }
789 } 942 }
790 943
791 public override bool Kinematic 944 public override void SetAcceleration(PhysicsVector accel)
792 { 945 {
793 get { return false; } 946 base.SetAcceleration(accel);
794 set { }
795 } 947 }
796
797 public override void AddForce(PhysicsVector force) 948 public override void AddForce(PhysicsVector force)
798 { 949 {
950 base.AddForce(force);
799 } 951 }
800
801 public override void SetMomentum(PhysicsVector momentum) 952 public override void SetMomentum(PhysicsVector momentum)
802 { 953 {
954 base.SetMomentum(momentum);
803 } 955 }
804 956
805 internal void Move(float timeStep) 957 internal void Move(float timeStep)
@@ -835,9 +987,8 @@ namespace OpenSim.Region.Physics.BulletXPlugin
835 } 987 }
836 rigidBody.LinearVelocity = vec; 988 rigidBody.LinearVelocity = vec;
837 } 989 }
838
839 //This validation is very basic 990 //This validation is very basic
840 internal void ValidateHeight(float heighmapPositionValue) 991 internal override void ValidateHeight(float heighmapPositionValue)
841 { 992 {
842 if (rigidBody.CenterOfMassPosition.Z < heighmapPositionValue + _size.Z/2.0f) 993 if (rigidBody.CenterOfMassPosition.Z < heighmapPositionValue + _size.Z/2.0f)
843 { 994 {
@@ -850,93 +1001,30 @@ namespace OpenSim.Region.Physics.BulletXPlugin
850 Speed(new PhysicsVector(rigidBody.LinearVelocity.X, rigidBody.LinearVelocity.Y, 0.0f)); 1001 Speed(new PhysicsVector(rigidBody.LinearVelocity.X, rigidBody.LinearVelocity.Y, 0.0f));
851 } 1002 }
852 } 1003 }
853 1004 internal override void UpdateKinetics()
854 internal void UpdateKinetics()
855 { 1005 {
856 _position = BulletXMaths.XnaVector3ToPhysicsVector(rigidBody.CenterOfMassPosition); 1006 _position = BulletXMaths.XnaVector3ToPhysicsVector(rigidBody.CenterOfMassPosition);
857 _velocity = BulletXMaths.XnaVector3ToPhysicsVector(rigidBody.LinearVelocity); 1007 _velocity = BulletXMaths.XnaVector3ToPhysicsVector(rigidBody.LinearVelocity);
858 //Orientation it seems that it will be the default. 1008 //Orientation it seems that it will be the default.
859 ReOrient(); 1009 ReOrient();
860 } 1010 }
861
862 #region Methods for updating values of RigidBody
863
864 private void Translate()
865 {
866 Translate(_position);
867 }
868
869 private void Translate(PhysicsVector _newPos)
870 {
871 Vector3 _translation;
872 _translation = BulletXMaths.PhysicsVectorToXnaVector3(_newPos) - rigidBody.CenterOfMassPosition;
873 rigidBody.Translate(_translation);
874 }
875
876 private void Speed()
877 {
878 Speed(_velocity);
879 }
880
881 private void Speed(PhysicsVector _newSpeed)
882 {
883 Vector3 _speed;
884 _speed = BulletXMaths.PhysicsVectorToXnaVector3(_newSpeed);
885 rigidBody.LinearVelocity = _speed;
886 }
887
888 private void ReOrient()
889 {
890 ReOrient(_orientation);
891 }
892
893 private void ReOrient(AxiomQuaternion _newOrient)
894 {
895 Quaternion _newOrientation;
896 _newOrientation = BulletXMaths.AxiomQuaternionToXnaQuaternion(_newOrient);
897 Matrix _comTransform = rigidBody.CenterOfMassTransform;
898 BulletXMaths.SetRotation(ref _comTransform, _newOrientation);
899 rigidBody.CenterOfMassTransform = _comTransform;
900 }
901
902 #endregion
903 } 1011 }
904 1012
905 /// <summary> 1013 /// <summary>
906 /// PhysicsActor Prim Class for BulletX 1014 /// PhysicsActor Prim Class for BulletX
907 /// </summary> 1015 /// </summary>
908 public class BulletXPrim : PhysicsActor 1016 public class BulletXPrim : BulletXActor
909 { 1017 {
910 private PhysicsVector _position;
911 private PhysicsVector _velocity;
912 private PhysicsVector _size;
913 private PhysicsVector _acceleration;
914 private AxiomQuaternion _orientation;
915 //Density it will depends of material. 1018 //Density it will depends of material.
916 //For now all prims have the same density, all prims are made of water. Be water my friend! :D 1019 //For now all prims have the same density, all prims are made of water. Be water my friend! :D
917 private const float _density = 1000.0f; 1020 private const float _density = 1000.0f;
918 private RigidBody rigidBody;
919 private BulletXScene _parent_scene; 1021 private BulletXScene _parent_scene;
920 //_physical value will be linked with the prim object value
921 private Boolean _physical = false;
922 private Boolean iscolliding = false;
923
924 public Vector3 RigidBodyPosition
925 {
926 get { return rigidBody.CenterOfMassPosition; }
927 }
928
929 public BulletXPrim(BulletXScene parent_scene, PhysicsVector pos, PhysicsVector size, AxiomQuaternion rotation)
930 : this("", parent_scene, pos, new PhysicsVector(), size, new PhysicsVector(), rotation, null, null)
931 {
932 }
933 1022
934 public BulletXPrim(String primName, BulletXScene parent_scene, PhysicsVector pos, PhysicsVector size, 1023 public BulletXPrim(String primName, BulletXScene parent_scene, PhysicsVector pos, PhysicsVector size,
935 AxiomQuaternion rotation, Mesh mesh, PrimitiveBaseShape pbs) 1024 AxiomQuaternion rotation, Mesh mesh, PrimitiveBaseShape pbs)
936 : this(primName, parent_scene, pos, new PhysicsVector(), size, new PhysicsVector(), rotation, mesh, pbs) 1025 : this(primName, parent_scene, pos, new PhysicsVector(), size, new PhysicsVector(), rotation, mesh, pbs)
937 { 1026 {
938 } 1027 }
939
940 public BulletXPrim(String primName, BulletXScene parent_scene, PhysicsVector pos, PhysicsVector velocity, 1028 public BulletXPrim(String primName, BulletXScene parent_scene, PhysicsVector pos, PhysicsVector velocity,
941 PhysicsVector size, 1029 PhysicsVector size,
942 PhysicsVector aceleration, AxiomQuaternion rotation, Mesh mesh, PrimitiveBaseShape pbs) 1030 PhysicsVector aceleration, AxiomQuaternion rotation, Mesh mesh, PrimitiveBaseShape pbs)
@@ -983,41 +1071,20 @@ namespace OpenSim.Region.Physics.BulletXPlugin
983 1071
984 public override PhysicsVector Position 1072 public override PhysicsVector Position
985 { 1073 {
986 get { return _position; } 1074 get { return base.Position; }
987 set 1075 set { base.Position = value; }
988 {
989 lock (BulletXScene.BulletXLock)
990 {
991 _position = value;
992 Translate();
993 }
994 }
995 } 1076 }
996
997 public override PhysicsVector Velocity 1077 public override PhysicsVector Velocity
998 { 1078 {
999 get { return _velocity; } 1079 get { return base.Velocity; }
1000 set 1080 set { base.Velocity = value; }
1001 {
1002 lock (BulletXScene.BulletXLock)
1003 {
1004 //Static objects don' have linear velocity
1005 if (_physical)
1006 {
1007 _velocity = value;
1008 Speed();
1009 }
1010 else
1011 {
1012 _velocity = new PhysicsVector();
1013 }
1014 }
1015 }
1016 } 1081 }
1017
1018 public override PhysicsVector Size 1082 public override PhysicsVector Size
1019 { 1083 {
1020 get { return _size; } 1084 get
1085 {
1086 return _size;
1087 }
1021 set 1088 set
1022 { 1089 {
1023 lock (BulletXScene.BulletXLock) 1090 lock (BulletXScene.BulletXLock)
@@ -1027,87 +1094,86 @@ namespace OpenSim.Region.Physics.BulletXPlugin
1027 } 1094 }
1028 } 1095 }
1029 } 1096 }
1030
1031 public override PhysicsVector Acceleration 1097 public override PhysicsVector Acceleration
1032 { 1098 {
1033 get { return _acceleration; } 1099 get { return base.Acceleration; }
1034 } 1100 }
1035
1036 public override AxiomQuaternion Orientation 1101 public override AxiomQuaternion Orientation
1037 { 1102 {
1038 get { return _orientation; } 1103 get { return base.Orientation; }
1039 set 1104 set { base.Orientation = value; }
1040 {
1041 lock (BulletXScene.BulletXLock)
1042 {
1043 _orientation = value;
1044 ReOrient();
1045 }
1046 }
1047 } 1105 }
1048 1106 public override float Mass
1049 public float Mass
1050 { 1107 {
1051 get 1108 get
1052 { 1109 {
1053 //For now all prims are boxes 1110 //For now all prims are boxes
1054 return (_physical ? 1 : 0)*_density*_size.X*_size.Y*_size.Z; 1111 return (_physical ? 1 : 0) * _density * _size.X * _size.Y * _size.Z;
1055 } 1112 }
1056 } 1113 }
1057 1114 public Boolean Physical
1058 public RigidBody RigidBody
1059 { 1115 {
1060 get { return rigidBody; } 1116 get { return _physical; }
1117 set { _physical = value; }
1061 } 1118 }
1062 1119 /*public override bool Physical
1063 public override bool Flying
1064 { 1120 {
1065 get { return false; //no flying prims for you 1121 get
1122 {
1123 return base.Physical;
1124 }
1125 set
1126 {
1127 base.Physical = value;
1128 if (value)
1129 {
1130 //---
1131 PhysicsPluginManager.PhysicsPluginMessage("Physical - Recreate", true);
1132 //---
1133 ReCreateRigidBody(this._size);
1134 }
1135 else
1136 {
1137 //---
1138 PhysicsPluginManager.PhysicsPluginMessage("Physical - SetMassProps", true);
1139 //---
1140 this.rigidBody.SetMassProps(Mass, new MonoXnaCompactMaths.Vector3());
1141 }
1066 } 1142 }
1067 set { } 1143 }*/
1144 public override bool Flying
1145 {
1146 get { return base.Flying; }
1147 set { base.Flying = value; }
1068 } 1148 }
1069
1070 public override bool IsColliding 1149 public override bool IsColliding
1071 { 1150 {
1072 get { return iscolliding; } 1151 get { return base.IsColliding; }
1073 set { iscolliding = value; } 1152 set { base.IsColliding = value; }
1074 } 1153 }
1075 public Boolean Physical 1154 public override bool Kinematic
1076 { 1155 {
1077 get { return _physical; } 1156 get { return base.Kinematic; }
1078 set { _physical = value; } 1157 set { base.Kinematic = value; }
1079 } 1158 }
1080 1159
1081 public void SetAcceleration(PhysicsVector accel) 1160 public override void SetAcceleration(PhysicsVector accel)
1082 { 1161 {
1083 lock (BulletXScene.BulletXLock) 1162 lock (BulletXScene.BulletXLock)
1084 { 1163 {
1085 _acceleration = accel; 1164 _acceleration = accel;
1086 } 1165 }
1087 } 1166 }
1088
1089 public override bool Kinematic
1090 {
1091 get
1092 {
1093 return false;
1094 //return this._prim.Kinematic;
1095 }
1096 set
1097 {
1098 //this._prim.Kinematic = value;
1099 }
1100 }
1101
1102 public override void AddForce(PhysicsVector force) 1167 public override void AddForce(PhysicsVector force)
1103 { 1168 {
1169 base.AddForce(force);
1104 } 1170 }
1105
1106 public override void SetMomentum(PhysicsVector momentum) 1171 public override void SetMomentum(PhysicsVector momentum)
1107 { 1172 {
1173 base.SetMomentum(momentum);
1108 } 1174 }
1109 1175
1110 internal void ValidateHeight(float heighmapPositionValue) 1176 internal override void ValidateHeight(float heighmapPositionValue)
1111 { 1177 {
1112 if (rigidBody.CenterOfMassPosition.Z < heighmapPositionValue + _size.Z/2.0f) 1178 if (rigidBody.CenterOfMassPosition.Z < heighmapPositionValue + _size.Z/2.0f)
1113 { 1179 {
@@ -1122,8 +1188,7 @@ namespace OpenSim.Region.Physics.BulletXPlugin
1122 Speed(new PhysicsVector(rigidBody.LinearVelocity.X, rigidBody.LinearVelocity.Y, 0.0f)); 1188 Speed(new PhysicsVector(rigidBody.LinearVelocity.X, rigidBody.LinearVelocity.Y, 0.0f));
1123 } 1189 }
1124 } 1190 }
1125 1191 internal override void UpdateKinetics()
1126 internal void UpdateKinetics()
1127 { 1192 {
1128 if (_physical) //Updates properties. Prim updates its properties physically 1193 if (_physical) //Updates properties. Prim updates its properties physically
1129 { 1194 {
@@ -1140,44 +1205,8 @@ namespace OpenSim.Region.Physics.BulletXPlugin
1140 } 1205 }
1141 1206
1142 #region Methods for updating values of RigidBody 1207 #region Methods for updating values of RigidBody
1143 1208 internal protected void CreateRigidBody(BulletXScene parent_scene, PhysicsVector pos, PhysicsVector size)
1144 private void Translate()
1145 { 1209 {
1146 Translate(_position);
1147 }
1148
1149 private void Translate(PhysicsVector _newPos)
1150 {
1151 Vector3 _translation;
1152 _translation = BulletXMaths.PhysicsVectorToXnaVector3(_newPos) - rigidBody.CenterOfMassPosition;
1153 rigidBody.Translate(_translation);
1154 }
1155
1156 private void Speed()
1157 {
1158 Speed(_velocity);
1159 }
1160
1161 private void Speed(PhysicsVector _newSpeed)
1162 {
1163 Vector3 _speed;
1164 _speed = BulletXMaths.PhysicsVectorToXnaVector3(_newSpeed);
1165 rigidBody.LinearVelocity = _speed;
1166 }
1167
1168 private void ReSize()
1169 {
1170 ReSize(_size);
1171 }
1172
1173 private void ReSize(PhysicsVector _newSize)
1174 {
1175 //I wonder to know how to resize with a simple instruction in BulletX. It seems that for now there isn't
1176 //so i have to do it manually. That's recreating rigidbody
1177 Vector3 _newsize;
1178 _newsize = BulletXMaths.PhysicsVectorToXnaVector3(_newSize);
1179 if ((_newsize.X == 0) || (_newsize.Y == 0) || (_newsize.Z == 0)) throw new Exception("Size 0");
1180
1181 //For RigidBody Constructor. The next values might change 1210 //For RigidBody Constructor. The next values might change
1182 float _linearDamping = 0.0f; 1211 float _linearDamping = 0.0f;
1183 float _angularDamping = 0.0f; 1212 float _angularDamping = 0.0f;
@@ -1185,54 +1214,48 @@ namespace OpenSim.Region.Physics.BulletXPlugin
1185 float _restitution = 0.0f; 1214 float _restitution = 0.0f;
1186 Matrix _startTransform = Matrix.Identity; 1215 Matrix _startTransform = Matrix.Identity;
1187 Matrix _centerOfMassOffset = Matrix.Identity; 1216 Matrix _centerOfMassOffset = Matrix.Identity;
1188 RigidBody _tmpRigidBody; 1217 lock (BulletXScene.BulletXLock)
1189 _startTransform.Translation = BulletXMaths.PhysicsVectorToXnaVector3(_position); 1218 {
1190 //For now all prims are boxes 1219 _startTransform.Translation = BulletXMaths.PhysicsVectorToXnaVector3(pos);
1191 CollisionShape _collisionShape = new BoxShape(BulletXMaths.PhysicsVectorToXnaVector3(_newSize)/2.0f); 1220 //For now all prims are boxes
1192 DefaultMotionState _motionState = new DefaultMotionState(_startTransform, _centerOfMassOffset); 1221 CollisionShape _collisionShape = new XnaDevRu.BulletX.BoxShape(BulletXMaths.PhysicsVectorToXnaVector3(size) / 2.0f);
1193 Vector3 _localInertia = new Vector3(); 1222 DefaultMotionState _motionState = new DefaultMotionState(_startTransform, _centerOfMassOffset);
1194 if (_physical) _collisionShape.CalculateLocalInertia(Mass, out _localInertia); //Always when mass > 0 1223 MonoXnaCompactMaths.Vector3 _localInertia = new MonoXnaCompactMaths.Vector3();
1195 _tmpRigidBody = 1224 if (_physical) _collisionShape.CalculateLocalInertia(Mass, out _localInertia); //Always when mass > 0
1196 new RigidBody(Mass, _motionState, _collisionShape, _localInertia, _linearDamping, _angularDamping, 1225 rigidBody = new RigidBody(Mass, _motionState, _collisionShape, _localInertia, _linearDamping, _angularDamping, _friction, _restitution);
1197 _friction, _restitution); 1226 //rigidBody.ActivationState = ActivationState.DisableDeactivation;
1198 //rigidBody.ActivationState = ActivationState.DisableDeactivation; 1227 //It's seems that there are a bug with rigidBody constructor and its CenterOfMassPosition
1199 //It's seems that there are a bug with rigidBody constructor and its CenterOfMassPosition 1228 MonoXnaCompactMaths.Vector3 _vDebugTranslation;
1200 Vector3 _vDebugTranslation; 1229 _vDebugTranslation = _startTransform.Translation - rigidBody.CenterOfMassPosition;
1201 _vDebugTranslation = _startTransform.Translation - rigidBody.CenterOfMassPosition; 1230 rigidBody.Translate(_vDebugTranslation);
1202 _tmpRigidBody.Translate(_vDebugTranslation); 1231 //---
1203 //--- 1232 parent_scene.ddWorld.AddRigidBody(rigidBody);
1233 }
1234 }
1235 internal protected void ReCreateRigidBody(PhysicsVector size)
1236 {
1204 //There is a bug when trying to remove a rigidBody that is colliding with something.. 1237 //There is a bug when trying to remove a rigidBody that is colliding with something..
1205 try 1238 try
1206 { 1239 {
1207 _parent_scene.ddWorld.RemoveRigidBody(rigidBody); 1240 this._parent_scene.ddWorld.RemoveRigidBody(rigidBody);
1208 } 1241 }
1209 catch (Exception ex) 1242 catch (Exception ex)
1210 { 1243 {
1211 _parent_scene.BulletXMessage(_parent_scene.is_ex_message + ex.Message, true); 1244 this._parent_scene.BulletXMessage(this._parent_scene.is_ex_message + ex.Message, true);
1212 rigidBody.ActivationState = ActivationState.DisableSimulation; 1245 rigidBody.ActivationState = ActivationState.DisableSimulation;
1213 _parent_scene.AddForgottenRigidBody(rigidBody); 1246 this._parent_scene.AddForgottenRigidBody(rigidBody);
1214 } 1247 }
1215 rigidBody = _tmpRigidBody; 1248 CreateRigidBody(this._parent_scene, this._position, size);
1216 _parent_scene.ddWorld.AddRigidBody(rigidBody); 1249 if (_physical) Speed();//Static objects don't have linear velocity
1217 if (_physical) Speed(); //Static objects don't have linear velocity
1218 ReOrient(); 1250 ReOrient();
1219 GC.Collect(); 1251 GC.Collect();
1220 } 1252 }
1221 1253 internal protected override void ReSize(PhysicsVector _newSize)
1222 private void ReOrient()
1223 {
1224 ReOrient(_orientation);
1225 }
1226
1227 private void ReOrient(AxiomQuaternion _newOrient)
1228 { 1254 {
1229 Quaternion _newOrientation; 1255 //I wonder to know how to resize with a simple instruction in BulletX. It seems that for now there isn't
1230 _newOrientation = BulletXMaths.AxiomQuaternionToXnaQuaternion(_newOrient); 1256 //so i have to do it manually. That's recreating rigidbody
1231 Matrix _comTransform = rigidBody.CenterOfMassTransform; 1257 ReCreateRigidBody(_newSize);
1232 BulletXMaths.SetRotation(ref _comTransform, _newOrientation);
1233 rigidBody.CenterOfMassTransform = _comTransform;
1234 } 1258 }
1235
1236 #endregion 1259 #endregion
1237 } 1260 }
1238 1261