Avoid code duplication in character manager

0.6.3
Andrei Kortunov 7 years ago
parent e3812f4075
commit 0c92655250

@ -562,12 +562,8 @@ void CharacterController::refreshIdleAnims(const WeaponInfo* weap, CharacterStat
void CharacterController::refreshCurrentAnims(CharacterState idle, CharacterState movement, JumpingState jump, bool force) void CharacterController::refreshCurrentAnims(CharacterState idle, CharacterState movement, JumpingState jump, bool force)
{ {
// If the current animation is persistent, do not touch it // If the current animation is persistent, do not touch it
if (!mAnimQueue.empty()) if (isPersistentAnimPlaying())
{ return;
AnimationQueueEntry& first = mAnimQueue.front();
if (first.mPersist && isAnimPlaying(first.mGroup))
return;
}
if (mPtr.getClass().isActor()) if (mPtr.getClass().isActor())
refreshHitRecoilAnims(); refreshHitRecoilAnims();
@ -754,12 +750,8 @@ void CharacterController::playRandomDeath(float startpoint)
} }
// Do not interrupt scripted animation by death // Do not interrupt scripted animation by death
if (!mAnimQueue.empty()) if (isPersistentAnimPlaying())
{ return;
AnimationQueueEntry& first = mAnimQueue.front();
if (first.mPersist && isAnimPlaying(first.mGroup))
return;
}
playDeath(startpoint, mDeathState); playDeath(startpoint, mDeathState);
} }
@ -2154,12 +2146,8 @@ bool CharacterController::playGroup(const std::string &groupname, int mode, int
return false; return false;
// We should not interrupt persistent animations by non-persistent ones // We should not interrupt persistent animations by non-persistent ones
if (!mAnimQueue.empty()) if (isPersistentAnimPlaying() && !persist)
{ return false;
AnimationQueueEntry& first = mAnimQueue.front();
if (first.mPersist && !persist)
return false;
}
// If this animation is a looped animation (has a "loop start" key) that is already playing // If this animation is a looped animation (has a "loop start" key) that is already playing
// and has not yet reached the end of the loop, allow it to continue animating with its existing loop count // and has not yet reached the end of the loop, allow it to continue animating with its existing loop count
@ -2215,6 +2203,17 @@ void CharacterController::skipAnim()
mSkipAnim = true; mSkipAnim = true;
} }
bool CharacterController::isPersistentAnimPlaying()
{
if (!mAnimQueue.empty())
{
AnimationQueueEntry& first = mAnimQueue.front();
return first.mPersist && isAnimPlaying(first.mGroup);
}
return false;
}
bool CharacterController::isAnimPlaying(const std::string &groupName) bool CharacterController::isAnimPlaying(const std::string &groupName)
{ {
if(mAnimation == NULL) if(mAnimation == NULL)
@ -2222,16 +2221,11 @@ bool CharacterController::isAnimPlaying(const std::string &groupName)
return mAnimation->isPlaying(groupName); return mAnimation->isPlaying(groupName);
} }
void CharacterController::clearAnimQueue() void CharacterController::clearAnimQueue()
{ {
// Do not interrupt scripted animations // Do not interrupt scripted animations
if (!mAnimQueue.empty()) if (!isPersistentAnimPlaying() && !mAnimQueue.empty())
{ mAnimation->disable(mAnimQueue.front().mGroup);
AnimationQueueEntry& first = mAnimQueue.front();
if (!first.mPersist)
mAnimation->disable(mAnimQueue.front().mGroup);
}
for (AnimationQueue::iterator it = mAnimQueue.begin(); it != mAnimQueue.end();) for (AnimationQueue::iterator it = mAnimQueue.begin(); it != mAnimQueue.end();)
{ {

@ -221,6 +221,8 @@ class CharacterController : public MWRender::Animation::TextKeyListener
bool updateCreatureState(); bool updateCreatureState();
void updateIdleStormState(bool inwater); void updateIdleStormState(bool inwater);
bool isPersistentAnimPlaying();
void updateAnimQueue(); void updateAnimQueue();
void updateHeadTracking(float duration); void updateHeadTracking(float duration);

Loading…
Cancel
Save