Merge pull request #56648 from KoBeWi/tween_pause()
This commit is contained in:
commit
a095c4bf65
@ -303,16 +303,19 @@
|
|||||||
</signals>
|
</signals>
|
||||||
<constants>
|
<constants>
|
||||||
<constant name="TWEEN_PROCESS_PHYSICS" value="0" enum="TweenProcessMode">
|
<constant name="TWEEN_PROCESS_PHYSICS" value="0" enum="TweenProcessMode">
|
||||||
The [Tween] updates during physics frame.
|
The [Tween] updates during the physics frame.
|
||||||
</constant>
|
</constant>
|
||||||
<constant name="TWEEN_PROCESS_IDLE" value="1" enum="TweenProcessMode">
|
<constant name="TWEEN_PROCESS_IDLE" value="1" enum="TweenProcessMode">
|
||||||
The [Tween] updates during idle
|
The [Tween] updates during the idle frame.
|
||||||
</constant>
|
</constant>
|
||||||
<constant name="TWEEN_PAUSE_BOUND" value="0" enum="TweenPauseMode">
|
<constant name="TWEEN_PAUSE_BOUND" value="0" enum="TweenPauseMode">
|
||||||
|
If the [Tween] has a bound node, it will process when that node can process (see [member Node.process_mode]). Otherwise it's the same as [constant TWEEN_PAUSE_STOP].
|
||||||
</constant>
|
</constant>
|
||||||
<constant name="TWEEN_PAUSE_STOP" value="1" enum="TweenPauseMode">
|
<constant name="TWEEN_PAUSE_STOP" value="1" enum="TweenPauseMode">
|
||||||
|
If [SceneTree] is paused, the [Tween] will also pause.
|
||||||
</constant>
|
</constant>
|
||||||
<constant name="TWEEN_PAUSE_PROCESS" value="2" enum="TweenPauseMode">
|
<constant name="TWEEN_PAUSE_PROCESS" value="2" enum="TweenPauseMode">
|
||||||
|
The [Tween] will process regardless of whether [SceneTree] is paused.
|
||||||
</constant>
|
</constant>
|
||||||
<constant name="TRANS_LINEAR" value="0" enum="TransitionType">
|
<constant name="TRANS_LINEAR" value="0" enum="TransitionType">
|
||||||
The animation is interpolated linearly.
|
The animation is interpolated linearly.
|
||||||
|
@ -260,10 +260,8 @@ bool Tween::step(float p_delta) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (is_bound) {
|
if (is_bound) {
|
||||||
Object *bound_instance = ObjectDB::get_instance(bound_node);
|
Node *bound_node = get_bound_node();
|
||||||
if (bound_instance) {
|
if (bound_node) {
|
||||||
Node *bound_node = Object::cast_to<Node>(bound_instance);
|
|
||||||
// This can't by anything else than Node, so we can omit checking if casting succeeded.
|
|
||||||
if (!bound_node->is_inside_tree()) {
|
if (!bound_node->is_inside_tree()) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -320,16 +318,23 @@ bool Tween::step(float p_delta) {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Tween::should_pause() {
|
bool Tween::can_process(bool p_tree_paused) const {
|
||||||
if (is_bound && pause_mode == TWEEN_PAUSE_BOUND) {
|
if (is_bound && pause_mode == TWEEN_PAUSE_BOUND) {
|
||||||
Object *bound_instance = ObjectDB::get_instance(bound_node);
|
Node *bound_node = get_bound_node();
|
||||||
if (bound_instance) {
|
if (bound_node) {
|
||||||
Node *bound_node = Object::cast_to<Node>(bound_instance);
|
return bound_node->can_process();
|
||||||
return !bound_node->can_process();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return pause_mode != TWEEN_PAUSE_PROCESS;
|
return !p_tree_paused || pause_mode == TWEEN_PAUSE_PROCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
Node *Tween::get_bound_node() const {
|
||||||
|
if (is_bound) {
|
||||||
|
return Object::cast_to<Node>(ObjectDB::get_instance(bound_node));
|
||||||
|
} else {
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
real_t Tween::run_equation(TransitionType p_trans_type, EaseType p_ease_type, real_t p_time, real_t p_initial, real_t p_delta, real_t p_duration) {
|
real_t Tween::run_equation(TransitionType p_trans_type, EaseType p_ease_type, real_t p_time, real_t p_initial, real_t p_delta, real_t p_duration) {
|
||||||
|
@ -97,7 +97,7 @@ public:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
TweenProcessMode process_mode = TweenProcessMode::TWEEN_PROCESS_IDLE;
|
TweenProcessMode process_mode = TweenProcessMode::TWEEN_PROCESS_IDLE;
|
||||||
TweenPauseMode pause_mode = TweenPauseMode::TWEEN_PAUSE_STOP;
|
TweenPauseMode pause_mode = TweenPauseMode::TWEEN_PAUSE_BOUND;
|
||||||
TransitionType default_transition = TransitionType::TRANS_LINEAR;
|
TransitionType default_transition = TransitionType::TRANS_LINEAR;
|
||||||
EaseType default_ease = EaseType::EASE_IN_OUT;
|
EaseType default_ease = EaseType::EASE_IN_OUT;
|
||||||
ObjectID bound_node;
|
ObjectID bound_node;
|
||||||
@ -164,7 +164,8 @@ public:
|
|||||||
Variant calculate_delta_value(Variant p_intial_val, Variant p_final_val);
|
Variant calculate_delta_value(Variant p_intial_val, Variant p_final_val);
|
||||||
|
|
||||||
bool step(float p_delta);
|
bool step(float p_delta);
|
||||||
bool should_pause();
|
bool can_process(bool p_tree_paused) const;
|
||||||
|
Node *get_bound_node() const;
|
||||||
|
|
||||||
Tween() {}
|
Tween() {}
|
||||||
};
|
};
|
||||||
|
@ -535,7 +535,7 @@ void SceneTree::process_tweens(float p_delta, bool p_physics) {
|
|||||||
for (List<Ref<Tween>>::Element *E = tweens.front(); E;) {
|
for (List<Ref<Tween>>::Element *E = tweens.front(); E;) {
|
||||||
List<Ref<Tween>>::Element *N = E->next();
|
List<Ref<Tween>>::Element *N = E->next();
|
||||||
// Don't process if paused or process mode doesn't match.
|
// Don't process if paused or process mode doesn't match.
|
||||||
if ((paused && E->get()->should_pause()) || (p_physics == (E->get()->get_process_mode() == Tween::TWEEN_PROCESS_IDLE))) {
|
if (!E->get()->can_process(paused) || (p_physics == (E->get()->get_process_mode() == Tween::TWEEN_PROCESS_IDLE))) {
|
||||||
if (E == L) {
|
if (E == L) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user