Make AnimatedSprite able to play backwards

(cherry picked from commit 4a2c433028)
This commit is contained in:
Michael Alexsander Silva Dias 2019-03-17 04:03:23 -03:00 committed by Hein-Pieter van Braam-Stewart
parent 42fa261563
commit 94f6c3a810
3 changed files with 23 additions and 8 deletions

View file

@ -22,7 +22,7 @@
<argument index="0" name="anim" type="String" default="&quot;&quot;"> <argument index="0" name="anim" type="String" default="&quot;&quot;">
</argument> </argument>
<description> <description>
Play the animation set in parameter. If no parameter is provided, the current animation is played. Play the animation set in parameter. If no parameter is provided, the current animation is played. Property [code]backwards[/code] plays the animation in reverse if set to [code]true[/code].
</description> </description>
</method> </method>
<method name="stop"> <method name="stop">

View file

@ -393,19 +393,30 @@ void AnimatedSprite::_notification(int p_what) {
timeout = _get_frame_duration(); timeout = _get_frame_duration();
int fc = frames->get_frame_count(animation); int fc = frames->get_frame_count(animation);
if (frame >= fc - 1) { if ((!backwards && frame >= fc - 1) || (backwards && frame <= 0)) {
if (frames->get_animation_loop(animation)) { if (frames->get_animation_loop(animation)) {
frame = 0; if (backwards)
frame = fc - 1;
else
frame = 0;
emit_signal(SceneStringNames::get_singleton()->animation_finished); emit_signal(SceneStringNames::get_singleton()->animation_finished);
} else { } else {
frame = fc - 1; if (backwards)
frame = 0;
else
frame = fc - 1;
if (!is_over) { if (!is_over) {
is_over = true; is_over = true;
emit_signal(SceneStringNames::get_singleton()->animation_finished); emit_signal(SceneStringNames::get_singleton()->animation_finished);
} }
} }
} else { } else {
frame++; if (backwards)
frame--;
else
frame++;
} }
update(); update();
@ -594,10 +605,12 @@ bool AnimatedSprite::_is_playing() const {
return playing; return playing;
} }
void AnimatedSprite::play(const StringName &p_animation) { void AnimatedSprite::play(const StringName &p_animation, const bool p_backwards) {
if (p_animation) if (p_animation)
set_animation(p_animation); set_animation(p_animation);
backwards = p_backwards;
_set_playing(true); _set_playing(true);
} }
@ -666,7 +679,7 @@ void AnimatedSprite::_bind_methods() {
ClassDB::bind_method(D_METHOD("_set_playing", "playing"), &AnimatedSprite::_set_playing); ClassDB::bind_method(D_METHOD("_set_playing", "playing"), &AnimatedSprite::_set_playing);
ClassDB::bind_method(D_METHOD("_is_playing"), &AnimatedSprite::_is_playing); ClassDB::bind_method(D_METHOD("_is_playing"), &AnimatedSprite::_is_playing);
ClassDB::bind_method(D_METHOD("play", "anim"), &AnimatedSprite::play, DEFVAL(StringName())); ClassDB::bind_method(D_METHOD("play", "anim", "backwards"), &AnimatedSprite::play, DEFVAL(StringName()));
ClassDB::bind_method(D_METHOD("stop"), &AnimatedSprite::stop); ClassDB::bind_method(D_METHOD("stop"), &AnimatedSprite::stop);
ClassDB::bind_method(D_METHOD("is_playing"), &AnimatedSprite::is_playing); ClassDB::bind_method(D_METHOD("is_playing"), &AnimatedSprite::is_playing);
@ -713,6 +726,7 @@ AnimatedSprite::AnimatedSprite() {
frame = 0; frame = 0;
speed_scale = 1.0f; speed_scale = 1.0f;
playing = false; playing = false;
backwards = false;
animation = "default"; animation = "default";
timeout = 0; timeout = 0;
is_over = false; is_over = false;

View file

@ -128,6 +128,7 @@ class AnimatedSprite : public Node2D {
Ref<SpriteFrames> frames; Ref<SpriteFrames> frames;
bool playing; bool playing;
bool backwards;
StringName animation; StringName animation;
int frame; int frame;
float speed_scale; float speed_scale;
@ -169,7 +170,7 @@ public:
void set_sprite_frames(const Ref<SpriteFrames> &p_frames); void set_sprite_frames(const Ref<SpriteFrames> &p_frames);
Ref<SpriteFrames> get_sprite_frames() const; Ref<SpriteFrames> get_sprite_frames() const;
void play(const StringName &p_animation = StringName()); void play(const StringName &p_animation = StringName(), const bool p_backwards = false);
void stop(); void stop();
bool is_playing() const; bool is_playing() const;