mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-26 09:35:28 +00:00
Don't store the animation group string in the character controller
This commit is contained in:
parent
849335d8cc
commit
9da2c9153e
@ -108,7 +108,8 @@ CharacterController::CharacterController(const MWWorld::Ptr &ptr, MWRender::Anim
|
|||||||
if(!mAnimation)
|
if(!mAnimation)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
getStateInfo(mState, &mCurrentGroup);
|
std::string group;
|
||||||
|
getStateInfo(mState, &group);
|
||||||
if(MWWorld::Class::get(mPtr).isActor())
|
if(MWWorld::Class::get(mPtr).isActor())
|
||||||
{
|
{
|
||||||
/* Accumulate along X/Y only for now, until we can figure out how we should
|
/* Accumulate along X/Y only for now, until we can figure out how we should
|
||||||
@ -120,8 +121,8 @@ CharacterController::CharacterController(const MWWorld::Ptr &ptr, MWRender::Anim
|
|||||||
/* Don't accumulate with non-actors. */
|
/* Don't accumulate with non-actors. */
|
||||||
mAnimation->setAccumulation(Ogre::Vector3(0.0f));
|
mAnimation->setAccumulation(Ogre::Vector3(0.0f));
|
||||||
}
|
}
|
||||||
if(mAnimation->hasAnimation(mCurrentGroup))
|
if(mAnimation->hasAnimation(group))
|
||||||
mMovingAnim = mAnimation->play(mCurrentGroup, "start", "stop", 1.0f, loop ? (~(size_t)0) : 0);
|
mMovingAnim = mAnimation->play(group, "start", "stop", 1.0f, loop ? (~(size_t)0) : 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
CharacterController::~CharacterController()
|
CharacterController::~CharacterController()
|
||||||
@ -214,10 +215,10 @@ void CharacterController::update(float duration, Movement &movement)
|
|||||||
setState((inwater ? CharState_IdleSwim : (sneak ? CharState_IdleSneak : CharState_Idle)), true);
|
setState((inwater ? CharState_IdleSwim : (sneak ? CharState_IdleSneak : CharState_Idle)), true);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
mCurrentGroup = mAnimQueue.front().first;
|
mMovingAnim = mAnimation->play(mAnimQueue.front().first,
|
||||||
size_t count = mAnimQueue.front().second;
|
"start", "stop", 0.0f,
|
||||||
|
mAnimQueue.front().second);
|
||||||
mAnimQueue.pop_front();
|
mAnimQueue.pop_front();
|
||||||
mMovingAnim = mAnimation->play(mCurrentGroup, "start", "stop", 0.0f, count);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -248,9 +249,8 @@ void CharacterController::playGroup(const std::string &groupname, int mode, int
|
|||||||
if(mode != 0 || getState() != CharState_SpecialIdle)
|
if(mode != 0 || getState() != CharState_SpecialIdle)
|
||||||
{
|
{
|
||||||
mAnimQueue.clear();
|
mAnimQueue.clear();
|
||||||
mCurrentGroup = groupname;
|
|
||||||
mState = CharState_SpecialIdle;
|
mState = CharState_SpecialIdle;
|
||||||
mMovingAnim = mAnimation->play(mCurrentGroup, ((mode==2) ? "loop start" : "start"), "stop", 0.0f, count-1);
|
mMovingAnim = mAnimation->play(groupname, ((mode==2) ? "loop start" : "start"), "stop", 0.0f, count-1);
|
||||||
}
|
}
|
||||||
else if(mode == 0)
|
else if(mode == 0)
|
||||||
{
|
{
|
||||||
@ -279,10 +279,7 @@ void CharacterController::setState(CharacterState state, bool loop)
|
|||||||
std::string anim;
|
std::string anim;
|
||||||
getStateInfo(mState, &anim);
|
getStateInfo(mState, &anim);
|
||||||
if((mMovingAnim=mAnimation->hasAnimation(anim)) != false)
|
if((mMovingAnim=mAnimation->hasAnimation(anim)) != false)
|
||||||
{
|
mMovingAnim = mAnimation->play(anim, "start", "stop", 0.0f, loop ? (~(size_t)0) : 0);
|
||||||
mCurrentGroup = anim;
|
|
||||||
mMovingAnim = mAnimation->play(mCurrentGroup, "start", "stop", 0.0f, loop ? (~(size_t)0) : 0);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -75,7 +75,6 @@ class CharacterController
|
|||||||
typedef std::deque<std::pair<std::string,size_t> > AnimationQueue;
|
typedef std::deque<std::pair<std::string,size_t> > AnimationQueue;
|
||||||
AnimationQueue mAnimQueue;
|
AnimationQueue mAnimQueue;
|
||||||
|
|
||||||
std::string mCurrentGroup;
|
|
||||||
CharacterState mState;
|
CharacterState mState;
|
||||||
bool mSkipAnim;
|
bool mSkipAnim;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user