aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs30
-rw-r--r--OpenSim/Region/Framework/Scenes/SceneObjectPart.cs43
-rw-r--r--OpenSim/Region/Framework/Scenes/ScenePresence.cs36
3 files changed, 52 insertions, 57 deletions
diff --git a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
index 53c185b..954f21f 100644
--- a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
+++ b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
@@ -6256,20 +6256,22 @@ namespace OpenSim.Region.ClientStack.LindenUDP
6256 /// <param name='x'></param> 6256 /// <param name='x'></param>
6257 private bool CheckAgentCameraUpdateSignificance(AgentUpdatePacket.AgentDataBlock x) 6257 private bool CheckAgentCameraUpdateSignificance(AgentUpdatePacket.AgentDataBlock x)
6258 { 6258 {
6259 float vdelta = Vector3.Distance(x.CameraAtAxis, m_thisAgentUpdateArgs.CameraAtAxis); 6259 if(Math.Abs(x.CameraCenter.X - m_thisAgentUpdateArgs.CameraCenter.X) > VDELTA ||
6260 if((vdelta > VDELTA)) 6260 Math.Abs(x.CameraCenter.Y - m_thisAgentUpdateArgs.CameraCenter.Y) > VDELTA ||
6261 return true; 6261 Math.Abs(x.CameraCenter.Z - m_thisAgentUpdateArgs.CameraCenter.Z) > VDELTA ||
6262 6262
6263 vdelta = Vector3.Distance(x.CameraCenter, m_thisAgentUpdateArgs.CameraCenter); 6263 Math.Abs(x.CameraAtAxis.X - m_thisAgentUpdateArgs.CameraAtAxis.X) > VDELTA ||
6264 if((vdelta > VDELTA)) 6264 Math.Abs(x.CameraAtAxis.Y - m_thisAgentUpdateArgs.CameraAtAxis.Y) > VDELTA ||
6265 return true; 6265// Math.Abs(x.CameraAtAxis.Z - m_thisAgentUpdateArgs.CameraAtAxis.Z) > VDELTA ||
6266 6266
6267 vdelta = Vector3.Distance(x.CameraLeftAxis, m_thisAgentUpdateArgs.CameraLeftAxis); 6267 Math.Abs(x.CameraLeftAxis.X - m_thisAgentUpdateArgs.CameraLeftAxis.X) > VDELTA ||
6268 if((vdelta > VDELTA)) 6268 Math.Abs(x.CameraLeftAxis.Y - m_thisAgentUpdateArgs.CameraLeftAxis.Y) > VDELTA ||
6269 return true; 6269// Math.Abs(x.CameraLeftAxis.Z - m_thisAgentUpdateArgs.CameraLeftAxis.Z) > VDELTA ||
6270 6270
6271 vdelta = Vector3.Distance(x.CameraUpAxis, m_thisAgentUpdateArgs.CameraUpAxis); 6271 Math.Abs(x.CameraUpAxis.X - m_thisAgentUpdateArgs.CameraUpAxis.X) > VDELTA ||
6272 if((vdelta > VDELTA)) 6272 Math.Abs(x.CameraUpAxis.Y - m_thisAgentUpdateArgs.CameraUpAxis.Y) > VDELTA
6273// Math.Abs(x.CameraLeftAxis.Z - m_thisAgentUpdateArgs.CameraLeftAxis.Z) > VDELTA ||
6274 )
6273 return true; 6275 return true;
6274 6276
6275 return false; 6277 return false;
diff --git a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
index 576a013..2e16663 100644
--- a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
+++ b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
@@ -3237,7 +3237,7 @@ namespace OpenSim.Region.Framework.Scenes
3237 3237
3238 /// <summary> 3238 /// <summary>
3239 /// Schedule a terse update for this prim. Terse updates only send position, 3239 /// Schedule a terse update for this prim. Terse updates only send position,
3240 /// rotation, velocity and rotational velocity information. 3240 /// rotation, velocity and rotational velocity information. WRONG!!!!
3241 /// </summary> 3241 /// </summary>
3242 public void ScheduleTerseUpdate() 3242 public void ScheduleTerseUpdate()
3243 { 3243 {
@@ -3296,21 +3296,6 @@ namespace OpenSim.Region.Framework.Scenes
3296 sp.SendAttachmentUpdate(this, UpdateRequired.FULL); 3296 sp.SendAttachmentUpdate(this, UpdateRequired.FULL);
3297 } 3297 }
3298 } 3298 }
3299
3300/* this does nothing
3301SendFullUpdateToClient(remoteClient, Position) ignores position parameter
3302 if (IsRoot)
3303 {
3304 if (ParentGroup.IsAttachment)
3305 {
3306 SendFullUpdateToClient(remoteClient, AttachedPos);
3307 }
3308 else
3309 {
3310 SendFullUpdateToClient(remoteClient, AbsolutePosition);
3311 }
3312 }
3313*/
3314 else 3299 else
3315 { 3300 {
3316 SendFullUpdateToClient(remoteClient); 3301 SendFullUpdateToClient(remoteClient);
@@ -3396,24 +3381,26 @@ SendFullUpdateToClient(remoteClient, Position) ignores position parameter
3396 ParentGroup.Scene.StatsReporter.AddObjectUpdates(1); 3381 ParentGroup.Scene.StatsReporter.AddObjectUpdates(1);
3397 } 3382 }
3398 3383
3384
3385 private const float ROTATION_TOLERANCE = 0.01f;
3386 private const float VELOCITY_TOLERANCE = 0.1f; // terse update vel has low resolution
3387 private const float POSITION_TOLERANCE = 0.05f; // I don't like this, but I suppose it's necessary
3388 private const double TIME_MS_TOLERANCE = 200f; //llSetPos has a 200ms delay. This should NOT be 3 seconds.
3399 3389
3400 /// <summary> 3390 /// <summary>
3401 /// Tell all the prims which have had updates scheduled 3391 /// Tell all the prims which have had updates scheduled
3402 /// </summary> 3392 /// </summary>
3403 public void SendScheduledUpdates() 3393 public void SendScheduledUpdates()
3404 { 3394 {
3405 const float ROTATION_TOLERANCE = 0.01f;
3406 const float VELOCITY_TOLERANCE = 0.1f; // terse update vel has low resolution
3407 const float POSITION_TOLERANCE = 0.05f; // I don't like this, but I suppose it's necessary
3408 const double TIME_MS_TOLERANCE = 200f; //llSetPos has a 200ms delay. This should NOT be 3 seconds.
3409
3410 switch (UpdateFlag) 3395 switch (UpdateFlag)
3411 { 3396 {
3412 // this is wrong we need to get back to this 3397 case UpdateRequired.NONE:
3413 case UpdateRequired.TERSE:
3414 {
3415 ClearUpdateSchedule(); 3398 ClearUpdateSchedule();
3399 break;
3400
3401 case UpdateRequired.TERSE:
3416 3402
3403 ClearUpdateSchedule();
3417 bool needupdate = true; 3404 bool needupdate = true;
3418 double now = Util.GetTimeStampMS(); 3405 double now = Util.GetTimeStampMS();
3419 Vector3 curvel = Velocity; 3406 Vector3 curvel = Velocity;
@@ -3423,8 +3410,6 @@ SendFullUpdateToClient(remoteClient, Position) ignores position parameter
3423 while(true) // just to avoid ugly goto 3410 while(true) // just to avoid ugly goto
3424 { 3411 {
3425 double elapsed = now - m_lastUpdateSentTime; 3412 double elapsed = now - m_lastUpdateSentTime;
3426
3427 // minimal rate also for the other things on terse updates
3428 if (elapsed > TIME_MS_TOLERANCE) 3413 if (elapsed > TIME_MS_TOLERANCE)
3429 break; 3414 break;
3430 3415
@@ -3514,13 +3499,11 @@ SendFullUpdateToClient(remoteClient, Position) ignores position parameter
3514 }); 3499 });
3515 } 3500 }
3516 break; 3501 break;
3517 } 3502
3518 case UpdateRequired.FULL: 3503 case UpdateRequired.FULL:
3519 {
3520 ClearUpdateSchedule(); 3504 ClearUpdateSchedule();
3521 SendFullUpdateToAllClientsInternal(); 3505 SendFullUpdateToAllClientsInternal();
3522 break; 3506 break;
3523 }
3524 } 3507 }
3525 } 3508 }
3526 3509
diff --git a/OpenSim/Region/Framework/Scenes/ScenePresence.cs b/OpenSim/Region/Framework/Scenes/ScenePresence.cs
index c1b62af..ba3aaae 100644
--- a/OpenSim/Region/Framework/Scenes/ScenePresence.cs
+++ b/OpenSim/Region/Framework/Scenes/ScenePresence.cs
@@ -279,8 +279,11 @@ namespace OpenSim.Region.Framework.Scenes
279 private bool MouseDown = false; 279 private bool MouseDown = false;
280 public Vector3 lastKnownAllowedPosition; 280 public Vector3 lastKnownAllowedPosition;
281 public bool sentMessageAboutRestrictedParcelFlyingDown; 281 public bool sentMessageAboutRestrictedParcelFlyingDown;
282
282 public Vector4 CollisionPlane = Vector4.UnitW; 283 public Vector4 CollisionPlane = Vector4.UnitW;
283 284
285 public Vector4 m_lastCollisionPlane = Vector4.UnitW;
286 private byte m_lastState;
284 private Vector3 m_lastPosition; 287 private Vector3 m_lastPosition;
285 private Quaternion m_lastRotation; 288 private Quaternion m_lastRotation;
286 private Vector3 m_lastVelocity; 289 private Vector3 m_lastVelocity;
@@ -2818,16 +2821,13 @@ namespace OpenSim.Region.Framework.Scenes
2818 CameraAtAxis = agentData.CameraAtAxis; 2821 CameraAtAxis = agentData.CameraAtAxis;
2819 CameraLeftAxis = agentData.CameraLeftAxis; 2822 CameraLeftAxis = agentData.CameraLeftAxis;
2820 CameraUpAxis = agentData.CameraUpAxis; 2823 CameraUpAxis = agentData.CameraUpAxis;
2821 Quaternion camRot = Util.Axes2Rot(CameraAtAxis, CameraLeftAxis, CameraUpAxis);
2822 CameraRotation = camRot;
2823
2824 // The Agent's Draw distance setting
2825 // When we get to the point of re-computing neighbors everytime this
2826 // changes, then start using the agent's drawdistance rather than the
2827 // region's draw distance.
2828
2829 DrawDistance = agentData.Far; 2824 DrawDistance = agentData.Far;
2830 2825
2826 CameraAtAxis.Normalize();
2827 CameraLeftAxis.Normalize();
2828 CameraUpAxis.Normalize();
2829 Quaternion camRot = Util.Axes2Rot(CameraAtAxis, CameraLeftAxis, CameraUpAxis);
2830 CameraRotation = camRot;
2831 2831
2832 // Check if Client has camera in 'follow cam' or 'build' mode. 2832 // Check if Client has camera in 'follow cam' or 'build' mode.
2833// Vector3 camdif = (Vector3.One * Rotation - Vector3.One * CameraRotation); 2833// Vector3 camdif = (Vector3.One * Rotation - Vector3.One * CameraRotation);
@@ -3794,15 +3794,17 @@ namespace OpenSim.Region.Framework.Scenes
3794 // this does need to be more complex later 3794 // this does need to be more complex later
3795 Vector3 vel = Velocity; 3795 Vector3 vel = Velocity;
3796 Vector3 dpos = m_pos - m_lastPosition; 3796 Vector3 dpos = m_pos - m_lastPosition;
3797 if( Math.Abs(vel.X - m_lastVelocity.X) > VELOCITY_TOLERANCE || 3797 if( State != m_lastState ||
3798 Math.Abs(vel.X - m_lastVelocity.X) > VELOCITY_TOLERANCE ||
3798 Math.Abs(vel.Y - m_lastVelocity.Y) > VELOCITY_TOLERANCE || 3799 Math.Abs(vel.Y - m_lastVelocity.Y) > VELOCITY_TOLERANCE ||
3799 Math.Abs(vel.Z - m_lastVelocity.Z) > VELOCITY_TOLERANCE || 3800 Math.Abs(vel.Z - m_lastVelocity.Z) > VELOCITY_TOLERANCE ||
3800 3801
3801 Math.Abs(m_bodyRot.X - m_lastRotation.X) > ROTATION_TOLERANCE || 3802 Math.Abs(m_bodyRot.X - m_lastRotation.X) > ROTATION_TOLERANCE ||
3802 Math.Abs(m_bodyRot.Y - m_lastRotation.Y) > ROTATION_TOLERANCE || 3803 Math.Abs(m_bodyRot.Y - m_lastRotation.Y) > ROTATION_TOLERANCE ||
3803 Math.Abs(m_bodyRot.Z - m_lastRotation.Z) > ROTATION_TOLERANCE || 3804 Math.Abs(m_bodyRot.Z - m_lastRotation.Z) > ROTATION_TOLERANCE ||
3804 3805
3805 (vel == Vector3.Zero && m_lastVelocity != Vector3.Zero) || 3806 (vel == Vector3.Zero && m_lastVelocity != Vector3.Zero) ||
3807
3806 Math.Abs(dpos.X) > POSITION_LARGETOLERANCE || 3808 Math.Abs(dpos.X) > POSITION_LARGETOLERANCE ||
3807 Math.Abs(dpos.Y) > POSITION_LARGETOLERANCE || 3809 Math.Abs(dpos.Y) > POSITION_LARGETOLERANCE ||
3808 Math.Abs(dpos.Z) > POSITION_LARGETOLERANCE || 3810 Math.Abs(dpos.Z) > POSITION_LARGETOLERANCE ||
@@ -3811,7 +3813,12 @@ namespace OpenSim.Region.Framework.Scenes
3811 Math.Abs(dpos.Y) > POSITION_SMALLTOLERANCE || 3813 Math.Abs(dpos.Y) > POSITION_SMALLTOLERANCE ||
3812 Math.Abs(dpos.Z) > POSITION_SMALLTOLERANCE) 3814 Math.Abs(dpos.Z) > POSITION_SMALLTOLERANCE)
3813 && vel.LengthSquared() < LOWVELOCITYSQ 3815 && vel.LengthSquared() < LOWVELOCITYSQ
3814 )) 3816 ) ||
3817
3818 Math.Abs(CollisionPlane.X - m_lastCollisionPlane.X) > POSITION_SMALLTOLERANCE ||
3819 Math.Abs(CollisionPlane.Y - m_lastCollisionPlane.Y) > POSITION_SMALLTOLERANCE ||
3820 Math.Abs(CollisionPlane.W - m_lastCollisionPlane.W) > POSITION_SMALLTOLERANCE
3821 )
3815 { 3822 {
3816 SendTerseUpdateToAllClients(); 3823 SendTerseUpdateToAllClients();
3817 } 3824 }
@@ -3910,11 +3917,14 @@ namespace OpenSim.Region.Framework.Scenes
3910 /// </summary> 3917 /// </summary>
3911 public void SendTerseUpdateToAllClients() 3918 public void SendTerseUpdateToAllClients()
3912 { 3919 {
3913 m_scene.ForEachScenePresence(SendTerseUpdateToAgent); 3920 m_lastState = State;
3914 // Update the "last" values
3915 m_lastPosition = m_pos; 3921 m_lastPosition = m_pos;
3916 m_lastRotation = m_bodyRot; 3922 m_lastRotation = m_bodyRot;
3917 m_lastVelocity = Velocity; 3923 m_lastVelocity = Velocity;
3924 m_lastCollisionPlane = CollisionPlane;
3925
3926 m_scene.ForEachScenePresence(SendTerseUpdateToAgent);
3927 // Update the "last" values
3918 TriggerScenePresenceUpdated(); 3928 TriggerScenePresenceUpdated();
3919 } 3929 }
3920 3930