summaryrefslogtreecommitdiffstats
path: root/scene/animation
diff options
context:
space:
mode:
authorNazarii <nazarii.yablonskyi.pp.2022@lpnu.ua>2024-10-31 18:47:17 +0200
committerNazarii <nazarii.yablonskyi.pp.2022@lpnu.ua>2024-10-31 19:26:02 +0200
commitd1dc7afdd5bf60bc14c34284c1fefb3836b65667 (patch)
treef65b914fb0d2a64130893a8320b5943e74e733e2 /scene/animation
parent61accf060515416da07d913580419fd8c8490f7b (diff)
downloadredot-engine-d1dc7afdd5bf60bc14c34284c1fefb3836b65667.tar.gz
Fix `capture_cache.animation` was not cached
Diffstat (limited to 'scene/animation')
-rw-r--r--scene/animation/animation_mixer.cpp37
-rw-r--r--scene/animation/animation_mixer.h1
2 files changed, 26 insertions, 12 deletions
diff --git a/scene/animation/animation_mixer.cpp b/scene/animation/animation_mixer.cpp
index 0fa6810d23..b40c677f6e 100644
--- a/scene/animation/animation_mixer.cpp
+++ b/scene/animation/animation_mixer.cpp
@@ -600,6 +600,22 @@ void AnimationMixer::_init_root_motion_cache() {
root_motion_scale_accumulator = Vector3(1, 1, 1);
}
+void AnimationMixer::_create_track_num_to_track_cashe_for_animation(Ref<Animation> &p_animation) {
+ ERR_FAIL_COND(animation_track_num_to_track_cashe.has(p_animation));
+ LocalVector<TrackCache *> &track_num_to_track_cashe = animation_track_num_to_track_cashe.insert_new(p_animation, LocalVector<TrackCache *>())->value;
+ const Vector<Animation::Track *> &tracks = p_animation->get_tracks();
+
+ track_num_to_track_cashe.resize(tracks.size());
+ for (int i = 0; i < tracks.size(); i++) {
+ TrackCache **track_ptr = track_cache.getptr(tracks[i]->thash);
+ if (track_ptr == nullptr) {
+ track_num_to_track_cashe[i] = nullptr;
+ } else {
+ track_num_to_track_cashe[i] = *track_ptr;
+ }
+ }
+}
+
bool AnimationMixer::_update_caches() {
setup_pass++;
@@ -928,20 +944,9 @@ bool AnimationMixer::_update_caches() {
}
animation_track_num_to_track_cashe.clear();
- LocalVector<TrackCache *> track_num_to_track_cashe;
for (const StringName &E : sname_list) {
Ref<Animation> anim = get_animation(E);
- const Vector<Animation::Track *> tracks = anim->get_tracks();
- track_num_to_track_cashe.resize(tracks.size());
- for (int i = 0; i < tracks.size(); i++) {
- TrackCache **track_ptr = track_cache.getptr(tracks[i]->thash);
- if (track_ptr == nullptr) {
- track_num_to_track_cashe[i] = nullptr;
- } else {
- track_num_to_track_cashe[i] = *track_ptr;
- }
- }
- animation_track_num_to_track_cashe.insert(anim, track_num_to_track_cashe);
+ _create_track_num_to_track_cashe_for_animation(anim);
}
track_count = idx;
@@ -1074,6 +1079,9 @@ void AnimationMixer::blend_capture(double p_delta) {
capture_cache.remain -= p_delta * capture_cache.step;
if (Animation::is_less_or_equal_approx(capture_cache.remain, 0)) {
+ if (capture_cache.animation.is_valid()) {
+ animation_track_num_to_track_cashe.erase(capture_cache.animation);
+ }
capture_cache.clear();
return;
}
@@ -2205,6 +2213,9 @@ void AnimationMixer::capture(const StringName &p_name, double p_duration, Tween:
capture_cache.step = 1.0 / p_duration;
capture_cache.trans_type = p_trans_type;
capture_cache.ease_type = p_ease_type;
+ if (capture_cache.animation.is_valid()) {
+ animation_track_num_to_track_cashe.erase(capture_cache.animation);
+ }
capture_cache.animation.instantiate();
bool is_valid = false;
@@ -2228,6 +2239,8 @@ void AnimationMixer::capture(const StringName &p_name, double p_duration, Tween:
}
if (!is_valid) {
capture_cache.clear();
+ } else {
+ _create_track_num_to_track_cashe_for_animation(capture_cache.animation);
}
}
diff --git a/scene/animation/animation_mixer.h b/scene/animation/animation_mixer.h
index 1906146c56..3769fa268c 100644
--- a/scene/animation/animation_mixer.h
+++ b/scene/animation/animation_mixer.h
@@ -321,6 +321,7 @@ protected:
void _clear_playing_caches();
void _init_root_motion_cache();
bool _update_caches();
+ void _create_track_num_to_track_cashe_for_animation(Ref<Animation> &p_animation);
/* ---- Audio ---- */
AudioServer::PlaybackType playback_type;