mirror of
https://github.com/godotengine/godot.git
synced 2025-01-18 20:40:57 +08:00
Fixed animation audio to play considering time when seeking
This commit is contained in:
parent
0b1d516f67
commit
b9b8130432
@ -857,7 +857,7 @@ void AnimationPlayer::_animation_process_animation(AnimationData *p_anim, double
|
|||||||
HashMap<int, TrackNodeCache::PlayingAudioStreamInfo> &map = aa->playing_streams;
|
HashMap<int, TrackNodeCache::PlayingAudioStreamInfo> &map = aa->playing_streams;
|
||||||
// Find stream.
|
// Find stream.
|
||||||
int idx = -1;
|
int idx = -1;
|
||||||
if (p_seeked) {
|
if (p_seeked || p_started) {
|
||||||
idx = a->track_find_key(i, p_time);
|
idx = a->track_find_key(i, p_time);
|
||||||
// Discard previous stream when seeking.
|
// Discard previous stream when seeking.
|
||||||
if (map.has(idx)) {
|
if (map.has(idx)) {
|
||||||
@ -866,12 +866,7 @@ void AnimationPlayer::_animation_process_animation(AnimationData *p_anim, double
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
List<int> to_play;
|
List<int> to_play;
|
||||||
if (p_started) {
|
|
||||||
int first_key = a->track_find_key(i, p_prev_time, Animation::FIND_MODE_EXACT);
|
|
||||||
if (first_key >= 0) {
|
|
||||||
to_play.push_back(first_key);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
a->track_get_key_indices_in_range(i, p_time, p_delta, &to_play, p_looped_flag);
|
a->track_get_key_indices_in_range(i, p_time, p_delta, &to_play, p_looped_flag);
|
||||||
if (to_play.size()) {
|
if (to_play.size()) {
|
||||||
idx = to_play.back()->get();
|
idx = to_play.back()->get();
|
||||||
@ -888,6 +883,10 @@ void AnimationPlayer::_animation_process_animation(AnimationData *p_anim, double
|
|||||||
double end_ofs = a->audio_track_get_key_end_offset(i, idx);
|
double end_ofs = a->audio_track_get_key_end_offset(i, idx);
|
||||||
double len = stream->get_length();
|
double len = stream->get_length();
|
||||||
|
|
||||||
|
if (p_seeked || p_started) {
|
||||||
|
start_ofs += p_time - a->track_get_key_time(i, idx);
|
||||||
|
}
|
||||||
|
|
||||||
if (aa->object->call(SNAME("get_stream")) != aa->audio_stream) {
|
if (aa->object->call(SNAME("get_stream")) != aa->audio_stream) {
|
||||||
aa->object->call(SNAME("set_stream"), aa->audio_stream);
|
aa->object->call(SNAME("set_stream"), aa->audio_stream);
|
||||||
aa->audio_stream_playback.unref();
|
aa->audio_stream_playback.unref();
|
||||||
@ -1286,6 +1285,8 @@ void AnimationPlayer::_animation_process(double p_delta) {
|
|||||||
_animation_update_transforms();
|
_animation_update_transforms();
|
||||||
|
|
||||||
if (end_reached) {
|
if (end_reached) {
|
||||||
|
_clear_audio_streams();
|
||||||
|
_stop_playing_caches(false);
|
||||||
if (queued.size()) {
|
if (queued.size()) {
|
||||||
String old = playback.assigned;
|
String old = playback.assigned;
|
||||||
play(queued.front()->get());
|
play(queued.front()->get());
|
||||||
|
@ -1546,6 +1546,10 @@ void AnimationTree::_process_graph(double p_delta) {
|
|||||||
double end_ofs = a->audio_track_get_key_end_offset(i, idx);
|
double end_ofs = a->audio_track_get_key_end_offset(i, idx);
|
||||||
double len = stream->get_length();
|
double len = stream->get_length();
|
||||||
|
|
||||||
|
if (seeked) {
|
||||||
|
start_ofs += time - a->track_get_key_time(i, idx);
|
||||||
|
}
|
||||||
|
|
||||||
if (t->object->call(SNAME("get_stream")) != t->audio_stream) {
|
if (t->object->call(SNAME("get_stream")) != t->audio_stream) {
|
||||||
t->object->call(SNAME("set_stream"), t->audio_stream);
|
t->object->call(SNAME("set_stream"), t->audio_stream);
|
||||||
t->audio_stream_playback.unref();
|
t->audio_stream_playback.unref();
|
||||||
|
Loading…
Reference in New Issue
Block a user