Update teleport routing to match Avination
							parent
							
								
									37fc19fae0
								
							
						
					
					
						commit
						44cde8d5c6
					
				|  | @ -892,6 +892,8 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                 pos.Y = crossedBorder.BorderLine.Z - 1; |                 pos.Y = crossedBorder.BorderLine.Z - 1; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  |             CheckAndAdjustLandingPoint(ref pos); | ||||||
|  | 
 | ||||||
|             if (pos.X < 0f || pos.Y < 0f || pos.Z < 0f) |             if (pos.X < 0f || pos.Y < 0f || pos.Z < 0f) | ||||||
|             { |             { | ||||||
|                 m_log.WarnFormat( |                 m_log.WarnFormat( | ||||||
|  | @ -1056,6 +1058,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             bool isFlying = Flying; |             bool isFlying = Flying; | ||||||
|             RemoveFromPhysicalScene(); |             RemoveFromPhysicalScene(); | ||||||
|             Velocity = Vector3.Zero; |             Velocity = Vector3.Zero; | ||||||
|  |             CheckLandingPoint(ref pos); | ||||||
|             AbsolutePosition = pos; |             AbsolutePosition = pos; | ||||||
|             AddToPhysicalScene(isFlying); |             AddToPhysicalScene(isFlying); | ||||||
| 
 | 
 | ||||||
|  | @ -1066,6 +1069,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|         { |         { | ||||||
|             bool isFlying = Flying; |             bool isFlying = Flying; | ||||||
|             RemoveFromPhysicalScene(); |             RemoveFromPhysicalScene(); | ||||||
|  |             CheckLandingPoint(ref pos); | ||||||
|             AbsolutePosition = pos; |             AbsolutePosition = pos; | ||||||
|             AddToPhysicalScene(isFlying); |             AddToPhysicalScene(isFlying); | ||||||
| 
 | 
 | ||||||
|  | @ -1181,22 +1185,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
| 
 | 
 | ||||||
|             Vector3 look = Velocity; |             Vector3 look = Velocity; | ||||||
| 
 | 
 | ||||||
|             // Place avatar according to parcel owner teleport routing... |  | ||||||
|             ILandObject land = Scene.LandChannel.GetLandObject(AbsolutePosition.X, AbsolutePosition.Y); |  | ||||||
| 
 |  | ||||||
|             if (land != null) |  | ||||||
|             { |  | ||||||
|                 // Land owner should be able to land anywhere, others honor settings |  | ||||||
|                 if (land.LandData.OwnerID != client.AgentId) |  | ||||||
|                 { |  | ||||||
|                     if (land.LandData.LandingType == (byte)1 && land.LandData.UserLocation != Vector3.Zero) |  | ||||||
|                     { |  | ||||||
|                         AbsolutePosition = land.LandData.UserLocation; |  | ||||||
|                         look = land.LandData.UserLookAt; |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             if ((look.X == 0) && (look.Y == 0) && (look.Z == 0)) |             if ((look.X == 0) && (look.Y == 0) && (look.Z == 0)) | ||||||
|             { |             { | ||||||
|                 look = new Vector3(0.99f, 0.042f, 0); |                 look = new Vector3(0.99f, 0.042f, 0); | ||||||
|  | @ -3820,5 +3808,59 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                 m_reprioritization_called = false; |                 m_reprioritization_called = false; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|  |         private void CheckLandingPoint(ref Vector3 pos) | ||||||
|  |         { | ||||||
|  |             // Never constrain lures | ||||||
|  |             if ((TeleportFlags & TeleportFlags.ViaLure) != 0) | ||||||
|  |                 return; | ||||||
|  | 
 | ||||||
|  |             if (m_scene.RegionInfo.EstateSettings.AllowDirectTeleport) | ||||||
|  |                 return; | ||||||
|  | 
 | ||||||
|  |             ILandObject land = m_scene.LandChannel.GetLandObject(pos.X, pos.Y); | ||||||
|  | 
 | ||||||
|  |             if (land.LandData.LandingType == (byte)LandingType.LandingPoint && | ||||||
|  |                 land.LandData.UserLocation != Vector3.Zero && | ||||||
|  |                 land.LandData.OwnerID != m_uuid && | ||||||
|  |                 (!m_scene.Permissions.IsGod(m_uuid)) && | ||||||
|  |                 (!m_scene.RegionInfo.EstateSettings.IsEstateManager(m_uuid))) | ||||||
|  |             { | ||||||
|  |                 float curr = Vector3.Distance(AbsolutePosition, pos); | ||||||
|  |                 if (Vector3.Distance(land.LandData.UserLocation, pos) < curr) | ||||||
|  |                     pos = land.LandData.UserLocation; | ||||||
|  |                 else | ||||||
|  |                     ControllingClient.SendAlertMessage("Can't teleport closer to destination"); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         private void CheckAndAdjustLandingPoint(ref Vector3 pos) | ||||||
|  |         { | ||||||
|  |             ILandObject land = m_scene.LandChannel.GetLandObject(pos.X, pos.Y); | ||||||
|  |             if (land != null) | ||||||
|  |             { | ||||||
|  |                 // If we come in via login, landmark or map, we want to | ||||||
|  |                 // honor landing points. If we come in via Lure, we want | ||||||
|  |                 // to ignore them. | ||||||
|  |                 if ((m_teleportFlags & (TeleportFlags.ViaLogin | TeleportFlags.ViaRegionID)) == (TeleportFlags.ViaLogin | TeleportFlags.ViaRegionID) || | ||||||
|  |                     (m_teleportFlags & TeleportFlags.ViaLandmark) != 0 || | ||||||
|  |                     (m_teleportFlags & TeleportFlags.ViaLocation) != 0) | ||||||
|  |                 { | ||||||
|  |                     // Don't restrict gods, estate managers, or land owners to | ||||||
|  |                     // the TP point. This behaviour mimics agni. | ||||||
|  |                     if (land.LandData.LandingType == (byte)LandingType.LandingPoint && | ||||||
|  |                         land.LandData.UserLocation != Vector3.Zero && | ||||||
|  |                         GodLevel < 200 && | ||||||
|  |                         ((land.LandData.OwnerID != m_uuid && | ||||||
|  |                         (!m_scene.Permissions.IsGod(m_uuid)) && | ||||||
|  |                         (!m_scene.RegionInfo.EstateSettings.IsEstateManager(m_uuid))) || (m_teleportFlags & TeleportFlags.ViaLocation) != 0)) | ||||||
|  |                     { | ||||||
|  |                         pos = land.LandData.UserLocation; | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 land.SendLandUpdateToClient(ControllingClient); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 Melanie
						Melanie