aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim')
-rw-r--r--OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs50
-rw-r--r--OpenSim/Region/Framework/Scenes/SceneObjectPart.cs23
2 files changed, 47 insertions, 26 deletions
diff --git a/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs b/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs
index ca6f457..0eed64e 100644
--- a/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs
+++ b/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs
@@ -2929,22 +2929,24 @@ namespace OpenSim.Region.Framework.Scenes
2929 // First move the new group's root SOP's position to be relative to ours 2929 // First move the new group's root SOP's position to be relative to ours
2930 // (radams1: Not sure if the multiple setting of OffsetPosition is required. If not, 2930 // (radams1: Not sure if the multiple setting of OffsetPosition is required. If not,
2931 // this code can be reordered to have a more logical flow.) 2931 // this code can be reordered to have a more logical flow.)
2932 linkPart.OffsetPosition = linkPart.GroupPosition - AbsolutePosition; 2932 linkPart.setOffsetPosition(linkPart.GroupPosition - AbsolutePosition);
2933 // Assign the new parent to the root of the old group 2933 // Assign the new parent to the root of the old group
2934 linkPart.ParentID = m_rootPart.LocalId; 2934 linkPart.ParentID = m_rootPart.LocalId;
2935 // Now that it's a child, it's group position is our root position 2935 // Now that it's a child, it's group position is our root position
2936 linkPart.GroupPosition = AbsolutePosition; 2936 linkPart.setGroupPosition(AbsolutePosition);
2937 2937
2938 Vector3 axPos = linkPart.OffsetPosition;
2939 // Rotate the linking root SOP's position to be relative to the new root prim 2938 // Rotate the linking root SOP's position to be relative to the new root prim
2940 Quaternion parentRot = m_rootPart.RotationOffset; 2939 Quaternion parentRot = m_rootPart.RotationOffset;
2941 axPos *= Quaternion.Conjugate(parentRot);
2942 linkPart.OffsetPosition = axPos;
2943 2940
2944 // Make the linking root SOP's rotation relative to the new root prim 2941 // Make the linking root SOP's rotation relative to the new root prim
2945 Quaternion oldRot = linkPart.RotationOffset; 2942 Quaternion oldRot = linkPart.RotationOffset;
2946 Quaternion newRot = Quaternion.Conjugate(parentRot) * oldRot; 2943 Quaternion newRot = Quaternion.Conjugate(parentRot) * oldRot;
2947 linkPart.RotationOffset = newRot; 2944 linkPart.setRotationOffset(newRot);
2945
2946 Vector3 axPos = linkPart.OffsetPosition;
2947 axPos *= Quaternion.Conjugate(parentRot);
2948 linkPart.OffsetPosition = axPos;
2949
2948 2950
2949 // If there is only one SOP in a SOG, the LinkNum is zero. I.e., not a linkset. 2951 // If there is only one SOP in a SOG, the LinkNum is zero. I.e., not a linkset.
2950 // Now that we know this SOG has at least two SOPs in it, the new root 2952 // Now that we know this SOG has at least two SOPs in it, the new root
@@ -3168,9 +3170,9 @@ namespace OpenSim.Region.Framework.Scenes
3168 linkPart.GroupPosition = AbsolutePosition + linkPart.OffsetPosition; 3170 linkPart.GroupPosition = AbsolutePosition + linkPart.OffsetPosition;
3169 linkPart.OffsetPosition = new Vector3(0, 0, 0); 3171 linkPart.OffsetPosition = new Vector3(0, 0, 0);
3170 */ 3172 */
3171 linkPart.GroupPosition = worldPos; 3173 linkPart.setGroupPosition(worldPos);
3172 linkPart.OffsetPosition = Vector3.Zero; 3174 linkPart.setOffsetPosition(Vector3.Zero);
3173 linkPart.RotationOffset = worldRot; 3175 linkPart.setRotationOffset(worldRot);
3174 3176
3175 // Create a new SOG to go around this unlinked and unattached SOP 3177 // Create a new SOG to go around this unlinked and unattached SOP
3176 SceneObjectGroup objectGroup = new SceneObjectGroup(linkPart); 3178 SceneObjectGroup objectGroup = new SceneObjectGroup(linkPart);
@@ -3221,15 +3223,14 @@ namespace OpenSim.Region.Framework.Scenes
3221 Quaternion parentRot = oldGroupRotation; 3223 Quaternion parentRot = oldGroupRotation;
3222 Quaternion oldRot = part.RotationOffset; 3224 Quaternion oldRot = part.RotationOffset;
3223 3225
3224 // Move our position to not be relative to the old parent 3226 // Move our position in world
3225 Vector3 axPos = part.OffsetPosition; 3227 Vector3 axPos = part.OffsetPosition;
3226 axPos *= parentRot; 3228 axPos *= parentRot;
3227 part.OffsetPosition = axPos; 3229 Vector3 newPos = oldGroupPosition + axPos;
3228 Vector3 newPos = oldGroupPosition + part.OffsetPosition; 3230 part.setGroupPosition(newPos);
3229 part.GroupPosition = newPos; 3231 part.setOffsetPosition(Vector3.Zero);
3230 part.OffsetPosition = Vector3.Zero;
3231 3232
3232 // Compution our rotation to be not relative to the old parent 3233 // Compution our rotation in world
3233 Quaternion worldRot = parentRot * oldRot; 3234 Quaternion worldRot = parentRot * oldRot;
3234 part.RotationOffset = worldRot; 3235 part.RotationOffset = worldRot;
3235 3236
@@ -3237,31 +3238,30 @@ namespace OpenSim.Region.Framework.Scenes
3237 part.SetParent(this); 3238 part.SetParent(this);
3238 part.ParentID = m_rootPart.LocalId; 3239 part.ParentID = m_rootPart.LocalId;
3239 m_parts.Add(part.UUID, part); 3240 m_parts.Add(part.UUID, part);
3240
3241 3241
3242 part.LinkNum = linkNum; 3242 part.LinkNum = linkNum;
3243 3243
3244 m_scene.updateScenePartGroup(part, this); 3244 m_scene.updateScenePartGroup(part, this);
3245 3245
3246 // Compute the new position of this SOP relative to the group position 3246 // Compute the new position of this SOP relative to the group position
3247 part.OffsetPosition = newPos - AbsolutePosition; 3247 part.setOffsetPosition(newPos - AbsolutePosition);
3248 3248
3249 // (radams1 20120711: I don't know why part.OffsetPosition is set multiple times. 3249 // (radams1 20120711: I don't know why part.OffsetPosition is set multiple times.
3250 // It would have the affect of setting the physics engine position multiple 3250 // It would have the affect of setting the physics engine position multiple
3251 // times. In theory, that is not necessary but I don't have a good linkset 3251 // times. In theory, that is not necessary but I don't have a good linkset
3252 // test to know that cleaning up this code wouldn't break things.) 3252 // test to know that cleaning up this code wouldn't break things.)
3253 3253
3254 // Rotate the relative position by the rotation of the group
3255 Quaternion rootRotation = m_rootPart.RotationOffset;
3256 Vector3 pos = part.OffsetPosition;
3257 pos *= Quaternion.Conjugate(rootRotation);
3258 part.OffsetPosition = pos;
3259
3260 // Compute the SOP's rotation relative to the rotation of the group. 3254 // Compute the SOP's rotation relative to the rotation of the group.
3261 parentRot = m_rootPart.RotationOffset; 3255 parentRot = m_rootPart.RotationOffset;
3256
3262 oldRot = part.RotationOffset; 3257 oldRot = part.RotationOffset;
3263 Quaternion newRot = Quaternion.Conjugate(parentRot) * worldRot; 3258 Quaternion newRot = Quaternion.Conjugate(parentRot) * worldRot;
3264 part.RotationOffset = newRot; 3259 part.setRotationOffset(newRot);
3260
3261 Vector3 pos = part.OffsetPosition;
3262 pos *= Quaternion.Conjugate(parentRot);
3263
3264 part.OffsetPosition = pos; // update position and orientation on physics also
3265 3265
3266 // Since this SOP's state has changed, push those changes into the physics engine 3266 // Since this SOP's state has changed, push those changes into the physics engine
3267 // and the simulator. 3267 // and the simulator.
@@ -3947,7 +3947,7 @@ namespace OpenSim.Region.Framework.Scenes
3947 } 3947 }
3948 3948
3949 AbsolutePosition = newPos; 3949 AbsolutePosition = newPos;
3950 3950
3951 if (IsAttachment) 3951 if (IsAttachment)
3952 m_rootPart.AttachedPos = newPos; 3952 m_rootPart.AttachedPos = newPos;
3953 3953
diff --git a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
index 43ae880..de07131 100644
--- a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
+++ b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
@@ -771,9 +771,20 @@ namespace OpenSim.Region.Framework.Scenes
771 set { m_damage = value; } 771 set { m_damage = value; }
772 } 772 }
773 773
774
775
776
777 public void setGroupPosition(Vector3 pos)
778 {
779 m_groupPosition = pos;
780 }
781
774 /// <summary> 782 /// <summary>
775 /// The position of the entire group that this prim belongs to. 783 /// The position of the entire group that this prim belongs to.
776 /// </summary> 784 /// </summary>
785 ///
786
787
777 public Vector3 GroupPosition 788 public Vector3 GroupPosition
778 { 789 {
779 get 790 get
@@ -811,7 +822,7 @@ namespace OpenSim.Region.Framework.Scenes
811 // Root prim actually goes at Position 822 // Root prim actually goes at Position
812 if (ParentID == 0) 823 if (ParentID == 0)
813 { 824 {
814 actor.Position = value; 825 actor.Position = value;
815 } 826 }
816 else 827 else
817 { 828 {
@@ -832,6 +843,11 @@ namespace OpenSim.Region.Framework.Scenes
832 } 843 }
833 } 844 }
834 845
846 public void setOffsetPosition(Vector3 pos)
847 {
848 m_offsetPosition = pos;
849 }
850
835 public Vector3 OffsetPosition 851 public Vector3 OffsetPosition
836 { 852 {
837 get { return m_offsetPosition; } 853 get { return m_offsetPosition; }
@@ -890,6 +906,11 @@ namespace OpenSim.Region.Framework.Scenes
890 } 906 }
891 } 907 }
892 908
909 public void setRotationOffset(Quaternion q)
910 {
911 m_rotationOffset = q;
912 }
913
893 public Quaternion RotationOffset 914 public Quaternion RotationOffset
894 { 915 {
895 get 916 get