|
|
@ -1023,50 +1023,54 @@ namespace MWRender
|
|
|
|
{
|
|
|
|
{
|
|
|
|
float targetTime;
|
|
|
|
float targetTime;
|
|
|
|
|
|
|
|
|
|
|
|
if(state.getTime() >= state.mLoopStopTime && state.mLoopCount > 0)
|
|
|
|
if (state.getTime() < state.mLoopStopTime || state.mLoopCount == 0)
|
|
|
|
goto handle_loop;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
targetTime = state.getTime() + timepassed;
|
|
|
|
|
|
|
|
if(textkey == textkeys.end() || textkey->first > targetTime)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if(mAccumCtrl && state.mTime == mAnimationTimePtr[0]->getTimePtr())
|
|
|
|
|
|
|
|
updatePosition(state.getTime(), targetTime, movement);
|
|
|
|
|
|
|
|
state.setTime(std::min(targetTime, state.mStopTime));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if(mAccumCtrl && state.mTime == mAnimationTimePtr[0]->getTimePtr())
|
|
|
|
targetTime = state.getTime() + timepassed;
|
|
|
|
updatePosition(state.getTime(), textkey->first, movement);
|
|
|
|
if(textkey == textkeys.end() || textkey->first > targetTime)
|
|
|
|
state.setTime(textkey->first);
|
|
|
|
{
|
|
|
|
}
|
|
|
|
if(mAccumCtrl && state.mTime == mAnimationTimePtr[0]->getTimePtr())
|
|
|
|
|
|
|
|
updatePosition(state.getTime(), targetTime, movement);
|
|
|
|
state.mPlaying = (state.getTime() < state.mStopTime);
|
|
|
|
state.setTime(std::min(targetTime, state.mStopTime));
|
|
|
|
timepassed = targetTime - state.getTime();
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
while(textkey != textkeys.end() && textkey->first <= state.getTime())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if(mAccumCtrl && state.mTime == mAnimationTimePtr[0]->getTimePtr())
|
|
|
|
handleTextKey(state, stateiter->first, textkey, textkeys);
|
|
|
|
updatePosition(state.getTime(), textkey->first, movement);
|
|
|
|
++textkey;
|
|
|
|
state.setTime(textkey->first);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if(state.getTime() >= state.mLoopStopTime && state.mLoopCount > 0)
|
|
|
|
state.mPlaying = (state.getTime() < state.mStopTime);
|
|
|
|
{
|
|
|
|
timepassed = targetTime - state.getTime();
|
|
|
|
handle_loop:
|
|
|
|
|
|
|
|
state.mLoopCount--;
|
|
|
|
|
|
|
|
state.setTime(state.mLoopStartTime);
|
|
|
|
|
|
|
|
state.mPlaying = true;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
textkey = textkeys.lower_bound(state.getTime());
|
|
|
|
|
|
|
|
while(textkey != textkeys.end() && textkey->first <= state.getTime())
|
|
|
|
while(textkey != textkeys.end() && textkey->first <= state.getTime())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
handleTextKey(state, stateiter->first, textkey, textkeys);
|
|
|
|
handleTextKey(state, stateiter->first, textkey, textkeys);
|
|
|
|
++textkey;
|
|
|
|
++textkey;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if(state.getTime() >= state.mLoopStopTime)
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(state.getTime() >= state.mLoopStopTime)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (!state.mLoopingEnabled)
|
|
|
|
|
|
|
|
state.mLoopCount = 0;
|
|
|
|
|
|
|
|
else if (state.mLoopCount > 0)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
state.mLoopCount--;
|
|
|
|
|
|
|
|
state.setTime(state.mLoopStartTime);
|
|
|
|
|
|
|
|
state.mPlaying = true;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
textkey = textkeys.lower_bound(state.getTime());
|
|
|
|
|
|
|
|
while(textkey != textkeys.end() && textkey->first <= state.getTime())
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
handleTextKey(state, stateiter->first, textkey, textkeys);
|
|
|
|
|
|
|
|
++textkey;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(state.getTime() >= state.mLoopStopTime)
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if(timepassed <= 0.0f)
|
|
|
|
if(timepassed <= 0.0f)
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -1095,6 +1099,21 @@ namespace MWRender
|
|
|
|
return movement;
|
|
|
|
return movement;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void Animation::setLoopingEnabled(const std::string &groupname, bool enabled)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
AnimStateMap::iterator state(mStates.find(groupname));
|
|
|
|
|
|
|
|
if(state != mStates.end())
|
|
|
|
|
|
|
|
state->second.mLoopingEnabled = enabled;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool Animation::getLoopingEnabled(const std::string &groupname) const
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
AnimStateMap::const_iterator state(mStates.find(groupname));
|
|
|
|
|
|
|
|
if(state != mStates.end())
|
|
|
|
|
|
|
|
return state->second.mLoopingEnabled;
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Animation::setObjectRoot(const std::string &model, bool forceskeleton, bool baseonly, bool isCreature)
|
|
|
|
void Animation::setObjectRoot(const std::string &model, bool forceskeleton, bool baseonly, bool isCreature)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
osg::ref_ptr<osg::StateSet> previousStateset;
|
|
|
|
osg::ref_ptr<osg::StateSet> previousStateset;
|
|
|
|