Skip to content

Commit

Permalink
Merge pull request #46609 from jmb462/fix-no-tween-repeat-after-stop
Browse files Browse the repository at this point in the history
Fix no tween repeat after stop and restart (Fix #39801)
  • Loading branch information
akien-mga authored Mar 3, 2021
2 parents 43264c6 + b3d7adc commit 4d1f83a
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 1 deletion.
15 changes: 14 additions & 1 deletion scene/animation/tween.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -869,8 +869,21 @@ void Tween::start() {
return;
}

pending_update++;
for (List<InterpolateData>::Element *E = interpolates.front(); E; E = E->next()) {
InterpolateData &data = E->get();
data.active = true;
}
pending_update--;

// We want to be activated
set_active(true);

// Don't resume from current position if stop_all() function has been used
if (was_stopped) {
seek(0);
}
was_stopped = false;
}

void Tween::reset(Object *p_object, StringName p_key) {
Expand Down Expand Up @@ -939,7 +952,7 @@ void Tween::stop(Object *p_object, StringName p_key) {
void Tween::stop_all() {
// We no longer need to be active since all tweens have been stopped
set_active(false);

was_stopped = true;
// For each interpolation...
pending_update++;
for (List<InterpolateData>::Element *E = interpolates.front(); E; E = E->next()) {
Expand Down
1 change: 1 addition & 0 deletions scene/animation/tween.h
Original file line number Diff line number Diff line change
Expand Up @@ -107,6 +107,7 @@ class Tween : public Node {
float speed_scale = 1.0;
mutable int pending_update = 0;
int uid = 0;
bool was_stopped = false;

List<InterpolateData> interpolates;

Expand Down

0 comments on commit 4d1f83a

Please sign in to comment.