From 18c792fe42fcb01dce5cac8f8b3afed68320d229 Mon Sep 17 00:00:00 2001 From: SaracenOne Date: Mon, 9 Aug 2021 20:31:48 +0100 Subject: 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. --- scene/animation/animation_tree.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'scene/animation/animation_tree.cpp') 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) { -- cgit v1.2.3