aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim')
-rw-r--r--OpenSim/Region/Framework/Scenes/ScenePresence.cs34
-rw-r--r--OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs27
2 files changed, 22 insertions, 39 deletions
diff --git a/OpenSim/Region/Framework/Scenes/ScenePresence.cs b/OpenSim/Region/Framework/Scenes/ScenePresence.cs
index 21e2878..a810de2 100644
--- a/OpenSim/Region/Framework/Scenes/ScenePresence.cs
+++ b/OpenSim/Region/Framework/Scenes/ScenePresence.cs
@@ -519,40 +519,6 @@ namespace OpenSim.Region.Framework.Scenes
519 } 519 }
520 } 520 }
521 521
522 // returns offset position relative to root prim of object when siting
523 public Vector3 OffsetPositionToSOGRoot
524 {
525 get
526 {
527 if (ParentPart != null)
528 return ParentPart.OffsetPosition + (m_pos * ParentPart.RotationOffset);
529 else
530 return m_pos;
531 }
532 }
533
534 public Quaternion OffsetRotationToSOGRoot
535 {
536 get
537 {
538 if (ParentPart != null)
539 return ParentPart.RotationOffset * Rotation;
540 else
541 return Rotation;
542 }
543 }
544
545 public Quaternion WorldRotation
546 {
547 get
548 {
549 if (ParentPart != null)
550 return ParentPart.GetWorldRotation() * Rotation;
551 else
552 return Rotation;
553 }
554 }
555
556 /// <summary> 522 /// <summary>
557 /// Current velocity of the avatar. 523 /// Current velocity of the avatar.
558 /// </summary> 524 /// </summary>
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
index b2c21cd..4f6803f 100644
--- a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
+++ b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
@@ -8914,6 +8914,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
8914 // replies as SL wiki 8914 // replies as SL wiki
8915 8915
8916 LSL_List res = new LSL_List(); 8916 LSL_List res = new LSL_List();
8917 SceneObjectPart sitPart = avatar.ParentPart; // most likelly it will be needed
8917 int idx = 0; 8918 int idx = 0;
8918 while (idx < rules.Length) 8919 while (idx < rules.Length)
8919 { 8920 {
@@ -8949,7 +8950,12 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
8949 break; 8950 break;
8950 8951
8951 case (int)ScriptBaseClass.PRIM_ROTATION: 8952 case (int)ScriptBaseClass.PRIM_ROTATION:
8952 Quaternion rot = avatar.WorldRotation; 8953 Quaternion rot = avatar.Rotation;
8954 if (sitPart != null)
8955 {
8956 rot = sitPart.GetWorldRotation() * rot; // apply sit part world rotation
8957 }
8958
8953 res.Add(new LSL_Rotation (rot.X, rot.Y, rot.Z, rot.W)); 8959 res.Add(new LSL_Rotation (rot.X, rot.Y, rot.Z, rot.W));
8954 break; 8960 break;
8955 8961
@@ -9036,7 +9042,6 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
9036 return res; 9042 return res;
9037 face = (int)rules.GetLSLIntegerItem(idx++); 9043 face = (int)rules.GetLSLIntegerItem(idx++);
9038 9044
9039 int fullbright;
9040 if (face == ScriptBaseClass.ALL_SIDES) 9045 if (face == ScriptBaseClass.ALL_SIDES)
9041 { 9046 {
9042 for (face = 0; face < 21; face++) 9047 for (face = 0; face < 21; face++)
@@ -9110,18 +9115,30 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
9110 res.Add(new LSL_Vector(0f,0f,0f)); 9115 res.Add(new LSL_Vector(0f,0f,0f));
9111 res.Add(new LSL_Float(1.0f)); 9116 res.Add(new LSL_Float(1.0f));
9112 break; 9117 break;
9118
9113 case (int)ScriptBaseClass.PRIM_NAME: 9119 case (int)ScriptBaseClass.PRIM_NAME:
9114 res.Add(new LSL_String(avatar.Name)); 9120 res.Add(new LSL_String(avatar.Name));
9115 break; 9121 break;
9122
9116 case (int)ScriptBaseClass.PRIM_DESC: 9123 case (int)ScriptBaseClass.PRIM_DESC:
9117 res.Add(new LSL_String("")); 9124 res.Add(new LSL_String(""));
9118 break; 9125 break;
9119 case (int)ScriptBaseClass.PRIM_ROT_LOCAL: 9126
9120 Quaternion lrot = avatar.OffsetRotationToSOGRoot; 9127 case (int)ScriptBaseClass.PRIM_ROT_LOCAL:
9128 Quaternion lrot = avatar.Rotation;
9129 if (sitPart != null)
9130 {
9131 lrot = sitPart.RotationOffset * lrot; // apply sit part rotation offset
9132 }
9121 res.Add(new LSL_Rotation(lrot.X, lrot.Y, lrot.Z, lrot.W)); 9133 res.Add(new LSL_Rotation(lrot.X, lrot.Y, lrot.Z, lrot.W));
9122 break; 9134 break;
9135
9123 case (int)ScriptBaseClass.PRIM_POS_LOCAL: 9136 case (int)ScriptBaseClass.PRIM_POS_LOCAL:
9124 Vector3 lpos = avatar.OffsetPositionToSOGRoot; 9137 Vector3 lpos = avatar.OffsetPosition; // pos relative to sit part
9138 if (sitPart != null)
9139 {
9140 lpos = sitPart.OffsetPosition + (lpos * sitPart.RotationOffset); // make it relative to root prim
9141 }
9125 res.Add(new LSL_Vector(lpos.X,lpos.Y,lpos.Z)); 9142 res.Add(new LSL_Vector(lpos.X,lpos.Y,lpos.Z));
9126 break; 9143 break;
9127 } 9144 }