aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim')
-rw-r--r--OpenSim/Region/Framework/Scenes/SceneObjectPart.cs20
-rw-r--r--OpenSim/Region/Framework/Scenes/ScenePresence.cs324
-rw-r--r--OpenSim/Region/Physics/UbitOdePlugin/ODECharacter.cs1
3 files changed, 173 insertions, 172 deletions
diff --git a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
index 2852c4b..a57e9bc 100644
--- a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
+++ b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
@@ -2495,21 +2495,21 @@ namespace OpenSim.Region.Framework.Scenes
2495 { 2495 {
2496 } 2496 }
2497 2497
2498 private bool CollisionFilteredOut(SceneObjectPart dest, UUID objectID, string objectName) 2498 public bool CollisionFilteredOut(UUID objectID, string objectName)
2499 { 2499 {
2500 if(dest.CollisionFilter.Count == 0) 2500 if(CollisionFilter.Count == 0)
2501 return false; 2501 return false;
2502 2502
2503 if (dest.CollisionFilter.ContainsValue(objectID.ToString()) || 2503 if (CollisionFilter.ContainsValue(objectID.ToString()) ||
2504 dest.CollisionFilter.ContainsValue(objectID.ToString() + objectName) || 2504 CollisionFilter.ContainsValue(objectID.ToString() + objectName) ||
2505 dest.CollisionFilter.ContainsValue(UUID.Zero.ToString() + objectName)) 2505 CollisionFilter.ContainsValue(UUID.Zero.ToString() + objectName))
2506 { 2506 {
2507 if (dest.CollisionFilter.ContainsKey(1)) 2507 if (CollisionFilter.ContainsKey(1))
2508 return false; 2508 return false;
2509 return true; 2509 return true;
2510 } 2510 }
2511 2511
2512 if (dest.CollisionFilter.ContainsKey(1)) 2512 if (CollisionFilter.ContainsKey(1))
2513 return true; 2513 return true;
2514 2514
2515 return false; 2515 return false;
@@ -2572,7 +2572,7 @@ namespace OpenSim.Region.Framework.Scenes
2572 SceneObjectPart obj = ParentGroup.Scene.GetSceneObjectPart(localId); 2572 SceneObjectPart obj = ParentGroup.Scene.GetSceneObjectPart(localId);
2573 if (obj != null) 2573 if (obj != null)
2574 { 2574 {
2575 if (!dest.CollisionFilteredOut(this, obj.UUID, obj.Name)) 2575 if (!dest.CollisionFilteredOut(obj.UUID, obj.Name))
2576 colliding.Add(CreateDetObject(obj)); 2576 colliding.Add(CreateDetObject(obj));
2577 } 2577 }
2578 else 2578 else
@@ -2580,7 +2580,7 @@ namespace OpenSim.Region.Framework.Scenes
2580 ScenePresence av = ParentGroup.Scene.GetScenePresence(localId); 2580 ScenePresence av = ParentGroup.Scene.GetScenePresence(localId);
2581 if (av != null && (!av.IsChildAgent)) 2581 if (av != null && (!av.IsChildAgent))
2582 { 2582 {
2583 if (!dest.CollisionFilteredOut(this, av.UUID, av.Name)) 2583 if (!dest.CollisionFilteredOut(av.UUID, av.Name))
2584 colliding.Add(CreateDetObject(av)); 2584 colliding.Add(CreateDetObject(av));
2585 } 2585 }
2586 } 2586 }
@@ -2724,7 +2724,7 @@ namespace OpenSim.Region.Framework.Scenes
2724 2724
2725 SendCollisionEvent(scriptEvents.collision_start, startedColliders, ParentGroup.Scene.EventManager.TriggerScriptCollidingStart); 2725 SendCollisionEvent(scriptEvents.collision_start, startedColliders, ParentGroup.Scene.EventManager.TriggerScriptCollidingStart);
2726 if (!VolumeDetectActive) 2726 if (!VolumeDetectActive)
2727 SendCollisionEvent(scriptEvents.collision , m_lastColliders , ParentGroup.Scene.EventManager.TriggerScriptColliding); 2727 SendCollisionEvent(scriptEvents.collision , m_lastColliders , ParentGroup.Scene.EventManager.TriggerScriptColliding);
2728 SendCollisionEvent(scriptEvents.collision_end , endedColliders , ParentGroup.Scene.EventManager.TriggerScriptCollidingEnd); 2728 SendCollisionEvent(scriptEvents.collision_end , endedColliders , ParentGroup.Scene.EventManager.TriggerScriptCollidingEnd);
2729 2729
2730 if (startedColliders.Contains(0)) 2730 if (startedColliders.Contains(0))
diff --git a/OpenSim/Region/Framework/Scenes/ScenePresence.cs b/OpenSim/Region/Framework/Scenes/ScenePresence.cs
index 5a3b518..e2f32dd 100644
--- a/OpenSim/Region/Framework/Scenes/ScenePresence.cs
+++ b/OpenSim/Region/Framework/Scenes/ScenePresence.cs
@@ -3499,7 +3499,7 @@ namespace OpenSim.Region.Framework.Scenes
3499 3499
3500 RaiseCollisionScriptEvents(coldata); 3500 RaiseCollisionScriptEvents(coldata);
3501 3501
3502 if (Invulnerable) 3502 if (Invulnerable || GodLevel >= 200)
3503 return; 3503 return;
3504 3504
3505 float starthealth = Health; 3505 float starthealth = Health;
@@ -4096,199 +4096,199 @@ namespace OpenSim.Region.Framework.Scenes
4096 } 4096 }
4097 } 4097 }
4098 4098
4099 private void RaiseCollisionScriptEvents(Dictionary<uint, ContactPoint> coldata) 4099 private DetectedObject CreateDetObject(SceneObjectPart obj)
4100 { 4100 {
4101 /* 4101 DetectedObject detobj = new DetectedObject();
4102 lock(m_collisionEventLock) 4102 detobj.keyUUID = obj.UUID;
4103 { 4103 detobj.nameStr = obj.Name;
4104 if (m_collisionEventFlag) 4104 detobj.ownerUUID = obj.OwnerID;
4105 return; 4105 detobj.posVector = obj.AbsolutePosition;
4106 m_collisionEventFlag = true; 4106 detobj.rotQuat = obj.GetWorldRotation();
4107 } 4107 detobj.velVector = obj.Velocity;
4108 detobj.colliderType = 0;
4109 detobj.groupUUID = obj.GroupID;
4108 4110
4109 Util.FireAndForget(delegate(object x) 4111 return detobj;
4112 }
4113
4114 private DetectedObject CreateDetObject(ScenePresence av)
4115 {
4116 DetectedObject detobj = new DetectedObject();
4117 detobj.keyUUID = av.UUID;
4118 detobj.nameStr = av.ControllingClient.Name;
4119 detobj.ownerUUID = av.UUID;
4120 detobj.posVector = av.AbsolutePosition;
4121 detobj.rotQuat = av.Rotation;
4122 detobj.velVector = av.Velocity;
4123 detobj.colliderType = 0;
4124 detobj.groupUUID = av.ControllingClient.ActiveGroupId;
4125
4126 return detobj;
4127 }
4128
4129 private DetectedObject CreateDetObjectForGround()
4130 {
4131 DetectedObject detobj = new DetectedObject();
4132 detobj.keyUUID = UUID.Zero;
4133 detobj.nameStr = "";
4134 detobj.ownerUUID = UUID.Zero;
4135 detobj.posVector = AbsolutePosition;
4136 detobj.rotQuat = Quaternion.Identity;
4137 detobj.velVector = Vector3.Zero;
4138 detobj.colliderType = 0;
4139 detobj.groupUUID = UUID.Zero;
4140
4141 return detobj;
4142 }
4143
4144 private ColliderArgs CreateColliderArgs(SceneObjectPart dest, List<uint> colliders)
4145 {
4146 ColliderArgs colliderArgs = new ColliderArgs();
4147 List<DetectedObject> colliding = new List<DetectedObject>();
4148 foreach (uint localId in colliders)
4110 { 4149 {
4111 */ 4150 if (localId == 0)
4112 try 4151 continue;
4152
4153 SceneObjectPart obj = m_scene.GetSceneObjectPart(localId);
4154 if (obj != null)
4113 { 4155 {
4114 List<uint> thisHitColliders = new List<uint>(); 4156 if (!dest.CollisionFilteredOut(obj.UUID, obj.Name))
4115 List<uint> endedColliders = new List<uint>(); 4157 colliding.Add(CreateDetObject(obj));
4116 List<uint> startedColliders = new List<uint>(); 4158 }
4117 List<CollisionForSoundInfo> soundinfolist = new List<CollisionForSoundInfo>(); 4159 else
4118 CollisionForSoundInfo soundinfo; 4160 {
4119 ContactPoint curcontact; 4161 ScenePresence av = m_scene.GetScenePresence(localId);
4120 4162 if (av != null && (!av.IsChildAgent))
4121 if (coldata.Count == 0)
4122 { 4163 {
4123 if (m_lastColliders.Count == 0) 4164 if (!dest.CollisionFilteredOut(av.UUID, av.Name))
4124 return; // nothing to do 4165 colliding.Add(CreateDetObject(av));
4125
4126 foreach (uint localID in m_lastColliders)
4127 {
4128 endedColliders.Add(localID);
4129 }
4130 m_lastColliders.Clear();
4131 } 4166 }
4167 }
4168 }
4132 4169
4133 else 4170 colliderArgs.Colliders = colliding;
4134 {
4135 foreach (uint id in coldata.Keys)
4136 {
4137 thisHitColliders.Add(id);
4138 if (!m_lastColliders.Contains(id))
4139 {
4140 startedColliders.Add(id);
4141 curcontact = coldata[id];
4142 if (Math.Abs(curcontact.RelativeSpeed) > 0.2)
4143 {
4144 soundinfo = new CollisionForSoundInfo();
4145 soundinfo.colliderID = id;
4146 soundinfo.position = curcontact.Position;
4147 soundinfo.relativeVel = curcontact.RelativeSpeed;
4148 soundinfolist.Add(soundinfo);
4149 }
4150 }
4151 //m_log.Debug("[SCENE PRESENCE]: Collided with:" + localid.ToString() + " at depth of: " + collissionswith[localid].ToString());
4152 }
4153 4171
4154 // calculate things that ended colliding 4172 return colliderArgs;
4155 foreach (uint localID in m_lastColliders) 4173 }
4156 {
4157 if (!thisHitColliders.Contains(localID))
4158 {
4159 endedColliders.Add(localID);
4160 }
4161 }
4162 //add the items that started colliding this time to the last colliders list.
4163 foreach (uint localID in startedColliders)
4164 {
4165 m_lastColliders.Add(localID);
4166 }
4167 // remove things that ended colliding from the last colliders list
4168 foreach (uint localID in endedColliders)
4169 {
4170 m_lastColliders.Remove(localID);
4171 }
4172 4174
4173 if (soundinfolist.Count > 0) 4175 private delegate void ScriptCollidingNotification(uint localID, ColliderArgs message);
4174 CollisionSounds.AvatarCollisionSound(this, soundinfolist);
4175 4176
4176 // do event notification 4177 private void SendCollisionEvent(SceneObjectGroup dest, scriptEvents ev, List<uint> colliders, ScriptCollidingNotification notify)
4177 if (startedColliders.Count > 0) 4178 {
4178 { 4179 ColliderArgs CollidingMessage;
4179 4180
4180 ColliderArgs StartCollidingMessage = new ColliderArgs(); 4181 if (colliders.Count > 0)
4181 List<DetectedObject> colliding = new List<DetectedObject>(); 4182 {
4182 foreach (uint localId in startedColliders) 4183 if ((dest.RootPart.ScriptEvents & ev) != 0)
4183 { 4184 {
4184 if (localId == 0) 4185 CollidingMessage = CreateColliderArgs(dest.RootPart, colliders);
4185 continue;
4186 4186
4187 SceneObjectPart obj = Scene.GetSceneObjectPart(localId); 4187 if (CollidingMessage.Colliders.Count > 0)
4188 string data = ""; 4188 notify(dest.RootPart.LocalId, CollidingMessage);
4189 if (obj != null) 4189 }
4190 { 4190 }
4191 DetectedObject detobj = new DetectedObject(); 4191 }
4192 detobj.keyUUID = obj.UUID;
4193 detobj.nameStr = obj.Name;
4194 detobj.ownerUUID = obj.OwnerID;
4195 detobj.posVector = obj.AbsolutePosition;
4196 detobj.rotQuat = obj.GetWorldRotation();
4197 detobj.velVector = obj.Velocity;
4198 detobj.colliderType = 0;
4199 detobj.groupUUID = obj.GroupID;
4200 colliding.Add(detobj);
4201 }
4202 }
4203 4192
4204 if (colliding.Count > 0) 4193 private void SendLandCollisionEvent(SceneObjectGroup dest, scriptEvents ev, ScriptCollidingNotification notify)
4205 { 4194 {
4206 StartCollidingMessage.Colliders = colliding; 4195 if ((dest.RootPart.ScriptEvents & ev) != 0)
4196 {
4197 ColliderArgs LandCollidingMessage = new ColliderArgs();
4198 List<DetectedObject> colliding = new List<DetectedObject>();
4207 4199
4208 foreach (SceneObjectGroup att in GetAttachments()) 4200 colliding.Add(CreateDetObjectForGround());
4209 Scene.EventManager.TriggerScriptCollidingStart(att.LocalId, StartCollidingMessage); 4201 LandCollidingMessage.Colliders = colliding;
4210 }
4211 }
4212 }
4213 4202
4214 if (endedColliders.Count > 0) 4203 notify(dest.RootPart.LocalId, LandCollidingMessage);
4215 { 4204 }
4216 ColliderArgs EndCollidingMessage = new ColliderArgs(); 4205 }
4217 List<DetectedObject> colliding = new List<DetectedObject>();
4218 foreach (uint localId in endedColliders)
4219 {
4220 if (localId == 0)
4221 continue;
4222 4206
4223 SceneObjectPart obj = Scene.GetSceneObjectPart(localId); 4207 private void RaiseCollisionScriptEvents(Dictionary<uint, ContactPoint> coldata)
4224 string data = ""; 4208 {
4225 if (obj != null) 4209 try
4226 { 4210 {
4227 DetectedObject detobj = new DetectedObject(); 4211 List<uint> thisHitColliders = new List<uint>();
4228 detobj.keyUUID = obj.UUID; 4212 List<uint> endedColliders = new List<uint>();
4229 detobj.nameStr = obj.Name; 4213 List<uint> startedColliders = new List<uint>();
4230 detobj.ownerUUID = obj.OwnerID; 4214 List<CollisionForSoundInfo> soundinfolist = new List<CollisionForSoundInfo>();
4231 detobj.posVector = obj.AbsolutePosition; 4215 CollisionForSoundInfo soundinfo;
4232 detobj.rotQuat = obj.GetWorldRotation(); 4216 ContactPoint curcontact;
4233 detobj.velVector = obj.Velocity;
4234 detobj.colliderType = 0;
4235 detobj.groupUUID = obj.GroupID;
4236 colliding.Add(detobj);
4237 }
4238 }
4239 4217
4240 if (colliding.Count > 0) 4218 if (coldata.Count == 0)
4241 { 4219 {
4242 EndCollidingMessage.Colliders = colliding; 4220 if (m_lastColliders.Count == 0)
4221 return; // nothing to do
4243 4222
4244 foreach (SceneObjectGroup att in GetAttachments()) 4223 foreach (uint localID in m_lastColliders)
4245 Scene.EventManager.TriggerScriptCollidingEnd(att.LocalId, EndCollidingMessage); 4224 {
4246 } 4225 endedColliders.Add(localID);
4247 } 4226 }
4227 m_lastColliders.Clear();
4228 }
4248 4229
4249 if (thisHitColliders.Count > 0) 4230 else
4231 {
4232 foreach (uint id in coldata.Keys)
4250 { 4233 {
4251 ColliderArgs CollidingMessage = new ColliderArgs(); 4234 thisHitColliders.Add(id);
4252 List<DetectedObject> colliding = new List<DetectedObject>(); 4235 if (!m_lastColliders.Contains(id))
4253 foreach (uint localId in thisHitColliders)
4254 { 4236 {
4255 if (localId == 0) 4237 startedColliders.Add(id);
4256 continue; 4238 curcontact = coldata[id];
4257 4239 if (Math.Abs(curcontact.RelativeSpeed) > 0.2)
4258 SceneObjectPart obj = Scene.GetSceneObjectPart(localId);
4259 string data = "";
4260 if (obj != null)
4261 { 4240 {
4262 DetectedObject detobj = new DetectedObject(); 4241 soundinfo = new CollisionForSoundInfo();
4263 detobj.keyUUID = obj.UUID; 4242 soundinfo.colliderID = id;
4264 detobj.nameStr = obj.Name; 4243 soundinfo.position = curcontact.Position;
4265 detobj.ownerUUID = obj.OwnerID; 4244 soundinfo.relativeVel = curcontact.RelativeSpeed;
4266 detobj.posVector = obj.AbsolutePosition; 4245 soundinfolist.Add(soundinfo);
4267 detobj.rotQuat = obj.GetWorldRotation();
4268 detobj.velVector = obj.Velocity;
4269 detobj.colliderType = 0;
4270 detobj.groupUUID = obj.GroupID;
4271 colliding.Add(detobj);
4272 } 4246 }
4273 } 4247 }
4248 //m_log.Debug("[SCENE PRESENCE]: Collided with:" + localid.ToString() + " at depth of: " + collissionswith[localid].ToString());
4249 }
4274 4250
4275 if (colliding.Count > 0) 4251 // calculate things that ended colliding
4252 foreach (uint localID in m_lastColliders)
4253 {
4254 if (!thisHitColliders.Contains(localID))
4276 { 4255 {
4277 CollidingMessage.Colliders = colliding; 4256 endedColliders.Add(localID);
4278
4279 lock (m_attachments)
4280 {
4281 foreach (SceneObjectGroup att in m_attachments)
4282 Scene.EventManager.TriggerScriptColliding(att.LocalId, CollidingMessage);
4283 }
4284 } 4257 }
4285 } 4258 }
4259 //add the items that started colliding this time to the last colliders list.
4260 foreach (uint localID in startedColliders)
4261 {
4262 m_lastColliders.Add(localID);
4263 }
4264 // remove things that ended colliding from the last colliders list
4265 foreach (uint localID in endedColliders)
4266 {
4267 m_lastColliders.Remove(localID);
4268 }
4269
4270 if (soundinfolist.Count > 0)
4271 CollisionSounds.AvatarCollisionSound(this, soundinfolist);
4286 } 4272 }
4287 finally 4273
4274 foreach (SceneObjectGroup att in GetAttachments())
4288 { 4275 {
4289 m_collisionEventFlag = false; 4276 SendCollisionEvent(att, scriptEvents.collision_start, startedColliders, m_scene.EventManager.TriggerScriptCollidingStart);
4277 SendCollisionEvent(att, scriptEvents.collision , m_lastColliders , m_scene.EventManager.TriggerScriptColliding);
4278 SendCollisionEvent(att, scriptEvents.collision_end , endedColliders , m_scene.EventManager.TriggerScriptCollidingEnd);
4279
4280 if (startedColliders.Contains(0))
4281 SendLandCollisionEvent(att, scriptEvents.land_collision_start, m_scene.EventManager.TriggerScriptLandCollidingStart);
4282 if (m_lastColliders.Contains(0))
4283 SendLandCollisionEvent(att, scriptEvents.land_collision, m_scene.EventManager.TriggerScriptLandColliding);
4284 if (endedColliders.Contains(0))
4285 SendLandCollisionEvent(att, scriptEvents.land_collision_end, m_scene.EventManager.TriggerScriptLandCollidingEnd);
4290 } 4286 }
4291// }); 4287 }
4288 finally
4289 {
4290 m_collisionEventFlag = false;
4291 }
4292 } 4292 }
4293 4293
4294 private void TeleportFlagsDebug() { 4294 private void TeleportFlagsDebug() {
diff --git a/OpenSim/Region/Physics/UbitOdePlugin/ODECharacter.cs b/OpenSim/Region/Physics/UbitOdePlugin/ODECharacter.cs
index 093bc3c..6e4e41f 100644
--- a/OpenSim/Region/Physics/UbitOdePlugin/ODECharacter.cs
+++ b/OpenSim/Region/Physics/UbitOdePlugin/ODECharacter.cs
@@ -1118,6 +1118,7 @@ namespace OpenSim.Region.Physics.OdePlugin
1118 if (CollisionEventsThisFrame == null) 1118 if (CollisionEventsThisFrame == null)
1119 CollisionEventsThisFrame = new CollisionEventUpdate(); 1119 CollisionEventsThisFrame = new CollisionEventUpdate();
1120 CollisionEventsThisFrame.AddCollider(CollidedWith, contact); 1120 CollisionEventsThisFrame.AddCollider(CollidedWith, contact);
1121 _parent_scene.AddCollisionEventReporting(this);
1121 } 1122 }
1122 1123
1123 public void SendCollisions() 1124 public void SendCollisions()