diff options
-rw-r--r-- | OpenSim/Region/Framework/Scenes/ScenePresence.cs | 16 |
1 files changed, 9 insertions, 7 deletions
diff --git a/OpenSim/Region/Framework/Scenes/ScenePresence.cs b/OpenSim/Region/Framework/Scenes/ScenePresence.cs index 553e293..6a4675e 100644 --- a/OpenSim/Region/Framework/Scenes/ScenePresence.cs +++ b/OpenSim/Region/Framework/Scenes/ScenePresence.cs | |||
@@ -349,6 +349,7 @@ namespace OpenSim.Region.Framework.Scenes | |||
349 | 349 | ||
350 | protected int m_reprioritizationLastTime; | 350 | protected int m_reprioritizationLastTime; |
351 | protected bool m_reprioritizationBusy; | 351 | protected bool m_reprioritizationBusy; |
352 | protected Vector3 m_reprioritizationLastPosition; | ||
352 | 353 | ||
353 | private Quaternion m_headrotation = Quaternion.Identity; | 354 | private Quaternion m_headrotation = Quaternion.Identity; |
354 | 355 | ||
@@ -522,7 +523,7 @@ namespace OpenSim.Region.Framework.Scenes | |||
522 | /// <summary> | 523 | /// <summary> |
523 | /// Position of agent's camera in world (region cordinates) | 524 | /// Position of agent's camera in world (region cordinates) |
524 | /// </summary> | 525 | /// </summary> |
525 | protected Vector3 m_lastCameraPosition; | 526 | // protected Vector3 m_lastCameraPosition; |
526 | 527 | ||
527 | private Vector4 m_lastCameraCollisionPlane = new Vector4(0f, 0f, 0f, 1); | 528 | private Vector4 m_lastCameraCollisionPlane = new Vector4(0f, 0f, 0f, 1); |
528 | private bool m_doingCamRayCast = false; | 529 | private bool m_doingCamRayCast = false; |
@@ -1028,7 +1029,7 @@ namespace OpenSim.Region.Framework.Scenes | |||
1028 | m_scriptEngines = m_scene.RequestModuleInterfaces<IScriptModule>(); | 1029 | m_scriptEngines = m_scene.RequestModuleInterfaces<IScriptModule>(); |
1029 | 1030 | ||
1030 | AbsolutePosition = posLastMove = posLastSignificantMove = CameraPosition = | 1031 | AbsolutePosition = posLastMove = posLastSignificantMove = CameraPosition = |
1031 | m_lastCameraPosition = ControllingClient.StartPos; | 1032 | m_reprioritizationLastPosition = ControllingClient.StartPos; |
1032 | 1033 | ||
1033 | // disable updates workjobs for now | 1034 | // disable updates workjobs for now |
1034 | childUpdatesBusy = true; | 1035 | childUpdatesBusy = true; |
@@ -2042,7 +2043,8 @@ namespace OpenSim.Region.Framework.Scenes | |||
2042 | if (m_teleportFlags > 0 && !isNPC || m_currentParcelHide) | 2043 | if (m_teleportFlags > 0 && !isNPC || m_currentParcelHide) |
2043 | SendInitialDataToMe(); | 2044 | SendInitialDataToMe(); |
2044 | 2045 | ||
2045 | m_lastCameraPosition = CameraPosition; | 2046 | // priority uses avatar position only |
2047 | m_reprioritizationLastPosition = AbsolutePosition; | ||
2046 | m_reprioritizationLastTime = Util.EnvironmentTickCount() + 15000; // delay it | 2048 | m_reprioritizationLastTime = Util.EnvironmentTickCount() + 15000; // delay it |
2047 | m_reprioritizationBusy = false; | 2049 | m_reprioritizationBusy = false; |
2048 | 2050 | ||
@@ -3879,9 +3881,9 @@ namespace OpenSim.Region.Framework.Scenes | |||
3879 | int tdiff = Util.EnvironmentTickCountSubtract(m_reprioritizationLastTime); | 3881 | int tdiff = Util.EnvironmentTickCountSubtract(m_reprioritizationLastTime); |
3880 | if(tdiff < Scene.ReprioritizationInterval) | 3882 | if(tdiff < Scene.ReprioritizationInterval) |
3881 | return; | 3883 | return; |
3882 | 3884 | // priority uses avatar position | |
3883 | Vector3 pos = CameraPosition; | 3885 | Vector3 pos = AbsolutePosition; |
3884 | Vector3 diff = pos - m_lastCameraPosition; | 3886 | Vector3 diff = pos - m_reprioritizationLastPosition; |
3885 | float limit; | 3887 | float limit; |
3886 | if(IsChildAgent) | 3888 | if(IsChildAgent) |
3887 | limit = (float)Scene.ChildReprioritizationDistance; | 3889 | limit = (float)Scene.ChildReprioritizationDistance; |
@@ -3893,7 +3895,7 @@ namespace OpenSim.Region.Framework.Scenes | |||
3893 | return; | 3895 | return; |
3894 | 3896 | ||
3895 | m_reprioritizationBusy = true; | 3897 | m_reprioritizationBusy = true; |
3896 | m_lastCameraPosition = pos; | 3898 | m_reprioritizationLastPosition = pos; |
3897 | 3899 | ||
3898 | Util.FireAndForget( | 3900 | Util.FireAndForget( |
3899 | o => | 3901 | o => |