aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region')
-rw-r--r--OpenSim/Region/Framework/Scenes/ScenePresence.cs52
-rw-r--r--OpenSim/Region/PhysicsModules/SharedBase/PhysicsActor.cs25
2 files changed, 70 insertions, 7 deletions
diff --git a/OpenSim/Region/Framework/Scenes/ScenePresence.cs b/OpenSim/Region/Framework/Scenes/ScenePresence.cs
index db21dba..878381d 100644
--- a/OpenSim/Region/Framework/Scenes/ScenePresence.cs
+++ b/OpenSim/Region/Framework/Scenes/ScenePresence.cs
@@ -5429,10 +5429,23 @@ namespace OpenSim.Region.Framework.Scenes
5429 } 5429 }
5430 } 5430 }
5431 5431
5432 CameraData physActor_OnPhysicsRequestingCameraData()
5433 {
5434 return new CameraData
5435 {
5436 Valid = true,
5437 CameraPosition = this.CameraPosition,
5438 CameraRotation = this.CameraRotation,
5439 MouseLook = this.m_mouseLook,
5440 HeadRotation = this.m_headrotation,
5441 BodyRotation = this.m_bodyRot
5442 };
5443 }
5444
5432 public void RegisterControlEventsToScript(int controls, int accept, int pass_on, uint Obj_localID, UUID Script_item_UUID) 5445 public void RegisterControlEventsToScript(int controls, int accept, int pass_on, uint Obj_localID, UUID Script_item_UUID)
5433 { 5446 {
5434 SceneObjectPart p = m_scene.GetSceneObjectPart(Obj_localID); 5447 SceneObjectPart part = m_scene.GetSceneObjectPart(Obj_localID);
5435 if (p == null) 5448 if (part == null)
5436 return; 5449 return;
5437 5450
5438 ControllingClient.SendTakeControls(controls, false, false); 5451 ControllingClient.SendTakeControls(controls, false, false);
@@ -5442,7 +5455,7 @@ namespace OpenSim.Region.Framework.Scenes
5442 obj.ignoreControls = ScriptControlled.CONTROL_ZERO; 5455 obj.ignoreControls = ScriptControlled.CONTROL_ZERO;
5443 obj.eventControls = ScriptControlled.CONTROL_ZERO; 5456 obj.eventControls = ScriptControlled.CONTROL_ZERO;
5444 5457
5445 obj.objectID = p.ParentGroup.UUID; 5458 obj.objectID = part.ParentGroup.UUID;
5446 obj.itemID = Script_item_UUID; 5459 obj.itemID = Script_item_UUID;
5447 if (pass_on == 0 && accept == 0) 5460 if (pass_on == 0 && accept == 0)
5448 { 5461 {
@@ -5470,17 +5483,43 @@ namespace OpenSim.Region.Framework.Scenes
5470 { 5483 {
5471 IgnoredControls &= ~(ScriptControlled)controls; 5484 IgnoredControls &= ~(ScriptControlled)controls;
5472 if (scriptedcontrols.ContainsKey(Script_item_UUID)) 5485 if (scriptedcontrols.ContainsKey(Script_item_UUID))
5473 scriptedcontrols.Remove(Script_item_UUID); 5486 RemoveScriptFromControlNotifications(Script_item_UUID, part);
5474 } 5487 }
5475 else 5488 else
5476 { 5489 {
5477 scriptedcontrols[Script_item_UUID] = obj; 5490 AddScriptToControlNotifications(Script_item_UUID, part, ref obj);
5478 } 5491 }
5479 } 5492 }
5480 5493
5481 ControllingClient.SendTakeControls(controls, pass_on == 1 ? true : false, true); 5494 ControllingClient.SendTakeControls(controls, pass_on == 1 ? true : false, true);
5482 } 5495 }
5483 5496
5497 private void AddScriptToControlNotifications(OpenMetaverse.UUID Script_item_UUID, SceneObjectPart part, ref ScriptControllers obj)
5498 {
5499 scriptedcontrols[Script_item_UUID] = obj;
5500
5501 PhysicsActor physActor = part.ParentGroup.RootPart.PhysActor;
5502 if (physActor != null)
5503 {
5504 physActor.OnPhysicsRequestingCameraData -= physActor_OnPhysicsRequestingCameraData;
5505 physActor.OnPhysicsRequestingCameraData += physActor_OnPhysicsRequestingCameraData;
5506 }
5507 }
5508
5509 private void RemoveScriptFromControlNotifications(OpenMetaverse.UUID Script_item_UUID, SceneObjectPart part)
5510 {
5511 scriptedcontrols.Remove(Script_item_UUID);
5512
5513 if (part != null)
5514 {
5515 PhysicsActor physActor = part.ParentGroup.RootPart.PhysActor;
5516 if (physActor != null)
5517 {
5518 physActor.OnPhysicsRequestingCameraData -= physActor_OnPhysicsRequestingCameraData;
5519 }
5520 }
5521 }
5522
5484 public void HandleForceReleaseControls(IClientAPI remoteClient, UUID agentID) 5523 public void HandleForceReleaseControls(IClientAPI remoteClient, UUID agentID)
5485 { 5524 {
5486 IgnoredControls = ScriptControlled.CONTROL_ZERO; 5525 IgnoredControls = ScriptControlled.CONTROL_ZERO;
@@ -5518,6 +5557,7 @@ namespace OpenSim.Region.Framework.Scenes
5518 public void UnRegisterControlEventsToScript(uint Obj_localID, UUID Script_item_UUID) 5557 public void UnRegisterControlEventsToScript(uint Obj_localID, UUID Script_item_UUID)
5519 { 5558 {
5520 ScriptControllers takecontrols; 5559 ScriptControllers takecontrols;
5560 SceneObjectPart part = m_scene.GetSceneObjectPart(Obj_localID);
5521 5561
5522 lock (scriptedcontrols) 5562 lock (scriptedcontrols)
5523 { 5563 {
@@ -5528,7 +5568,7 @@ namespace OpenSim.Region.Framework.Scenes
5528 ControllingClient.SendTakeControls((int)sctc, false, false); 5568 ControllingClient.SendTakeControls((int)sctc, false, false);
5529 ControllingClient.SendTakeControls((int)sctc, true, false); 5569 ControllingClient.SendTakeControls((int)sctc, true, false);
5530 5570
5531 scriptedcontrols.Remove(Script_item_UUID); 5571 RemoveScriptFromControlNotifications(Script_item_UUID, part);
5532 IgnoredControls = ScriptControlled.CONTROL_ZERO; 5572 IgnoredControls = ScriptControlled.CONTROL_ZERO;
5533 foreach (ScriptControllers scData in scriptedcontrols.Values) 5573 foreach (ScriptControllers scData in scriptedcontrols.Values)
5534 { 5574 {
diff --git a/OpenSim/Region/PhysicsModules/SharedBase/PhysicsActor.cs b/OpenSim/Region/PhysicsModules/SharedBase/PhysicsActor.cs
index 04ccbf0..f140e09 100644
--- a/OpenSim/Region/PhysicsModules/SharedBase/PhysicsActor.cs
+++ b/OpenSim/Region/PhysicsModules/SharedBase/PhysicsActor.cs
@@ -55,6 +55,16 @@ namespace OpenSim.Region.PhysicsModules.SharedBase
55 Absolute 55 Absolute
56 } 56 }
57 57
58 public struct CameraData
59 {
60 public Quaternion CameraRotation;
61 public Vector3 CameraPosition;
62 public bool MouseLook;
63 public bool Valid;
64 public Quaternion HeadRotation;
65 public Quaternion BodyRotation;
66 }
67
58 public struct ContactPoint 68 public struct ContactPoint
59 { 69 {
60 public Vector3 Position; 70 public Vector3 Position;
@@ -159,13 +169,15 @@ namespace OpenSim.Region.PhysicsModules.SharedBase
159 public delegate void RequestTerseUpdate(); 169 public delegate void RequestTerseUpdate();
160 public delegate void CollisionUpdate(EventArgs e); 170 public delegate void CollisionUpdate(EventArgs e);
161 public delegate void OutOfBounds(Vector3 pos); 171 public delegate void OutOfBounds(Vector3 pos);
172 public delegate CameraData GetCameraData();
162 173
163// disable warning: public events 174 // disable warning: public events
164#pragma warning disable 67 175#pragma warning disable 67
165 public event PositionUpdate OnPositionUpdate; 176 public event PositionUpdate OnPositionUpdate;
166 public event VelocityUpdate OnVelocityUpdate; 177 public event VelocityUpdate OnVelocityUpdate;
167 public event OrientationUpdate OnOrientationUpdate; 178 public event OrientationUpdate OnOrientationUpdate;
168 public event RequestTerseUpdate OnRequestTerseUpdate; 179 public event RequestTerseUpdate OnRequestTerseUpdate;
180 public event GetCameraData OnPhysicsRequestingCameraData;
169 181
170 /// <summary> 182 /// <summary>
171 /// Subscribers to this event must synchronously handle the dictionary of collisions received, since the event 183 /// Subscribers to this event must synchronously handle the dictionary of collisions received, since the event
@@ -176,6 +188,17 @@ namespace OpenSim.Region.PhysicsModules.SharedBase
176 public event OutOfBounds OnOutOfBounds; 188 public event OutOfBounds OnOutOfBounds;
177#pragma warning restore 67 189#pragma warning restore 67
178 190
191 public CameraData TryGetCameraData()
192 {
193 GetCameraData handler = OnPhysicsRequestingCameraData;
194 if (handler != null)
195 {
196 return handler();
197 }
198
199 return new CameraData { Valid = false };
200 }
201
179 public static PhysicsActor Null 202 public static PhysicsActor Null
180 { 203 {
181 get { return new NullPhysicsActor(); } 204 get { return new NullPhysicsActor(); }