diff options
author | Adam Frisby | 2009-01-06 15:14:15 +0000 |
---|---|---|
committer | Adam Frisby | 2009-01-06 15:14:15 +0000 |
commit | 79bf2c809615cd67630830db1aaf68bbdd2f6c5f (patch) | |
tree | cb221fb822cd7d0aab9e78b0422ab2374e10ee0d /OpenSim/Region/Environment/Scenes/SceneGraph.cs | |
parent | * refactor: Remove the need to separately pass in the http listener to the sc... (diff) | |
download | opensim-SC-79bf2c809615cd67630830db1aaf68bbdd2f6c5f.zip opensim-SC-79bf2c809615cd67630830db1aaf68bbdd2f6c5f.tar.gz opensim-SC-79bf2c809615cd67630830db1aaf68bbdd2f6c5f.tar.bz2 opensim-SC-79bf2c809615cd67630830db1aaf68bbdd2f6c5f.tar.xz |
* Added three new events to SceneGraph:
- OnObjectCreate
- OnObjectDuplicate
- OnObjectRemove
Diffstat (limited to 'OpenSim/Region/Environment/Scenes/SceneGraph.cs')
-rw-r--r-- | OpenSim/Region/Environment/Scenes/SceneGraph.cs | 23 |
1 files changed, 20 insertions, 3 deletions
diff --git a/OpenSim/Region/Environment/Scenes/SceneGraph.cs b/OpenSim/Region/Environment/Scenes/SceneGraph.cs index 8476344..26fe40a 100644 --- a/OpenSim/Region/Environment/Scenes/SceneGraph.cs +++ b/OpenSim/Region/Environment/Scenes/SceneGraph.cs | |||
@@ -39,6 +39,12 @@ namespace OpenSim.Region.Environment.Scenes | |||
39 | { | 39 | { |
40 | public delegate void PhysicsCrash(); | 40 | public delegate void PhysicsCrash(); |
41 | 41 | ||
42 | public delegate void ObjectDuplicateDelegate(EntityBase original, EntityBase clone); | ||
43 | |||
44 | public delegate void ObjectCreateDelegate(EntityBase obj); | ||
45 | |||
46 | public delegate void ObjectDeleteDelegate(EntityBase obj); | ||
47 | |||
42 | /// <summary> | 48 | /// <summary> |
43 | /// This class used to be called InnerScene and may not yet truly be a SceneGraph. The non scene graph components | 49 | /// This class used to be called InnerScene and may not yet truly be a SceneGraph. The non scene graph components |
44 | /// should be migrated out over time. | 50 | /// should be migrated out over time. |
@@ -52,6 +58,10 @@ namespace OpenSim.Region.Environment.Scenes | |||
52 | protected internal event PhysicsCrash UnRecoverableError; | 58 | protected internal event PhysicsCrash UnRecoverableError; |
53 | private PhysicsCrash handlerPhysicsCrash = null; | 59 | private PhysicsCrash handlerPhysicsCrash = null; |
54 | 60 | ||
61 | public event ObjectDuplicateDelegate OnObjectDuplicate; | ||
62 | public event ObjectCreateDelegate OnObjectCreate; | ||
63 | public event ObjectDeleteDelegate OnObjectRemove; | ||
64 | |||
55 | #endregion | 65 | #endregion |
56 | 66 | ||
57 | #region Fields | 67 | #region Fields |
@@ -288,6 +298,9 @@ namespace OpenSim.Region.Environment.Scenes | |||
288 | if (attachToBackup) | 298 | if (attachToBackup) |
289 | sceneObject.AttachToBackup(); | 299 | sceneObject.AttachToBackup(); |
290 | 300 | ||
301 | if (OnObjectCreate != null) | ||
302 | OnObjectCreate(sceneObject); | ||
303 | |||
291 | return true; | 304 | return true; |
292 | } | 305 | } |
293 | } | 306 | } |
@@ -313,12 +326,12 @@ namespace OpenSim.Region.Environment.Scenes | |||
313 | } | 326 | } |
314 | } | 327 | } |
315 | 328 | ||
316 | 329 | if (OnObjectRemove != null) | |
330 | OnObjectRemove(Entities[uuid]); | ||
317 | 331 | ||
318 | Entities.Remove(uuid); | 332 | Entities.Remove(uuid); |
319 | //SceneObjectGroup part; | 333 | //SceneObjectGroup part; |
320 | //((part.RootPart.Flags & PrimFlags.Physics) == PrimFlags.Physics) | 334 | //((part.RootPart.Flags & PrimFlags.Physics) == PrimFlags.Physics) |
321 | |||
322 | 335 | ||
323 | return true; | 336 | return true; |
324 | } | 337 | } |
@@ -1694,7 +1707,7 @@ namespace OpenSim.Region.Environment.Scenes | |||
1694 | protected internal SceneObjectGroup DuplicateObject(uint originalPrim, Vector3 offset, uint flags, UUID AgentID, UUID GroupID, Quaternion rot) | 1707 | protected internal SceneObjectGroup DuplicateObject(uint originalPrim, Vector3 offset, uint flags, UUID AgentID, UUID GroupID, Quaternion rot) |
1695 | { | 1708 | { |
1696 | //m_log.DebugFormat("[SCENE]: Duplication of object {0} at offset {1} requested by agent {2}", originalPrim, offset, AgentID); | 1709 | //m_log.DebugFormat("[SCENE]: Duplication of object {0} at offset {1} requested by agent {2}", originalPrim, offset, AgentID); |
1697 | 1710 | ||
1698 | List<EntityBase> EntityList = GetEntities(); | 1711 | List<EntityBase> EntityList = GetEntities(); |
1699 | 1712 | ||
1700 | SceneObjectGroup originPrim = null; | 1713 | SceneObjectGroup originPrim = null; |
@@ -1739,6 +1752,10 @@ namespace OpenSim.Region.Environment.Scenes | |||
1739 | 1752 | ||
1740 | // required for physics to update it's position | 1753 | // required for physics to update it's position |
1741 | copy.AbsolutePosition = copy.AbsolutePosition; | 1754 | copy.AbsolutePosition = copy.AbsolutePosition; |
1755 | |||
1756 | if (OnObjectDuplicate != null) | ||
1757 | OnObjectDuplicate(originPrim, copy); | ||
1758 | |||
1742 | return copy; | 1759 | return copy; |
1743 | } | 1760 | } |
1744 | } | 1761 | } |