Merge pull request #1772 from akortunov/deathanim

Fast-forward death animation to end if death animation was finished earlier
This commit is contained in:
Bret Curtis 2018-06-20 13:28:36 +02:00 committed by GitHub
commit b619c0de2d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -2026,10 +2026,11 @@ void CharacterController::update(float duration)
{
// initial start of death animation for actors that started the game as dead
// not done in constructor since we need to give scripts a chance to set the mSkipAnim flag
if (!mSkipAnim && mDeathState != CharState_None && mCurrentDeath.empty() && cls.isPersistent(mPtr))
if (!mSkipAnim && mDeathState != CharState_None && mCurrentDeath.empty())
{
// Fast-forward death animation to end for persisting corpses
playDeath(1.f, mDeathState);
// Fast-forward death animation to end for persisting corpses or corpses after end of death animation
if (cls.isPersistent(mPtr) || cls.getCreatureStats(mPtr).isDeathAnimationFinished())
playDeath(1.f, mDeathState);
}
// We must always queue movement, even if there is none, to apply gravity.
world->queueMovement(mPtr, osg::Vec3f(0.f, 0.f, 0.f));