summaryrefslogtreecommitdiffstats
path: root/scene/animation/animation_tree.cpp
diff options
context:
space:
mode:
authorSilc Lizard (Tokage) Renew <61938263+TokageItLab@users.noreply.github.com>2023-12-06 00:42:31 +0900
committerSilc Lizard (Tokage) Renew <61938263+TokageItLab@users.noreply.github.com>2023-12-06 02:29:29 +0900
commit5acf6b4ca6360bb53a4f67bde207a730170d00b2 (patch)
treece9679ecfdf5de7472f4a9ffbaf8680ef4b05f07 /scene/animation/animation_tree.cpp
parent7ed7ea53e6221eff6e6bf1e357706533e9a31e8c (diff)
downloadredot-engine-5acf6b4ca6360bb53a4f67bde207a730170d00b2.tar.gz
Remove differences of the code between old AnimationTree and Mixer
Diffstat (limited to 'scene/animation/animation_tree.cpp')
-rw-r--r--scene/animation/animation_tree.cpp18
1 files changed, 9 insertions, 9 deletions
diff --git a/scene/animation/animation_tree.cpp b/scene/animation/animation_tree.cpp
index bdadc4ecac..e24816122c 100644
--- a/scene/animation/animation_tree.cpp
+++ b/scene/animation/animation_tree.cpp
@@ -100,9 +100,9 @@ void AnimationNode::blend_animation(const StringName &p_animation, AnimationMixe
process_state->tree->make_animation_instance(p_animation, p_playback_info);
}
-double AnimationNode::_pre_process(ProcessState *p_process_state, AnimationMixer::PlaybackInfo p_playback_info) {
+double AnimationNode::_pre_process(ProcessState *p_process_state, AnimationMixer::PlaybackInfo p_playback_info, bool p_test_only) {
process_state = p_process_state;
- double t = process(p_playback_info);
+ double t = process(p_playback_info, p_test_only);
process_state = nullptr;
return t;
}
@@ -152,7 +152,7 @@ double AnimationNode::blend_input(int p_input, AnimationMixer::PlaybackInfo p_pl
}
double AnimationNode::blend_node(Ref<AnimationNode> p_node, const StringName &p_subpath, AnimationMixer::PlaybackInfo p_playback_info, FilterAction p_filter, bool p_sync, bool p_test_only) {
- node_state.connections.clear();
+ p_node->node_state.connections.clear();
return _blend_node(p_node, p_subpath, this, p_playback_info, p_filter, p_sync, p_test_only, nullptr);
}
@@ -269,9 +269,9 @@ double AnimationNode::_blend_node(Ref<AnimationNode> p_node, const StringName &p
p_node->node_state.parent = new_parent;
if (!p_playback_info.seeked && !p_sync && !any_valid) {
p_playback_info.time = 0.0;
- return p_node->_pre_process(process_state, p_playback_info);
+ return p_node->_pre_process(process_state, p_playback_info, p_test_only);
}
- return p_node->_pre_process(process_state, p_playback_info);
+ return p_node->_pre_process(process_state, p_playback_info, p_test_only);
}
String AnimationNode::get_caption() const {
@@ -565,12 +565,12 @@ bool AnimationTree::_blend_pre_process(double p_delta, int p_track_count, const
if (started) {
// If started, seek.
pi.seeked = true;
- root_animation_node->_pre_process(&process_state, pi);
+ root_animation_node->_pre_process(&process_state, pi, false);
started = false;
- } else {
- pi.time = p_delta;
- root_animation_node->_pre_process(&process_state, pi);
}
+ pi.seeked = false;
+ pi.time = p_delta;
+ root_animation_node->_pre_process(&process_state, pi, false);
}
if (!process_state.valid) {