aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim')
-rw-r--r--OpenSim/Region/Framework/Scenes/ScenePresence.cs239
1 files changed, 113 insertions, 126 deletions
diff --git a/OpenSim/Region/Framework/Scenes/ScenePresence.cs b/OpenSim/Region/Framework/Scenes/ScenePresence.cs
index 258ca20..8e6e8fd 100644
--- a/OpenSim/Region/Framework/Scenes/ScenePresence.cs
+++ b/OpenSim/Region/Framework/Scenes/ScenePresence.cs
@@ -3475,7 +3475,7 @@ namespace OpenSim.Region.Framework.Scenes
3475 protected void CheckForBorderCrossing() 3475 protected void CheckForBorderCrossing()
3476 { 3476 {
3477 // Check that we we are not a child 3477 // Check that we we are not a child
3478 if (IsChildAgent) 3478 if (IsChildAgent)
3479 return; 3479 return;
3480 3480
3481 // If we don't have a PhysActor, we can't cross anyway 3481 // If we don't have a PhysActor, we can't cross anyway
@@ -3485,140 +3485,127 @@ namespace OpenSim.Region.Framework.Scenes
3485 if (ParentID != 0 || PhysicsActor == null || ParentUUID != UUID.Zero) 3485 if (ParentID != 0 || PhysicsActor == null || ParentUUID != UUID.Zero)
3486 return; 3486 return;
3487 3487
3488 if (!IsInTransit) 3488 if (IsInTransit)
3489 { 3489 return;
3490 Vector3 pos2 = AbsolutePosition;
3491 Vector3 vel = Velocity;
3492 int neighbor = 0;
3493 int[] fix = new int[2];
3494 3490
3495 float timeStep = 0.1f; 3491 Vector3 pos2 = AbsolutePosition;
3496 pos2.X = pos2.X + (vel.X * timeStep); 3492 Vector3 vel = Velocity;
3497 pos2.Y = pos2.Y + (vel.Y * timeStep); 3493 int neighbor = 0;
3498 pos2.Z = pos2.Z + (vel.Z * timeStep); 3494 int[] fix = new int[2];
3499 3495
3500 if (!IsInTransit) 3496 float timeStep = 0.1f;
3501 { 3497 pos2.X = pos2.X + (vel.X * timeStep);
3502// m_log.DebugFormat( 3498 pos2.Y = pos2.Y + (vel.Y * timeStep);
3503// "[SCENE PRESENCE]: Testing border check for projected position {0} of {1} in {2}", 3499 pos2.Z = pos2.Z + (vel.Z * timeStep);
3504// pos2, Name, Scene.Name);
3505 3500
3506 // Checks if where it's headed exists a region
3507 bool needsTransit = false;
3508 if (m_scene.TestBorderCross(pos2, Cardinals.W))
3509 {
3510 if (m_scene.TestBorderCross(pos2, Cardinals.S))
3511 {
3512 needsTransit = true;
3513 neighbor = m_scene.HaveNeighbor(Cardinals.SW, ref fix);
3514 }
3515 else if (m_scene.TestBorderCross(pos2, Cardinals.N))
3516 {
3517 needsTransit = true;
3518 neighbor = m_scene.HaveNeighbor(Cardinals.NW, ref fix);
3519 }
3520 else
3521 {
3522 needsTransit = true;
3523 neighbor = m_scene.HaveNeighbor(Cardinals.W, ref fix);
3524 }
3525 }
3526 else if (m_scene.TestBorderCross(pos2, Cardinals.E))
3527 {
3528 if (m_scene.TestBorderCross(pos2, Cardinals.S))
3529 {
3530 needsTransit = true;
3531 neighbor = m_scene.HaveNeighbor(Cardinals.SE, ref fix);
3532 }
3533 else if (m_scene.TestBorderCross(pos2, Cardinals.N))
3534 {
3535 needsTransit = true;
3536 neighbor = m_scene.HaveNeighbor(Cardinals.NE, ref fix);
3537 }
3538 else
3539 {
3540 needsTransit = true;
3541 neighbor = m_scene.HaveNeighbor(Cardinals.E, ref fix);
3542 }
3543 }
3544 else if (m_scene.TestBorderCross(pos2, Cardinals.S))
3545 {
3546 needsTransit = true;
3547 neighbor = m_scene.HaveNeighbor(Cardinals.S, ref fix);
3548 }
3549 else if (m_scene.TestBorderCross(pos2, Cardinals.N))
3550 {
3551 needsTransit = true;
3552 neighbor = m_scene.HaveNeighbor(Cardinals.N, ref fix);
3553 }
3554 3501
3555 // Makes sure avatar does not end up outside region 3502 // m_log.DebugFormat(
3556 if (neighbor <= 0) 3503 // "[SCENE PRESENCE]: Testing border check for projected position {0} of {1} in {2}",
3557 { 3504 // pos2, Name, Scene.Name);
3558 if (needsTransit) 3505
3559 { 3506 // Checks if where it's headed exists a region
3560 if (m_requestedSitTargetUUID == UUID.Zero) 3507 bool needsTransit = false;
3561 { 3508 if (m_scene.TestBorderCross(pos2, Cardinals.W))
3562 bool isFlying = Flying; 3509 {
3563 RemoveFromPhysicalScene(); 3510 if (m_scene.TestBorderCross(pos2, Cardinals.S))
3564 3511 {
3565 Vector3 pos = AbsolutePosition; 3512 needsTransit = true;
3566 if (AbsolutePosition.X < 0) 3513 neighbor = m_scene.HaveNeighbor(Cardinals.SW, ref fix);
3567 pos.X += Velocity.X * 2; 3514 }
3568 else if (AbsolutePosition.X > Constants.RegionSize) 3515 else if (m_scene.TestBorderCross(pos2, Cardinals.N))
3569 pos.X -= Velocity.X * 2; 3516 {
3570 if (AbsolutePosition.Y < 0) 3517 needsTransit = true;
3571 pos.Y += Velocity.Y * 2; 3518 neighbor = m_scene.HaveNeighbor(Cardinals.NW, ref fix);
3572 else if (AbsolutePosition.Y > Constants.RegionSize) 3519 }
3573 pos.Y -= Velocity.Y * 2; 3520 else
3574 Velocity = Vector3.Zero; 3521 {
3575 AbsolutePosition = pos; 3522 needsTransit = true;
3576 3523 neighbor = m_scene.HaveNeighbor(Cardinals.W, ref fix);
3577// m_log.DebugFormat("[SCENE PRESENCE]: Prevented flyoff for {0} at {1}", Name, AbsolutePosition); 3524 }
3578 3525 }
3579 AddToPhysicalScene(isFlying); 3526 else if (m_scene.TestBorderCross(pos2, Cardinals.E))
3580 } 3527 {
3581 } 3528 if (m_scene.TestBorderCross(pos2, Cardinals.S))
3582 } 3529 {
3583 else if (neighbor > 0) 3530 needsTransit = true;
3531 neighbor = m_scene.HaveNeighbor(Cardinals.SE, ref fix);
3532 }
3533 else if (m_scene.TestBorderCross(pos2, Cardinals.N))
3534 {
3535 needsTransit = true;
3536 neighbor = m_scene.HaveNeighbor(Cardinals.NE, ref fix);
3537 }
3538 else
3539 {
3540 needsTransit = true;
3541 neighbor = m_scene.HaveNeighbor(Cardinals.E, ref fix);
3542 }
3543 }
3544 else if (m_scene.TestBorderCross(pos2, Cardinals.S))
3545 {
3546 needsTransit = true;
3547 neighbor = m_scene.HaveNeighbor(Cardinals.S, ref fix);
3548 }
3549 else if (m_scene.TestBorderCross(pos2, Cardinals.N))
3550 {
3551 needsTransit = true;
3552 neighbor = m_scene.HaveNeighbor(Cardinals.N, ref fix);
3553 }
3554
3555 // Makes sure avatar does not end up outside region
3556 if (neighbor <= 0)
3557 {
3558 if (needsTransit)
3559 {
3560 if (m_requestedSitTargetUUID == UUID.Zero)
3584 { 3561 {
3585 if (!CrossToNewRegion()) 3562 bool isFlying = Flying;
3586 { 3563 RemoveFromPhysicalScene();
3587 if (m_requestedSitTargetUUID == UUID.Zero) 3564
3588 { 3565 Vector3 pos = AbsolutePosition;
3589 bool isFlying = Flying; 3566 if (AbsolutePosition.X < 0)
3590 RemoveFromPhysicalScene(); 3567 pos.X += Velocity.X * 2;
3591 3568 else if (AbsolutePosition.X > Constants.RegionSize)
3592 Vector3 pos = AbsolutePosition; 3569 pos.X -= Velocity.X * 2;
3593 if (AbsolutePosition.X < 0) 3570 if (AbsolutePosition.Y < 0)
3594 pos.X += Velocity.X * 2; 3571 pos.Y += Velocity.Y * 2;
3595 else if (AbsolutePosition.X > Constants.RegionSize) 3572 else if (AbsolutePosition.Y > Constants.RegionSize)
3596 pos.X -= Velocity.X * 2; 3573 pos.Y -= Velocity.Y * 2;
3597 if (AbsolutePosition.Y < 0) 3574 Velocity = Vector3.Zero;
3598 pos.Y += Velocity.Y * 2; 3575 AbsolutePosition = pos;
3599 else if (AbsolutePosition.Y > Constants.RegionSize) 3576
3600 pos.Y -= Velocity.Y * 2; 3577 // m_log.DebugFormat("[SCENE PRESENCE]: Prevented flyoff for {0} at {1}", Name, AbsolutePosition);
3601 Velocity = Vector3.Zero; 3578
3602 AbsolutePosition = pos; 3579 AddToPhysicalScene(isFlying);
3603
3604 AddToPhysicalScene(isFlying);
3605 }
3606 }
3607 } 3580 }
3608 } 3581 }
3609 else 3582 }
3583 else if (neighbor > 0)
3584 {
3585 if (!CrossToNewRegion())
3610 { 3586 {
3611 // This constant has been inferred from experimentation 3587 if (m_requestedSitTargetUUID == UUID.Zero)
3612 // I'm not sure what this value should be, so I tried a few values. 3588 {
3613 timeStep = 0.04f; 3589 bool isFlying = Flying;
3614 pos2 = AbsolutePosition; 3590 RemoveFromPhysicalScene();
3615 pos2.X = pos2.X + (vel.X * timeStep); 3591
3616 pos2.Y = pos2.Y + (vel.Y * timeStep); 3592 Vector3 pos = AbsolutePosition;
3617 // Don't touch the Z 3593 if (AbsolutePosition.X < 0)
3618 m_pos = pos2; 3594 pos.X += Velocity.X * 2;
3619 m_log.DebugFormat("[SCENE PRESENCE]: In transit m_pos={0}", m_pos); 3595 else if (AbsolutePosition.X > Constants.RegionSize)
3596 pos.X -= Velocity.X * 2;
3597 if (AbsolutePosition.Y < 0)
3598 pos.Y += Velocity.Y * 2;
3599 else if (AbsolutePosition.Y > Constants.RegionSize)
3600 pos.Y -= Velocity.Y * 2;
3601 Velocity = Vector3.Zero;
3602 AbsolutePosition = pos;
3603
3604 AddToPhysicalScene(isFlying);
3605 }
3620 } 3606 }
3621 } 3607 }
3608
3622 } 3609 }
3623 3610
3624 /// <summary> 3611 /// <summary>