123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137 |
- using System;
- using OpenMetaverse;
- using OpenSim.Framework;
- using OpenSim.Region.CoreModules.Avatar.Attachments;
- using OpenSim.Region.CoreModules.Avatar.Gods;
- using OpenSim.Region.Framework.Interfaces;
- using OpenSim.Region.Framework.Scenes;
- namespace OpenSim.Region.RegionCombinerModule
- {
- public class RegionCombinerIndividualEventForwarder
- {
- private Scene m_rootScene;
- private Scene m_virtScene;
- public RegionCombinerIndividualEventForwarder(Scene rootScene, Scene virtScene)
- {
- m_rootScene = rootScene;
- m_virtScene = virtScene;
- }
- public void ClientConnect(IClientAPI client)
- {
- m_virtScene.UnSubscribeToClientPrimEvents(client);
- m_virtScene.UnSubscribeToClientPrimRezEvents(client);
- m_virtScene.UnSubscribeToClientInventoryEvents(client);
- ((AttachmentsModule)m_virtScene.AttachmentsModule).UnsubscribeFromClientEvents(client);
-
- m_virtScene.UnSubscribeToClientScriptEvents(client);
-
- IGodsModule virtGodsModule = m_virtScene.RequestModuleInterface<IGodsModule>();
- if (virtGodsModule != null)
- ((GodsModule)virtGodsModule).UnsubscribeFromClientEvents(client);
-
- m_virtScene.UnSubscribeToClientNetworkEvents(client);
- m_rootScene.SubscribeToClientPrimEvents(client);
- client.OnAddPrim += LocalAddNewPrim;
- client.OnRezObject += LocalRezObject;
-
- m_rootScene.SubscribeToClientInventoryEvents(client);
- ((AttachmentsModule)m_rootScene.AttachmentsModule).SubscribeToClientEvents(client);
-
- m_rootScene.SubscribeToClientScriptEvents(client);
-
- IGodsModule rootGodsModule = m_virtScene.RequestModuleInterface<IGodsModule>();
- if (rootGodsModule != null)
- ((GodsModule)rootGodsModule).UnsubscribeFromClientEvents(client);
-
- m_rootScene.SubscribeToClientNetworkEvents(client);
- }
- public void ClientClosed(UUID clientid, Scene scene)
- {
- }
-
-
-
-
-
-
-
-
-
-
-
-
-
- private void LocalRezObject(IClientAPI remoteclient, UUID itemid, Vector3 rayend, Vector3 raystart,
- UUID raytargetid, byte bypassraycast, bool rayendisintersection, bool rezselected, bool removeitem,
- UUID fromtaskid)
- {
- int differenceX = (int)m_virtScene.RegionInfo.RegionLocX - (int)m_rootScene.RegionInfo.RegionLocX;
- int differenceY = (int)m_virtScene.RegionInfo.RegionLocY - (int)m_rootScene.RegionInfo.RegionLocY;
- rayend.X += differenceX * (int)Constants.RegionSize;
- rayend.Y += differenceY * (int)Constants.RegionSize;
- raystart.X += differenceX * (int)Constants.RegionSize;
- raystart.Y += differenceY * (int)Constants.RegionSize;
- m_rootScene.RezObject(remoteclient, itemid, rayend, raystart, raytargetid, bypassraycast,
- rayendisintersection, rezselected, removeitem, fromtaskid);
- }
-
-
-
-
-
-
-
-
-
-
-
-
- private void LocalAddNewPrim(UUID ownerid, UUID groupid, Vector3 rayend, Quaternion rot,
- PrimitiveBaseShape shape, byte bypassraycast, Vector3 raystart, UUID raytargetid,
- byte rayendisintersection)
- {
- int differenceX = (int)m_virtScene.RegionInfo.RegionLocX - (int)m_rootScene.RegionInfo.RegionLocX;
- int differenceY = (int)m_virtScene.RegionInfo.RegionLocY - (int)m_rootScene.RegionInfo.RegionLocY;
- rayend.X += differenceX * (int)Constants.RegionSize;
- rayend.Y += differenceY * (int)Constants.RegionSize;
- raystart.X += differenceX * (int)Constants.RegionSize;
- raystart.Y += differenceY * (int)Constants.RegionSize;
- m_rootScene.AddNewPrim(ownerid, groupid, rayend, rot, shape, bypassraycast, raystart, raytargetid,
- rayendisintersection);
- }
- }
- }
|