summaryrefslogtreecommitdiffstats
path: root/scene/animation/animation_tree.cpp
diff options
context:
space:
mode:
authorSaracenOne <SaracenOne@gmail.com>2021-08-09 20:31:48 +0100
committerSaracen <SaracenOne@gmail.com>2023-05-18 20:02:43 +0100
commit18c792fe42fcb01dce5cac8f8b3afed68320d229 (patch)
tree2aa004584cbe8c6b4c9d2bdf68b5344a1449785b /scene/animation/animation_tree.cpp
parent0032c1c0c203ba225dd41bdc799f2e622bccfde5 (diff)
downloadredot-engine-18c792fe42fcb01dce5cac8f8b3afed68320d229.tar.gz
Allocate unique track_blends vector for animation states.
Quick fix for a bug which occurs when blending the result of multiple instanced state machines outputting the same animation, but using filter tracks.
Diffstat (limited to 'scene/animation/animation_tree.cpp')
-rw-r--r--scene/animation/animation_tree.cpp4
1 files changed, 2 insertions, 2 deletions
diff --git a/scene/animation/animation_tree.cpp b/scene/animation/animation_tree.cpp
index c6cb3873e0..5d4d58f283 100644
--- a/scene/animation/animation_tree.cpp
+++ b/scene/animation/animation_tree.cpp
@@ -116,7 +116,7 @@ void AnimationNode::blend_animation(const StringName &p_animation, double p_time
AnimationState anim_state;
anim_state.blend = p_blend;
- anim_state.track_blends = &blends;
+ anim_state.track_blends = blends;
anim_state.delta = p_delta;
anim_state.time = p_time;
anim_state.animation = animation;
@@ -1124,7 +1124,7 @@ void AnimationTree::_process_graph(double p_delta) {
ERR_CONTINUE(!state.track_map.has(path));
int blend_idx = state.track_map[path];
ERR_CONTINUE(blend_idx < 0 || blend_idx >= state.track_count);
- real_t blend = (*as.track_blends)[blend_idx] * weight;
+ real_t blend = (as.track_blends)[blend_idx] * weight;
Animation::TrackType ttype = a->track_get_type(i);
if (ttype != Animation::TYPE_POSITION_3D && ttype != Animation::TYPE_ROTATION_3D && ttype != Animation::TYPE_SCALE_3D && track->type != ttype) {