1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-26 18:35:20 +00:00
OpenMW/apps/openmw/mwmechanics/steering.cpp

49 lines
1.3 KiB
C++
Raw Normal View History

2014-01-29 20:29:07 +01:00
#include "steering.hpp"
#include "../mwworld/class.hpp"
#include "../mwworld/ptr.hpp"
#include "../mwbase/environment.hpp"
#include "movement.hpp"
namespace MWMechanics
{
2015-06-03 19:41:19 +02:00
bool smoothTurn(const MWWorld::Ptr& actor, float targetAngleRadians, int axis, float epsilonRadians)
{
2015-06-03 19:41:19 +02:00
float currentAngle (actor.getRefData().getPosition().rot[axis]);
float diff (targetAngleRadians - currentAngle);
if (std::abs(diff) >= osg::DegreesToRadians(180.f))
{
if (diff >= 0)
{
diff = diff - osg::DegreesToRadians(360.f);
}
else
{
diff = osg::DegreesToRadians(360.f) + diff;
}
}
2015-06-03 19:41:19 +02:00
float absDiff = std::abs(diff);
// The turning animation actually moves you slightly, so the angle will be wrong again.
// Use epsilon to prevent jerkiness.
2015-06-03 19:41:19 +02:00
if (absDiff < epsilonRadians)
return true;
2015-06-03 19:41:19 +02:00
float limit = MAX_VEL_ANGULAR_RADIANS * MWBase::Environment::get().getFrameDuration();
if (absDiff > limit)
2015-06-03 19:41:19 +02:00
diff = osg::sign(diff) * limit;
2015-06-03 19:41:19 +02:00
actor.getClass().getMovementSettings(actor).mRotation[axis] = diff;
return false;
}
2015-06-03 19:41:19 +02:00
bool zTurn(const MWWorld::Ptr& actor, float targetAngleRadians, float epsilonRadians)
2014-01-29 20:29:07 +01:00
{
2015-06-03 19:41:19 +02:00
return smoothTurn(actor, targetAngleRadians, 2, epsilonRadians);
2014-01-29 20:29:07 +01:00
}
}