diff options
-rw-r--r-- | OpenSim/Region/Framework/Scenes/ScenePresence.cs | 24 |
1 files changed, 12 insertions, 12 deletions
diff --git a/OpenSim/Region/Framework/Scenes/ScenePresence.cs b/OpenSim/Region/Framework/Scenes/ScenePresence.cs index 4156f21..0ff93f6 100644 --- a/OpenSim/Region/Framework/Scenes/ScenePresence.cs +++ b/OpenSim/Region/Framework/Scenes/ScenePresence.cs | |||
@@ -320,7 +320,10 @@ namespace OpenSim.Region.Framework.Scenes | |||
320 | } | 320 | } |
321 | 321 | ||
322 | #region Client Camera | 322 | #region Client Camera |
323 | // Position of agent's camera in world (region cordinates) | 323 | |
324 | /// <summary> | ||
325 | /// Position of agent's camera in world (region cordinates) | ||
326 | /// </summary> | ||
324 | protected Vector3 m_lastCameraPosition; | 327 | protected Vector3 m_lastCameraPosition; |
325 | 328 | ||
326 | protected Vector3 m_CameraPosition; | 329 | protected Vector3 m_CameraPosition; |
@@ -1911,14 +1914,12 @@ namespace OpenSim.Region.Framework.Scenes | |||
1911 | foreach (SceneObjectPart part in partArray) | 1914 | foreach (SceneObjectPart part in partArray) |
1912 | { | 1915 | { |
1913 | // Is a sit target available? | 1916 | // Is a sit target available? |
1914 | Vector3 avSitOffSet = part.SitTargetPosition; | 1917 | Vector3 avSitOffset = part.SitTargetPosition; |
1915 | Quaternion avSitOrientation = part.SitTargetOrientation; | 1918 | Quaternion avSitOrientation = part.SitTargetOrientation; |
1916 | UUID avOnTargetAlready = part.SitTargetAvatar; | 1919 | UUID avOnTargetAlready = part.SitTargetAvatar; |
1917 | 1920 | ||
1918 | bool SitTargetUnOccupied = (!(avOnTargetAlready != UUID.Zero)); | 1921 | bool SitTargetUnOccupied = avOnTargetAlready == UUID.Zero; |
1919 | bool SitTargetisSet = | 1922 | bool SitTargetisSet = avSitOffset != Vector3.Zero || avSitOrientation != Quaternion.Identity; |
1920 | (!(avSitOffSet.X == 0f && avSitOffSet.Y == 0f && avSitOffSet.Z == 0f && avSitOrientation.W == 1f && | ||
1921 | avSitOrientation.X == 0f && avSitOrientation.Y == 0f && avSitOrientation.Z == 0f)); | ||
1922 | 1923 | ||
1923 | if (SitTargetisSet && SitTargetUnOccupied) | 1924 | if (SitTargetisSet && SitTargetUnOccupied) |
1924 | { | 1925 | { |
@@ -1940,7 +1941,6 @@ namespace OpenSim.Region.Framework.Scenes | |||
1940 | Vector3 cameraAtOffset = Vector3.Zero; | 1941 | Vector3 cameraAtOffset = Vector3.Zero; |
1941 | bool forceMouselook = false; | 1942 | bool forceMouselook = false; |
1942 | 1943 | ||
1943 | //SceneObjectPart part = m_scene.GetSceneObjectPart(targetID); | ||
1944 | SceneObjectPart part = FindNextAvailableSitTarget(targetID); | 1944 | SceneObjectPart part = FindNextAvailableSitTarget(targetID); |
1945 | if (part != null) | 1945 | if (part != null) |
1946 | { | 1946 | { |
@@ -1954,9 +1954,9 @@ namespace OpenSim.Region.Framework.Scenes | |||
1954 | 1954 | ||
1955 | bool SitTargetUnOccupied = (!(avOnTargetAlready != UUID.Zero)); | 1955 | bool SitTargetUnOccupied = (!(avOnTargetAlready != UUID.Zero)); |
1956 | bool SitTargetisSet = | 1956 | bool SitTargetisSet = |
1957 | (!(avSitOffSet.X == 0f && avSitOffSet.Y == 0f && avSitOffSet.Z == 0f && | 1957 | (!(avSitOffSet == Vector3.Zero && |
1958 | ( | 1958 | ( |
1959 | avSitOrientation.X == 0f && avSitOrientation.Y == 0f && avSitOrientation.Z == 0f && avSitOrientation.W == 1f // Valid Zero Rotation quaternion | 1959 | avSitOrientation == Quaternion.Identity // Valid Zero Rotation quaternion |
1960 | || avSitOrientation.X == 0f && avSitOrientation.Y == 0f && avSitOrientation.Z == 1f && avSitOrientation.W == 0f // W-Z Mapping was invalid at one point | 1960 | || avSitOrientation.X == 0f && avSitOrientation.Y == 0f && avSitOrientation.Z == 1f && avSitOrientation.W == 0f // W-Z Mapping was invalid at one point |
1961 | || avSitOrientation.X == 0f && avSitOrientation.Y == 0f && avSitOrientation.Z == 0f && avSitOrientation.W == 0f // Invalid Quaternion | 1961 | || avSitOrientation.X == 0f && avSitOrientation.Y == 0f && avSitOrientation.Z == 0f && avSitOrientation.W == 0f // Invalid Quaternion |
1962 | ) | 1962 | ) |
@@ -2008,6 +2008,7 @@ namespace OpenSim.Region.Framework.Scenes | |||
2008 | 2008 | ||
2009 | ControllingClient.SendSitResponse(targetID, offset, sitOrientation, autopilot, cameraAtOffset, cameraEyeOffset, forceMouselook); | 2009 | ControllingClient.SendSitResponse(targetID, offset, sitOrientation, autopilot, cameraAtOffset, cameraEyeOffset, forceMouselook); |
2010 | m_requestedSitTargetUUID = targetID; | 2010 | m_requestedSitTargetUUID = targetID; |
2011 | |||
2011 | // This calls HandleAgentSit twice, once from here, and the client calls | 2012 | // This calls HandleAgentSit twice, once from here, and the client calls |
2012 | // HandleAgentSit itself after it gets to the location | 2013 | // HandleAgentSit itself after it gets to the location |
2013 | // It doesn't get to the location until we've moved them there though | 2014 | // It doesn't get to the location until we've moved them there though |
@@ -2292,15 +2293,13 @@ namespace OpenSim.Region.Framework.Scenes | |||
2292 | 2293 | ||
2293 | //Quaternion result = (sitTargetOrient * vq) * nq; | 2294 | //Quaternion result = (sitTargetOrient * vq) * nq; |
2294 | 2295 | ||
2295 | m_pos = new Vector3(sitTargetPos.X, sitTargetPos.Y, sitTargetPos.Z); | 2296 | m_pos = sitTargetPos + SIT_TARGET_ADJUSTMENT; |
2296 | m_pos += SIT_TARGET_ADJUSTMENT; | ||
2297 | Rotation = sitTargetOrient; | 2297 | Rotation = sitTargetOrient; |
2298 | ParentPosition = part.AbsolutePosition; | 2298 | ParentPosition = part.AbsolutePosition; |
2299 | } | 2299 | } |
2300 | else | 2300 | else |
2301 | { | 2301 | { |
2302 | m_pos -= part.AbsolutePosition; | 2302 | m_pos -= part.AbsolutePosition; |
2303 | |||
2304 | ParentPosition = part.AbsolutePosition; | 2303 | ParentPosition = part.AbsolutePosition; |
2305 | 2304 | ||
2306 | // m_log.DebugFormat( | 2305 | // m_log.DebugFormat( |
@@ -2313,6 +2312,7 @@ namespace OpenSim.Region.Framework.Scenes | |||
2313 | return; | 2312 | return; |
2314 | } | 2313 | } |
2315 | } | 2314 | } |
2315 | |||
2316 | ParentID = m_requestedSitTargetID; | 2316 | ParentID = m_requestedSitTargetID; |
2317 | 2317 | ||
2318 | Velocity = Vector3.Zero; | 2318 | Velocity = Vector3.Zero; |