1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-25 06:35:30 +00:00

Scale animation speed using the direction length

The direction length doesn't currently give a good speed, but it's something.
This commit is contained in:
Chris Robinson 2013-01-18 21:40:47 -08:00
parent aecfc0829a
commit 0b68953f0d
4 changed files with 21 additions and 12 deletions

View File

@ -118,6 +118,17 @@ void CharacterController::markerEvent(float time, const std::string &evt)
}
void CharacterController::setDirection(const Ogre::Vector3 &dir)
{
// HACK: The direction length we get is too large.
float mult = dir.length() / 32.0f;
mult = std::max(1.0f, mult);
if(mAnimation)
mAnimation->setSpeedMult(mult);
mDirection = dir.normalisedCopy();
}
Ogre::Vector3 CharacterController::update(float duration)
{
Ogre::Vector3 movement = Ogre::Vector3::ZERO;
@ -125,17 +136,10 @@ Ogre::Vector3 CharacterController::update(float duration)
movement += mAnimation->runAnimation(duration);
mSkipAnim = false;
if(getState() == CharState_SpecialIdle || getState() == CharState_Idle ||
getState() == CharState_Dead)
if(!(getState() == CharState_SpecialIdle || getState() == CharState_Idle ||
getState() == CharState_Dead))
{
// FIXME: mDirection shouldn't influence the movement here.
movement += mDirection;
}
else
{
// FIXME: mDirection should be normalized after setting the speed of
// the animation in setDirection, rather than here.
movement = mDirection.normalisedCopy() * movement.length();
movement = mDirection * movement.length();
}
return movement;

View File

@ -54,8 +54,7 @@ public:
void playGroup(const std::string &groupname, int mode, int count);
void skipAnim();
void setDirection(const Ogre::Vector3 &dir)
{ mDirection = dir; }
void setDirection(const Ogre::Vector3 &dir);
void setState(CharacterState state);
CharacterState getState() const

View File

@ -26,6 +26,7 @@ Animation::Animation(const MWWorld::Ptr &ptr)
, mLastPosition(0.0f)
, mCurrentKeys(NULL)
, mAnimState(NULL)
, mAnimSpeedMult(1.0f)
{
}
@ -207,6 +208,7 @@ void Animation::play(const std::string &groupname, const std::string &start)
Ogre::Vector3 Animation::runAnimation(float timepassed)
{
Ogre::Vector3 movement = Ogre::Vector3::ZERO;
timepassed *= mAnimSpeedMult;
while(mAnimState && timepassed > 0.0f)
{
float targetTime = mAnimState->getTimePosition() + timepassed;

View File

@ -31,6 +31,7 @@ protected:
NifOgre::TextKeyMap *mCurrentKeys;
NifOgre::TextKeyMap::const_iterator mNextKey;
Ogre::AnimationState *mAnimState;
float mAnimSpeedMult;
/* Updates the animation to the specified time, and returns the movement
* vector since the last update or reset. */
@ -54,6 +55,9 @@ public:
// should be on the scale of 0 to 1.
void setAccumulation(const Ogre::Vector3 &accum);
void setSpeedMult(float speedmult)
{ mAnimSpeedMult = speedmult; }
void play(const std::string &groupname, const std::string &start);
virtual Ogre::Vector3 runAnimation(float timepassed);
};