aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/Framework/Scenes/ScenePresence.cs
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/Region/Framework/Scenes/ScenePresence.cs108
1 files changed, 59 insertions, 49 deletions
diff --git a/OpenSim/Region/Framework/Scenes/ScenePresence.cs b/OpenSim/Region/Framework/Scenes/ScenePresence.cs
index 4504e18..5d0baf3 100644
--- a/OpenSim/Region/Framework/Scenes/ScenePresence.cs
+++ b/OpenSim/Region/Framework/Scenes/ScenePresence.cs
@@ -227,8 +227,6 @@ namespace OpenSim.Region.Framework.Scenes
227 /// </summary> 227 /// </summary>
228 public bool LandAtTarget { get; private set; } 228 public bool LandAtTarget { get; private set; }
229 229
230 private bool m_followCamAuto;
231
232 private int m_movementUpdateCount; 230 private int m_movementUpdateCount;
233 private const int NumMovementsBetweenRayCast = 5; 231 private const int NumMovementsBetweenRayCast = 5;
234 232
@@ -357,6 +355,9 @@ namespace OpenSim.Region.Framework.Scenes
357 /// </summary> 355 /// </summary>
358 protected Vector3 m_lastCameraPosition; 356 protected Vector3 m_lastCameraPosition;
359 357
358 private Vector4 m_lastCameraCollisionPlane = new Vector4(0f, 0f, 0f, 1);
359 private bool m_doingCamRayCast = false;
360
360 public Vector3 CameraPosition { get; set; } 361 public Vector3 CameraPosition { get; set; }
361 362
362 public Quaternion CameraRotation 363 public Quaternion CameraRotation
@@ -1407,36 +1408,40 @@ namespace OpenSim.Region.Framework.Scenes
1407 /// <param name="collisionPoint"></param> 1408 /// <param name="collisionPoint"></param>
1408 /// <param name="localid"></param> 1409 /// <param name="localid"></param>
1409 /// <param name="distance"></param> 1410 /// <param name="distance"></param>
1410 public void RayCastCameraCallback(bool hitYN, Vector3 collisionPoint, uint localid, float distance, Vector3 pNormal) 1411 ///
1412
1413 private void UpdateCameraCollisionPlane(Vector4 plane)
1411 { 1414 {
1412 const float POSITION_TOLERANCE = 0.02f; 1415 if (m_lastCameraCollisionPlane != plane)
1413 const float VELOCITY_TOLERANCE = 0.02f; 1416 {
1414 const float ROTATION_TOLERANCE = 0.02f; 1417 m_lastCameraCollisionPlane = plane;
1418 ControllingClient.SendCameraConstraint(plane);
1419 }
1420 }
1415 1421
1416 if (m_followCamAuto) 1422 public void RayCastCameraCallback(bool hitYN, Vector3 collisionPoint, uint localid, float distance, Vector3 pNormal)
1423 {
1424 m_doingCamRayCast = false;
1425 if (hitYN && localid != LocalId)
1417 { 1426 {
1418 if (hitYN && localid != LocalId) 1427 CameraConstraintActive = true;
1419 { 1428 pNormal.X = (float)Math.Round(pNormal.X, 2);
1429 pNormal.Y = (float)Math.Round(pNormal.Y, 2);
1430 pNormal.Z = (float)Math.Round(pNormal.Z, 2);
1431 pNormal.Normalize();
1432 collisionPoint.X = (float)Math.Round(collisionPoint.X, 1);
1433 collisionPoint.Y = (float)Math.Round(collisionPoint.Y, 1);
1434 collisionPoint.Z = (float)Math.Round(collisionPoint.Z, 1);
1435
1436 Vector4 plane = new Vector4(pNormal.X, pNormal.Y, pNormal.Z, Vector3.Dot(collisionPoint, pNormal));
1437 UpdateCameraCollisionPlane(plane);
1438 }
1439 else
1440 {
1441 Vector4 plane = new Vector4(0.9f, 0.0f, 0.361f, -9000f); // not right...
1442 UpdateCameraCollisionPlane(plane);
1420 1443
1421 CameraConstraintActive = true; 1444 CameraConstraintActive = false;
1422 //m_log.DebugFormat("[RAYCASTRESULT]: {0}, {1}, {2}, {3}", hitYN, collisionPoint, localid, distance);
1423
1424 Vector3 normal = Vector3.Normalize(new Vector3(0f, 0f, collisionPoint.Z) - collisionPoint);
1425 ControllingClient.SendCameraConstraint(new Vector4(normal.X, normal.Y, normal.Z, -1 * Vector3.Distance(new Vector3(0,0,collisionPoint.Z),collisionPoint)));
1426 }
1427 else
1428 {
1429 if (!m_pos.ApproxEquals(m_lastPosition, POSITION_TOLERANCE) ||
1430 !Velocity.ApproxEquals(m_lastVelocity, VELOCITY_TOLERANCE) ||
1431 !Rotation.ApproxEquals(m_lastRotation, ROTATION_TOLERANCE))
1432 {
1433 if (CameraConstraintActive)
1434 {
1435 ControllingClient.SendCameraConstraint(new Vector4(0f, 0.5f, 0.9f, -3000f));
1436 CameraConstraintActive = false;
1437 }
1438 }
1439 }
1440 } 1445 }
1441 } 1446 }
1442 1447
@@ -1511,12 +1516,6 @@ namespace OpenSim.Region.Framework.Scenes
1511 // DrawDistance = agentData.Far; 1516 // DrawDistance = agentData.Far;
1512 DrawDistance = Scene.DefaultDrawDistance; 1517 DrawDistance = Scene.DefaultDrawDistance;
1513 1518
1514 // Check if Client has camera in 'follow cam' or 'build' mode.
1515 Vector3 camdif = (Vector3.One * Rotation - Vector3.One * CameraRotation);
1516
1517 m_followCamAuto = ((CameraUpAxis.Z > 0.959f && CameraUpAxis.Z < 0.98f)
1518 && (Math.Abs(camdif.X) < 0.4f && Math.Abs(camdif.Y) < 0.4f)) ? true : false;
1519
1520 m_mouseLook = (flags & AgentManager.ControlFlags.AGENT_CONTROL_MOUSELOOK) != 0; 1519 m_mouseLook = (flags & AgentManager.ControlFlags.AGENT_CONTROL_MOUSELOOK) != 0;
1521 m_leftButtonDown = (flags & AgentManager.ControlFlags.AGENT_CONTROL_LBUTTON_DOWN) != 0; 1520 m_leftButtonDown = (flags & AgentManager.ControlFlags.AGENT_CONTROL_LBUTTON_DOWN) != 0;
1522 1521
@@ -1536,26 +1535,37 @@ namespace OpenSim.Region.Framework.Scenes
1536 StandUp(); 1535 StandUp();
1537 } 1536 }
1538 1537
1539 //m_log.DebugFormat("[FollowCam]: {0}", m_followCamAuto);
1540 // Raycast from the avatar's head to the camera to see if there's anything blocking the view 1538 // Raycast from the avatar's head to the camera to see if there's anything blocking the view
1541 if ((m_movementUpdateCount % NumMovementsBetweenRayCast) == 0 && m_scene.PhysicsScene.SupportsRayCast()) 1539 // this exclude checks may not be complete
1540
1541 if (!m_doingCamRayCast && !m_mouseLook && m_scene.PhysicsScene.SupportsRayCast() && ParentID == 0)
1542 { 1542 {
1543 if (m_followCamAuto) 1543 Vector3 posAdjusted = AbsolutePosition;
1544 posAdjusted.Z += 0.5f * Appearance.AvatarSize.Z - 0.5f;
1545
1546 Vector3 tocam = CameraPosition - posAdjusted;
1547 tocam.X = (float)Math.Round(tocam.X, 1);
1548 tocam.Y = (float)Math.Round(tocam.Y, 1);
1549 tocam.Z = (float)Math.Round(tocam.Z, 1);
1550
1551 float distTocamlen = tocam.Length();
1552 if (distTocamlen > 0.3f)
1544 { 1553 {
1545 // Vector3 posAdjusted = m_pos + HEAD_ADJUSTMENT; 1554 tocam *= (1.0f / distTocamlen);
1546 // m_scene.PhysicsScene.RaycastWorld(m_pos, Vector3.Normalize(CameraPosition - posAdjusted), Vector3.Distance(CameraPosition, posAdjusted) + 0.3f, RayCastCameraCallback); 1555 posAdjusted.X = (float)Math.Round(posAdjusted.X, 1);
1547 1556 posAdjusted.Y = (float)Math.Round(posAdjusted.Y, 1);
1548 Vector3 posAdjusted = AbsolutePosition + HEAD_ADJUSTMENT; 1557 posAdjusted.Z = (float)Math.Round(posAdjusted.Z, 1);
1549 Vector3 distTocam = CameraPosition - posAdjusted; 1558
1550 float distTocamlen = distTocam.Length(); 1559 m_doingCamRayCast = true;
1551 if (distTocamlen > 0) 1560 m_scene.PhysicsScene.RaycastWorld(posAdjusted, tocam, distTocamlen + 1.0f, RayCastCameraCallback);
1552 {
1553 distTocam *= 1.0f / distTocamlen;
1554 m_scene.PhysicsScene.RaycastWorld(posAdjusted, distTocam, distTocamlen + 0.3f, RayCastCameraCallback);
1555 }
1556
1557 } 1561 }
1558 } 1562 }
1563 else if (CameraConstraintActive && (m_mouseLook || ParentID != 0) )
1564 {
1565 Vector4 plane = new Vector4(0.9f, 0.0f, 0.361f, -10000f); // not right...
1566 UpdateCameraCollisionPlane(plane);
1567 CameraConstraintActive = false;
1568 }
1559 1569
1560 uint flagsForScripts = (uint)flags; 1570 uint flagsForScripts = (uint)flags;
1561 flags = RemoveIgnoredControls(flags, IgnoredControls); 1571 flags = RemoveIgnoredControls(flags, IgnoredControls);