summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndreyL ProductEngine <alihatskiy@productengine.com>2017-10-16 15:23:13 +0300
committerAndreyL ProductEngine <alihatskiy@productengine.com>2017-10-16 15:23:13 +0300
commitc582029269d6eb60d50ac7af8cd3415c9448dd75 (patch)
tree45a6080278774c58cdd41596ef829664d5e9542c
parent252ca2542b8af646295ad51cf7acff31f03754be (diff)
parent86314969e6cbb5bb9b3fdedfafc3d82d9d57f854 (diff)
Merged in lindenlab/viewer-lynx
-rw-r--r--indra/newview/llphysicsmotion.cpp12
1 files changed, 5 insertions, 7 deletions
diff --git a/indra/newview/llphysicsmotion.cpp b/indra/newview/llphysicsmotion.cpp
index 65b57a2790..ea10d03264 100644
--- a/indra/newview/llphysicsmotion.cpp
+++ b/indra/newview/llphysicsmotion.cpp
@@ -44,7 +44,7 @@ typedef std::map<std::string, std::string> controller_map_t;
typedef std::map<std::string, F32> default_controller_map_t;
#define MIN_REQUIRED_PIXEL_AREA_AVATAR_PHYSICS_MOTION 0.f
-#define TIME_ITERATION_STEP 0.033f // roughtly 30 fps
+#define TIME_ITERATION_STEP 0.1f
inline F64 llsgn(const F64 a)
{
@@ -493,8 +493,8 @@ BOOL LLPhysicsMotion::onUpdate(F32 time)
const F32 time_delta = time - mLastTime;
- // Don't update too frequently (below 0.01), to avoid precision errors from small time slices.
- if (time_delta <= TIME_ITERATION_STEP)
+ // Don't update too frequently, to avoid precision errors from small time slices.
+ if (time_delta <= .01)
{
return FALSE;
}
@@ -561,10 +561,7 @@ BOOL LLPhysicsMotion::onUpdate(F32 time)
F32 time_iteration_step = TIME_ITERATION_STEP;
if (time_iteration + TIME_ITERATION_STEP > time_delta)
{
- time_iteration_step = time_delta - time_iteration;
- // Leave the rest for next update.
- mLastTime = time - time_iteration_step;
- break;
+ time_iteration_step = time_delta-time_iteration;
}
// mPositon_local should be in normalized 0,1 range already. Just making sure...
@@ -719,6 +716,7 @@ BOOL LLPhysicsMotion::onUpdate(F32 time)
mAccelerationJoint_local = acceleration_joint_local;
mPosition_local = position_new_local;
}
+ mLastTime = time;
mPosition_world = joint->getWorldPosition();
mVelocityJoint_local = velocity_joint_local;