X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Fobject%2Fsprite_particle.cpp;h=f5434fdac97186022811c939b53388219a9ef2a6;hb=7e15c4f871809033278711a6e9327616da00c4c9;hp=2dfee79ea713a97ce22b4bf9f13bc4ca4600006d;hpb=3e89eb527d5f3bca2cb8cd219784048764a148f5;p=supertux.git diff --git a/src/object/sprite_particle.cpp b/src/object/sprite_particle.cpp index 2dfee79ea..f5434fdac 100644 --- a/src/object/sprite_particle.cpp +++ b/src/object/sprite_particle.cpp @@ -17,6 +17,7 @@ // You should have received a copy of the GNU General Public License // along with this program; if not, write to the Free Software // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +#include #include #include "sprite_particle.hpp" @@ -25,17 +26,18 @@ #include "main.hpp" #include "log.hpp" -SpriteParticle::SpriteParticle(std::string sprite_name, std::string action, Vector position, AnchorPoint anchor, Vector velocity, Vector acceleration, int drawing_layer) - : position(position), velocity(velocity), acceleration(acceleration), drawing_layer(drawing_layer) +SpriteParticle::SpriteParticle(std::string sprite_name, std::string action, Vector position, AnchorPoint anchor, Vector velocity, Vector acceleration, int drawing_layer) + : position(position), velocity(velocity), acceleration(acceleration), drawing_layer(drawing_layer) { sprite = sprite_manager->create(sprite_name); if (!sprite) throw std::runtime_error("Could not load sprite "+sprite_name); sprite->set_action(action, 1); + sprite->set_animation_loops(1); //TODO: this is necessary because set_action will not set "loops" when "action" is the default action this->position -= get_anchor_pos(sprite->get_current_hitbox(), anchor); } - -SpriteParticle::~SpriteParticle() + +SpriteParticle::~SpriteParticle() { remove_me(); } @@ -46,7 +48,7 @@ SpriteParticle::hit(Player& ) } void -SpriteParticle::update(float elapsed_time) +SpriteParticle::update(float elapsed_time) { // die when animation is complete if (sprite->animation_done()) { @@ -62,7 +64,7 @@ SpriteParticle::update(float elapsed_time) // die when too far offscreen Vector camera = Sector::current()->camera->get_translation(); - if ((position.x < camera.x - 128) || (position.x > SCREEN_WIDTH + camera.x + 128) || + if ((position.x < camera.x - 128) || (position.x > SCREEN_WIDTH + camera.x + 128) || (position.y < camera.y - 128) || (position.y > SCREEN_HEIGHT + camera.y + 128)) { remove_me(); return; @@ -70,7 +72,7 @@ SpriteParticle::update(float elapsed_time) } void -SpriteParticle::draw(DrawingContext& context) +SpriteParticle::draw(DrawingContext& context) { sprite->draw(context, position, drawing_layer); }