|
|
@ -476,9 +476,7 @@ void CharacterController::playGroup(const std::string &groupname, int mode, int
|
|
|
|
count = std::max(count, 1);
|
|
|
|
count = std::max(count, 1);
|
|
|
|
if(mode != 0 || mAnimQueue.size() == 0)
|
|
|
|
if(mode != 0 || mAnimQueue.size() == 0)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if(mAnimQueue.size() > 0)
|
|
|
|
clearAnimQueue();
|
|
|
|
mAnimation->disable(mAnimQueue.front().first);
|
|
|
|
|
|
|
|
mAnimQueue.clear();
|
|
|
|
|
|
|
|
mAnimQueue.push_back(std::make_pair(groupname, count-1));
|
|
|
|
mAnimQueue.push_back(std::make_pair(groupname, count-1));
|
|
|
|
|
|
|
|
|
|
|
|
mCharState = CharState_SpecialIdle;
|
|
|
|
mCharState = CharState_SpecialIdle;
|
|
|
@ -500,6 +498,14 @@ void CharacterController::skipAnim()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void CharacterController::clearAnimQueue()
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if(mAnimQueue.size() > 0)
|
|
|
|
|
|
|
|
mAnimation->disable(mAnimQueue.front().first);
|
|
|
|
|
|
|
|
mAnimQueue.clear();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void CharacterController::setState(CharacterState state)
|
|
|
|
void CharacterController::setState(CharacterState state)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if(mCharState == state)
|
|
|
|
if(mCharState == state)
|
|
|
@ -513,9 +519,7 @@ void CharacterController::forceStateUpdate()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if(!mAnimation)
|
|
|
|
if(!mAnimation)
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
if(mAnimQueue.size() > 0)
|
|
|
|
clearAnimQueue();
|
|
|
|
mAnimation->disable(mAnimQueue.front().first);
|
|
|
|
|
|
|
|
mAnimQueue.clear();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
std::string group;
|
|
|
|
std::string group;
|
|
|
|
Priority prio;
|
|
|
|
Priority prio;
|
|
|
|