Fixed Animation Playback Track not seeking properly

Fixes #38093.
This commit is contained in:
Espeute Clement 2020-04-21 18:47:25 +02:00 committed by Rémi Verschelde
parent 173c0f8737
commit aa72af4f46
No known key found for this signature in database
GPG key ID: C3336907360768E1

View file

@ -737,7 +737,7 @@ void AnimationPlayer::_animation_process_animation(AnimationData *p_anim, double
if (anim->has_loop()) { if (anim->has_loop()) {
at_anim_pos = Math::fposmod(p_time - pos, (double)anim->get_length()); //seek to loop at_anim_pos = Math::fposmod(p_time - pos, (double)anim->get_length()); //seek to loop
} else { } else {
at_anim_pos = MAX((double)anim->get_length(), p_time - pos); //seek to end at_anim_pos = MIN((double)anim->get_length(), p_time - pos); //seek to end
} }
if (player->is_playing() || p_seeked) { if (player->is_playing() || p_seeked) {
@ -765,6 +765,7 @@ void AnimationPlayer::_animation_process_animation(AnimationData *p_anim, double
} }
} else { } else {
player->play(anim_name); player->play(anim_name);
player->seek(0.0, true);
nc->animation_playing = true; nc->animation_playing = true;
playing_caches.insert(nc); playing_caches.insert(nc);
} }