aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/Framework
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/Framework')
-rwxr-xr-xOpenSim/Region/Framework/Scenes/Scene.cs31
-rw-r--r--OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs85
2 files changed, 109 insertions, 7 deletions
diff --git a/OpenSim/Region/Framework/Scenes/Scene.cs b/OpenSim/Region/Framework/Scenes/Scene.cs
index c5b082c..3b9f551 100755
--- a/OpenSim/Region/Framework/Scenes/Scene.cs
+++ b/OpenSim/Region/Framework/Scenes/Scene.cs
@@ -808,6 +808,8 @@ namespace OpenSim.Region.Framework.Scenes
808 private float m_minReprioritizationDistance = 32f; 808 private float m_minReprioritizationDistance = 32f;
809 public bool ObjectsCullingByDistance = false; 809 public bool ObjectsCullingByDistance = false;
810 810
811 private ExpiringCache<UUID, UUID> TeleportTargetsCoolDown = new ExpiringCache<UUID, UUID>();
812
811 public AgentCircuitManager AuthenticateHandler 813 public AgentCircuitManager AuthenticateHandler
812 { 814 {
813 get { return m_authenticateHandler; } 815 get { return m_authenticateHandler; }
@@ -2983,15 +2985,14 @@ namespace OpenSim.Region.Framework.Scenes
2983 // Return 'true' if position inside region. 2985 // Return 'true' if position inside region.
2984 public bool PositionIsInCurrentRegion(Vector3 pos) 2986 public bool PositionIsInCurrentRegion(Vector3 pos)
2985 { 2987 {
2986 bool ret = false; 2988 int xx = (int)pos.X;
2987 int xx = (int)Math.Floor(pos.X); 2989 if (xx < 0 || xx >= RegionInfo.RegionSizeX)
2988 int yy = (int)Math.Floor(pos.Y);
2989 if (xx < 0 || yy < 0)
2990 return false; 2990 return false;
2991 2991
2992 if (xx < RegionInfo.RegionSizeX && yy < RegionInfo.RegionSizeY ) 2992 int yy = (int)pos.Y;
2993 ret = true; 2993 if (yy < 0 || yy >= RegionInfo.RegionSizeX)
2994 return ret; 2994 return false;
2995 return true;
2995 } 2996 }
2996 2997
2997 /// <summary> 2998 /// <summary>
@@ -6526,5 +6527,21 @@ Environment.Exit(1);
6526 6527
6527 m_eventManager.TriggerExtraSettingChanged(this, name, String.Empty); 6528 m_eventManager.TriggerExtraSettingChanged(this, name, String.Empty);
6528 } 6529 }
6530
6531 public bool InTeleportTargetsCoolDown(UUID sourceID, UUID targetID, double timeout)
6532 {
6533 lock(TeleportTargetsCoolDown)
6534 {
6535 UUID lastSource = UUID.Zero;
6536 TeleportTargetsCoolDown.TryGetValue(targetID, out lastSource);
6537 if(lastSource == UUID.Zero)
6538 {
6539 TeleportTargetsCoolDown.Add(targetID, sourceID, timeout);
6540 return false;
6541 }
6542 TeleportTargetsCoolDown.AddOrUpdate(targetID, sourceID, timeout);
6543 return lastSource == sourceID;
6544 }
6545 }
6529 } 6546 }
6530} 6547}
diff --git a/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs b/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs
index 719a5dd..402e5f7 100644
--- a/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs
+++ b/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs
@@ -853,6 +853,91 @@ namespace OpenSim.Region.Framework.Scenes
853 m_log.DebugFormat("[SCENE OBJECT]: Crossing agent {0} {1} completed.", agent.Firstname, agent.Lastname); 853 m_log.DebugFormat("[SCENE OBJECT]: Crossing agent {0} {1} completed.", agent.Firstname, agent.Lastname);
854 } 854 }
855*/ 855*/
856 public void ObjectTeleport(UUID sourceID, Vector3 targetPosition, Quaternion rotation, bool stop)
857 {
858 if(inTransit || IsDeleted || IsAttachmentCheckFull() || IsSelected || Scene == null)
859 return;
860
861 inTransit = true;
862
863 PhysicsActor pa = RootPart.PhysActor;
864 if(pa == null || RootPart.KeyframeMotion != null /*|| m_sittingAvatars.Count == 0*/)
865 {
866 inTransit = false;
867 return;
868 }
869
870 if(Scene.PositionIsInCurrentRegion(targetPosition))
871 {
872 if(Scene.InTeleportTargetsCoolDown(UUID, sourceID, 1.0))
873 {
874 inTransit = false;
875 return;
876 }
877
878 Vector3 curPos = AbsolutePosition;
879 ILandObject curLand = Scene.LandChannel.GetLandObject(curPos.X, curPos.Y);
880 float posX = targetPosition.X;
881 float posY = targetPosition.Y;
882 ILandObject land = Scene.LandChannel.GetLandObject(posX, posY);
883 if(land != null && land != curLand)
884 {
885 if(!Scene.Permissions.CanObjectEnterWithScripts(this, land))
886 {
887 inTransit = false;
888 return;
889 }
890
891 UUID agentID;
892 foreach (ScenePresence av in m_sittingAvatars)
893 {
894 agentID = av.UUID;
895 if(land.IsRestrictedFromLand(agentID) || land.IsBannedFromLand(agentID))
896 {
897 inTransit = false;
898 return;
899 }
900 }
901 }
902
903 if(stop)
904 RootPart.Stop();
905 else
906 {
907 rotation.Normalize();
908 if(Math.Abs(rotation.W) < 0.999)
909 {
910 Quaternion rot = RootPart.RotationOffset;
911 Vector3 vel = RootPart.Velocity;
912 Vector3 avel = RootPart.AngularVelocity;
913 Vector3 acc = RootPart.Acceleration;
914
915 rot *= rotation;
916 vel *= rotation;
917 avel *= rotation;
918 acc *= rotation;
919
920 RootPart.RotationOffset = rot;
921 RootPart.Velocity = vel;
922 RootPart.AngularVelocity = avel;
923 RootPart.Acceleration = acc;
924 }
925 }
926
927 Vector3 s = RootPart.Scale * RootPart.RotationOffset;
928 float h = Scene.GetGroundHeight(posX, posY) + 0.5f * (float)Math.Abs(s.Z) + 0.01f;
929 if(targetPosition.Z < h)
930 targetPosition.Z = h;
931
932 inTransit = false;
933 AbsolutePosition = targetPosition;
934 RootPart.ScheduleTerseUpdate();
935 return;
936 }
937
938 inTransit = false;
939 }
940
856 public override Vector3 Velocity 941 public override Vector3 Velocity
857 { 942 {
858 get { return RootPart.Velocity; } 943 get { return RootPart.Velocity; }