X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Fbadguy%2Fmriceblock.hpp;h=ddf3847aa48e8b836ff8ed60682b35582f55f74e;hb=8b8e1c3576cedddb1d88eafa5fd4804e8257793c;hp=7ded21a37a70f79687a05401ec5f3a1f76dde8ae;hpb=4c9b57d29e67f9db5605f378549b07f670baa837;p=supertux.git diff --git a/src/badguy/mriceblock.hpp b/src/badguy/mriceblock.hpp index 7ded21a37..ddf3847aa 100644 --- a/src/badguy/mriceblock.hpp +++ b/src/badguy/mriceblock.hpp @@ -20,29 +20,34 @@ #ifndef __MRICEBLOCK_H__ #define __MRICEBLOCK_H__ -#include "badguy.hpp" +#include "walking_badguy.hpp" #include "object/portable.hpp" -class MrIceBlock : public BadGuy, public Portable +class MrIceBlock : public WalkingBadguy, public Portable { public: MrIceBlock(const lisp::Lisp& reader); - MrIceBlock(float pos_x, float pos_y, Direction d); + MrIceBlock(const Vector& pos, Direction d); - void activate(); + void initialize(); void write(lisp::Writer& writer); HitResponse collision(GameObject& object, const CollisionHit& hit); - HitResponse collision_solid(GameObject& object, const CollisionHit& hit); + void collision_solid(const CollisionHit& hit); HitResponse collision_badguy(BadGuy& badguy, const CollisionHit& hit); HitResponse collision_player(Player& player, const CollisionHit& hit); void active_update(float elapsed_time); - + void grab(MovingObject& object, const Vector& pos, Direction dir); void ungrab(MovingObject& object, Direction dir); + bool is_portable() const; + + bool can_break(); + + virtual MrIceBlock* clone() const { return new MrIceBlock(*this); } protected: - bool collision_squished(Player& player); + bool collision_squished(GameObject& object); private: enum IceState { @@ -53,13 +58,11 @@ private: }; void set_state(IceState state); - + IceState ice_state; + Timer nokick_timer; Timer flat_timer; int squishcount; - bool set_direction; - Direction initial_direction; }; #endif -