diff --git a/OpenSim/Region/Environment/Scenes/Scene.cs b/OpenSim/Region/Environment/Scenes/Scene.cs index f674ce2982..cdf6788391 100644 --- a/OpenSim/Region/Environment/Scenes/Scene.cs +++ b/OpenSim/Region/Environment/Scenes/Scene.cs @@ -883,6 +883,15 @@ namespace OpenSim.Region.Environment.Scenes return false; } + public void SendKillObject(uint localID) + { + List avatars = this.RequestAvatarList(); + for (int i = 0; i < avatars.Count; i++) + { + avatars[i].ControllingClient.SendKillObject(this.m_regionHandle, localID); + } + } + public void SendAllSceneObjectsToClient(IClientAPI client) { foreach (EntityBase ent in Entities.Values) diff --git a/OpenSim/Region/Environment/Scenes/ScenePresence.cs b/OpenSim/Region/Environment/Scenes/ScenePresence.cs index 73e9d481b4..47f991c932 100644 --- a/OpenSim/Region/Environment/Scenes/ScenePresence.cs +++ b/OpenSim/Region/Environment/Scenes/ScenePresence.cs @@ -461,8 +461,11 @@ namespace OpenSim.Region.Environment.Scenes this.SendFullUpdateToOtherClient(avatar); if (avatar.LocalId != this.LocalId) { - avatar.SendFullUpdateToOtherClient(this); - avatar.SendAppearanceToOtherAgent(this); + if (!avatar.childAgent) + { + avatar.SendFullUpdateToOtherClient(this); + avatar.SendAppearanceToOtherAgent(this); + } } } } @@ -479,8 +482,8 @@ namespace OpenSim.Region.Environment.Scenes this.newAvatar = false; } - // this.SendFullUpdateToALLClients(); - // this.SendArrearanceToAllOtherAgents(); + this.SendFullUpdateToALLClients(); + this.SendArrearanceToAllOtherAgents(); } /// @@ -491,8 +494,8 @@ namespace OpenSim.Region.Environment.Scenes { this.ControllingClient.SendWearables(this.Wearables); - this.SendFullUpdateToALLClients(); - this.SendArrearanceToAllOtherAgents(); + //this.SendFullUpdateToALLClients(); + //this.SendArrearanceToAllOtherAgents(); this.m_scene.SendAllSceneObjectsToClient(this.ControllingClient); this.ControllingClient.SendViewerTime(this.m_scene.TimePhase); @@ -638,6 +641,7 @@ namespace OpenSim.Region.Environment.Scenes string capsPath = Util.GetCapsURL(this.ControllingClient.AgentId); this.ControllingClient.CrossRegion(neighbourHandle, newpos, vel, neighbourRegion.ExternalEndPoint, capsPath); this.MakeChildAgent(); + this.m_scene.SendKillObject(this.m_localId); } } }