aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/Framework
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/Region/Framework/Scenes/EventManager.cs56
-rw-r--r--OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs248
-rw-r--r--OpenSim/Region/Framework/Scenes/SceneObjectPart.cs34
3 files changed, 169 insertions, 169 deletions
diff --git a/OpenSim/Region/Framework/Scenes/EventManager.cs b/OpenSim/Region/Framework/Scenes/EventManager.cs
index 76d5cb6..399379e 100644
--- a/OpenSim/Region/Framework/Scenes/EventManager.cs
+++ b/OpenSim/Region/Framework/Scenes/EventManager.cs
@@ -181,14 +181,14 @@ namespace OpenSim.Region.Framework.Scenes
181 181
182 public delegate void ScriptNotAtTargetEvent(uint localID); 182 public delegate void ScriptNotAtTargetEvent(uint localID);
183 183
184 public event ScriptNotAtTargetEvent OnScriptNotAtTargetEvent; 184 public event ScriptNotAtTargetEvent OnScriptNotAtTargetEvent;
185 185
186 public delegate void ScriptAtRotTargetEvent(uint localID, uint handle, Quaternion targetrot, Quaternion atrot); 186 public delegate void ScriptAtRotTargetEvent(uint localID, uint handle, Quaternion targetrot, Quaternion atrot);
187 187
188 public event ScriptAtRotTargetEvent OnScriptAtRotTargetEvent; 188 public event ScriptAtRotTargetEvent OnScriptAtRotTargetEvent;
189 189
190 public delegate void ScriptNotAtRotTargetEvent(uint localID); 190 public delegate void ScriptNotAtRotTargetEvent(uint localID);
191 191
192 public event ScriptNotAtRotTargetEvent OnScriptNotAtRotTargetEvent; 192 public event ScriptNotAtRotTargetEvent OnScriptNotAtRotTargetEvent;
193 193
194 public delegate void ScriptColliding(uint localID, ColliderArgs colliders); 194 public delegate void ScriptColliding(uint localID, ColliderArgs colliders);
@@ -391,8 +391,8 @@ namespace OpenSim.Region.Framework.Scenes
391 391
392 private ScriptChangedEvent handlerScriptChangedEvent = null; //OnScriptChangedEvent; 392 private ScriptChangedEvent handlerScriptChangedEvent = null; //OnScriptChangedEvent;
393 private ScriptAtTargetEvent handlerScriptAtTargetEvent = null; 393 private ScriptAtTargetEvent handlerScriptAtTargetEvent = null;
394 private ScriptNotAtTargetEvent handlerScriptNotAtTargetEvent = null; 394 private ScriptNotAtTargetEvent handlerScriptNotAtTargetEvent = null;
395 private ScriptAtRotTargetEvent handlerScriptAtRotTargetEvent = null; 395 private ScriptAtRotTargetEvent handlerScriptAtRotTargetEvent = null;
396 private ScriptNotAtRotTargetEvent handlerScriptNotAtRotTargetEvent = null; 396 private ScriptNotAtRotTargetEvent handlerScriptNotAtRotTargetEvent = null;
397 private ClientMovement handlerClientMovement = null; //OnClientMovement; 397 private ClientMovement handlerClientMovement = null; //OnClientMovement;
398 private OnPermissionErrorDelegate handlerPermissionError = null; //OnPermissionError; 398 private OnPermissionErrorDelegate handlerPermissionError = null; //OnPermissionError;
@@ -859,24 +859,24 @@ namespace OpenSim.Region.Framework.Scenes
859 { 859 {
860 handlerScriptNotAtTargetEvent(localID); 860 handlerScriptNotAtTargetEvent(localID);
861 } 861 }
862 } 862 }
863 863
864 public void TriggerAtRotTargetEvent(uint localID, uint handle, Quaternion targetrot, Quaternion currentrot) 864 public void TriggerAtRotTargetEvent(uint localID, uint handle, Quaternion targetrot, Quaternion currentrot)
865 { 865 {
866 handlerScriptAtRotTargetEvent = OnScriptAtRotTargetEvent; 866 handlerScriptAtRotTargetEvent = OnScriptAtRotTargetEvent;
867 if (handlerScriptAtRotTargetEvent != null) 867 if (handlerScriptAtRotTargetEvent != null)
868 { 868 {
869 handlerScriptAtRotTargetEvent(localID, handle, targetrot, currentrot); 869 handlerScriptAtRotTargetEvent(localID, handle, targetrot, currentrot);
870 } 870 }
871 } 871 }
872 872
873 public void TriggerNotAtRotTargetEvent(uint localID) 873 public void TriggerNotAtRotTargetEvent(uint localID)
874 { 874 {
875 handlerScriptNotAtRotTargetEvent = OnScriptNotAtRotTargetEvent; 875 handlerScriptNotAtRotTargetEvent = OnScriptNotAtRotTargetEvent;
876 if (handlerScriptNotAtRotTargetEvent != null) 876 if (handlerScriptNotAtRotTargetEvent != null)
877 { 877 {
878 handlerScriptNotAtRotTargetEvent(localID); 878 handlerScriptNotAtRotTargetEvent(localID);
879 } 879 }
880 } 880 }
881 881
882 public void TriggerRequestChangeWaterHeight(float height) 882 public void TriggerRequestChangeWaterHeight(float height)
diff --git a/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs b/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs
index 8050bf6..ec41ac7 100644
--- a/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs
+++ b/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs
@@ -56,7 +56,7 @@ namespace OpenSim.Region.Framework.Scenes
56 land_collision = 2048, 56 land_collision = 2048,
57 land_collision_end = 4096, 57 land_collision_end = 4096,
58 land_collision_start = 8192, 58 land_collision_start = 8192,
59 at_target = 16384, 59 at_target = 16384,
60 at_rot_target = 16777216, 60 at_rot_target = 16777216,
61 listen = 32768, 61 listen = 32768,
62 money = 65536, 62 money = 65536,
@@ -80,13 +80,13 @@ namespace OpenSim.Region.Framework.Scenes
80 public Vector3 targetPos; 80 public Vector3 targetPos;
81 public float tolerance; 81 public float tolerance;
82 public uint handle; 82 public uint handle;
83 } 83 }
84 84
85 struct scriptRotTarget 85 struct scriptRotTarget
86 { 86 {
87 public Quaternion targetRot; 87 public Quaternion targetRot;
88 public float tolerance; 88 public float tolerance;
89 public uint handle; 89 public uint handle;
90 } 90 }
91 91
92 public delegate void PrimCountTaintedDelegate(); 92 public delegate void PrimCountTaintedDelegate();
@@ -173,13 +173,13 @@ namespace OpenSim.Region.Framework.Scenes
173 protected SceneObjectPart m_rootPart; 173 protected SceneObjectPart m_rootPart;
174 // private Dictionary<UUID, scriptEvents> m_scriptEvents = new Dictionary<UUID, scriptEvents>(); 174 // private Dictionary<UUID, scriptEvents> m_scriptEvents = new Dictionary<UUID, scriptEvents>();
175 175
176 private Dictionary<uint, scriptPosTarget> m_targets = new Dictionary<uint, scriptPosTarget>(); 176 private Dictionary<uint, scriptPosTarget> m_targets = new Dictionary<uint, scriptPosTarget>();
177 private Dictionary<uint, scriptRotTarget> m_rotTargets = new Dictionary<uint, scriptRotTarget>(); 177 private Dictionary<uint, scriptRotTarget> m_rotTargets = new Dictionary<uint, scriptRotTarget>();
178 178
179 private bool m_scriptListens_atTarget = false; 179 private bool m_scriptListens_atTarget = false;
180 private bool m_scriptListens_notAtTarget = false; 180 private bool m_scriptListens_notAtTarget = false;
181 181
182 private bool m_scriptListens_atRotTarget = false; 182 private bool m_scriptListens_atRotTarget = false;
183 private bool m_scriptListens_notAtRotTarget = false; 183 private bool m_scriptListens_notAtRotTarget = false;
184 184
185 internal Dictionary<UUID, string> m_savedScriptState = null; 185 internal Dictionary<UUID, string> m_savedScriptState = null;
@@ -1273,15 +1273,15 @@ namespace OpenSim.Region.Framework.Scenes
1273 lock (m_targets) 1273 lock (m_targets)
1274 m_targets.Clear(); 1274 m_targets.Clear();
1275 m_scene.RemoveGroupTarget(this); 1275 m_scene.RemoveGroupTarget(this);
1276 } 1276 }
1277 m_scriptListens_atRotTarget = ((aggregateScriptEvents & scriptEvents.at_rot_target) != 0); 1277 m_scriptListens_atRotTarget = ((aggregateScriptEvents & scriptEvents.at_rot_target) != 0);
1278 m_scriptListens_notAtRotTarget = ((aggregateScriptEvents & scriptEvents.not_at_rot_target) != 0); 1278 m_scriptListens_notAtRotTarget = ((aggregateScriptEvents & scriptEvents.not_at_rot_target) != 0);
1279 1279
1280 if (!m_scriptListens_atRotTarget && !m_scriptListens_notAtRotTarget) 1280 if (!m_scriptListens_atRotTarget && !m_scriptListens_notAtRotTarget)
1281 { 1281 {
1282 lock (m_rotTargets) 1282 lock (m_rotTargets)
1283 m_rotTargets.Clear(); 1283 m_rotTargets.Clear();
1284 m_scene.RemoveGroupTarget(this); 1284 m_scene.RemoveGroupTarget(this);
1285 } 1285 }
1286 1286
1287 ScheduleGroupForFullUpdate(); 1287 ScheduleGroupForFullUpdate();
@@ -3178,30 +3178,30 @@ namespace OpenSim.Region.Framework.Scenes
3178 } 3178 }
3179 3179
3180 } 3180 }
3181 } 3181 }
3182 public int registerRotTargetWaypoint(Quaternion target, float tolerance) 3182 public int registerRotTargetWaypoint(Quaternion target, float tolerance)
3183 { 3183 {
3184 scriptRotTarget waypoint = new scriptRotTarget(); 3184 scriptRotTarget waypoint = new scriptRotTarget();
3185 waypoint.targetRot = target; 3185 waypoint.targetRot = target;
3186 waypoint.tolerance = tolerance; 3186 waypoint.tolerance = tolerance;
3187 uint handle = m_scene.AllocateLocalId(); 3187 uint handle = m_scene.AllocateLocalId();
3188 waypoint.handle = handle; 3188 waypoint.handle = handle;
3189 lock (m_rotTargets) 3189 lock (m_rotTargets)
3190 { 3190 {
3191 m_rotTargets.Add(handle, waypoint); 3191 m_rotTargets.Add(handle, waypoint);
3192 } 3192 }
3193 m_scene.AddGroupTarget(this); 3193 m_scene.AddGroupTarget(this);
3194 return (int)handle; 3194 return (int)handle;
3195 } 3195 }
3196 3196
3197 public void unregisterRotTargetWaypoint(int handle) 3197 public void unregisterRotTargetWaypoint(int handle)
3198 { 3198 {
3199 lock (m_targets) 3199 lock (m_targets)
3200 { 3200 {
3201 m_rotTargets.Remove((uint)handle); 3201 m_rotTargets.Remove((uint)handle);
3202 if (m_targets.Count == 0) 3202 if (m_targets.Count == 0)
3203 m_scene.RemoveGroupTarget(this); 3203 m_scene.RemoveGroupTarget(this);
3204 } 3204 }
3205 } 3205 }
3206 3206
3207 public int registerTargetWaypoint(Vector3 target, float tolerance) 3207 public int registerTargetWaypoint(Vector3 target, float tolerance)
@@ -3308,85 +3308,85 @@ namespace OpenSim.Region.Framework.Scenes
3308 } 3308 }
3309 } 3309 }
3310 } 3310 }
3311 } 3311 }
3312 if (m_scriptListens_atRotTarget || m_scriptListens_notAtRotTarget) 3312 if (m_scriptListens_atRotTarget || m_scriptListens_notAtRotTarget)
3313 { 3313 {
3314 if (m_rotTargets.Count > 0) 3314 if (m_rotTargets.Count > 0)
3315 { 3315 {
3316 bool at_Rottarget = false; 3316 bool at_Rottarget = false;
3317 Dictionary<uint, scriptRotTarget> atRotTargets = new Dictionary<uint, scriptRotTarget>(); 3317 Dictionary<uint, scriptRotTarget> atRotTargets = new Dictionary<uint, scriptRotTarget>();
3318 lock (m_rotTargets) 3318 lock (m_rotTargets)
3319 { 3319 {
3320 foreach (uint idx in m_rotTargets.Keys) 3320 foreach (uint idx in m_rotTargets.Keys)
3321 { 3321 {
3322 scriptRotTarget target = m_rotTargets[idx]; 3322 scriptRotTarget target = m_rotTargets[idx];
3323 double angle = Math.Acos(target.targetRot.X * m_rootPart.RotationOffset.X + target.targetRot.Y * m_rootPart.RotationOffset.Y + target.targetRot.Z * m_rootPart.RotationOffset.Z + target.targetRot.W * m_rootPart.RotationOffset.W) * 2; 3323 double angle = Math.Acos(target.targetRot.X * m_rootPart.RotationOffset.X + target.targetRot.Y * m_rootPart.RotationOffset.Y + target.targetRot.Z * m_rootPart.RotationOffset.Z + target.targetRot.W * m_rootPart.RotationOffset.W) * 2;
3324 if (angle < 0) angle = -angle; 3324 if (angle < 0) angle = -angle;
3325 if (angle > Math.PI) angle = (Math.PI * 2 - angle); 3325 if (angle > Math.PI) angle = (Math.PI * 2 - angle);
3326 if (angle <= target.tolerance) 3326 if (angle <= target.tolerance)
3327 { 3327 {
3328 // trigger at_rot_target 3328 // trigger at_rot_target
3329 if (m_scriptListens_atRotTarget) 3329 if (m_scriptListens_atRotTarget)
3330 { 3330 {
3331 at_Rottarget = true; 3331 at_Rottarget = true;
3332 scriptRotTarget att = new scriptRotTarget(); 3332 scriptRotTarget att = new scriptRotTarget();
3333 att.targetRot = target.targetRot; 3333 att.targetRot = target.targetRot;
3334 att.tolerance = target.tolerance; 3334 att.tolerance = target.tolerance;
3335 att.handle = target.handle; 3335 att.handle = target.handle;
3336 atRotTargets.Add(idx, att); 3336 atRotTargets.Add(idx, att);
3337 } 3337 }
3338 } 3338 }
3339 } 3339 }
3340 } 3340 }
3341 3341
3342 if (atRotTargets.Count > 0) 3342 if (atRotTargets.Count > 0)
3343 { 3343 {
3344 uint[] localids = new uint[0]; 3344 uint[] localids = new uint[0];
3345 lock (m_parts) 3345 lock (m_parts)
3346 { 3346 {
3347 localids = new uint[m_parts.Count]; 3347 localids = new uint[m_parts.Count];
3348 int cntr = 0; 3348 int cntr = 0;
3349 foreach (SceneObjectPart part in m_parts.Values) 3349 foreach (SceneObjectPart part in m_parts.Values)
3350 { 3350 {
3351 localids[cntr] = part.LocalId; 3351 localids[cntr] = part.LocalId;
3352 cntr++; 3352 cntr++;
3353 } 3353 }
3354 } 3354 }
3355 3355
3356 for (int ctr = 0; ctr < localids.Length; ctr++) 3356 for (int ctr = 0; ctr < localids.Length; ctr++)
3357 { 3357 {
3358 foreach (uint target in atRotTargets.Keys) 3358 foreach (uint target in atRotTargets.Keys)
3359 { 3359 {
3360 scriptRotTarget att = atRotTargets[target]; 3360 scriptRotTarget att = atRotTargets[target];
3361 m_scene.EventManager.TriggerAtRotTargetEvent( 3361 m_scene.EventManager.TriggerAtRotTargetEvent(
3362 localids[ctr], att.handle, att.targetRot, m_rootPart.RotationOffset); 3362 localids[ctr], att.handle, att.targetRot, m_rootPart.RotationOffset);
3363 } 3363 }
3364 } 3364 }
3365 3365
3366 return; 3366 return;
3367 } 3367 }
3368 3368
3369 if (m_scriptListens_notAtRotTarget && !at_Rottarget) 3369 if (m_scriptListens_notAtRotTarget && !at_Rottarget)
3370 { 3370 {
3371 //trigger not_at_target 3371 //trigger not_at_target
3372 uint[] localids = new uint[0]; 3372 uint[] localids = new uint[0];
3373 lock (m_parts) 3373 lock (m_parts)
3374 { 3374 {
3375 localids = new uint[m_parts.Count]; 3375 localids = new uint[m_parts.Count];
3376 int cntr = 0; 3376 int cntr = 0;
3377 foreach (SceneObjectPart part in m_parts.Values) 3377 foreach (SceneObjectPart part in m_parts.Values)
3378 { 3378 {
3379 localids[cntr] = part.LocalId; 3379 localids[cntr] = part.LocalId;
3380 cntr++; 3380 cntr++;
3381 } 3381 }
3382 } 3382 }
3383 3383
3384 for (int ctr = 0; ctr < localids.Length; ctr++) 3384 for (int ctr = 0; ctr < localids.Length; ctr++)
3385 { 3385 {
3386 m_scene.EventManager.TriggerNotAtRotTargetEvent(localids[ctr]); 3386 m_scene.EventManager.TriggerNotAtRotTargetEvent(localids[ctr]);
3387 } 3387 }
3388 } 3388 }
3389 } 3389 }
3390 } 3390 }
3391 } 3391 }
3392 3392
diff --git a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
index 177de47..56b2f13 100644
--- a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
+++ b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
@@ -4078,23 +4078,23 @@ namespace OpenSim.Region.Framework.Scenes
4078 { 4078 {
4079 m_parentGroup.unregisterTargetWaypoint(handle); 4079 m_parentGroup.unregisterTargetWaypoint(handle);
4080 } 4080 }
4081 } 4081 }
4082 4082
4083 public int registerRotTargetWaypoint(Quaternion target, float tolerance) 4083 public int registerRotTargetWaypoint(Quaternion target, float tolerance)
4084 { 4084 {
4085 if (m_parentGroup != null) 4085 if (m_parentGroup != null)
4086 { 4086 {
4087 return m_parentGroup.registerRotTargetWaypoint(target, tolerance); 4087 return m_parentGroup.registerRotTargetWaypoint(target, tolerance);
4088 } 4088 }
4089 return 0; 4089 return 0;
4090 } 4090 }
4091 4091
4092 public void unregisterRotTargetWaypoint(int handle) 4092 public void unregisterRotTargetWaypoint(int handle)
4093 { 4093 {
4094 if (m_parentGroup != null) 4094 if (m_parentGroup != null)
4095 { 4095 {
4096 m_parentGroup.unregisterRotTargetWaypoint(handle); 4096 m_parentGroup.unregisterRotTargetWaypoint(handle);
4097 } 4097 }
4098 } 4098 }
4099 4099
4100 public void SetCameraAtOffset(Vector3 v) 4100 public void SetCameraAtOffset(Vector3 v)