X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Fbadguy%2Fmriceblock.hpp;h=6254527ef10ba3983b366c7f35b864f03312dfb2;hb=1ca8026695fc4a10187178c91616c38fecfcc755;hp=26546c4e812e34a8316fc8e2bd6442f426e4789d;hpb=a113d3bd1feddd510e3b2852b0d42522735eee40;p=supertux.git diff --git a/src/badguy/mriceblock.hpp b/src/badguy/mriceblock.hpp index 26546c4e8..6254527ef 100644 --- a/src/badguy/mriceblock.hpp +++ b/src/badguy/mriceblock.hpp @@ -1,12 +1,10 @@ -// $Id$ -// // SuperTux // Copyright (C) 2006 Matthias Braun // -// This program is free software; you can redistribute it and/or -// modify it under the terms of the GNU General Public License -// as published by the Free Software Foundation; either version 2 -// of the License, or (at your option) any later version. +// This program is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of @@ -14,23 +12,22 @@ // GNU General Public License for more details. // // 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. +// along with this program. If not, see . -#ifndef __MRICEBLOCK_H__ -#define __MRICEBLOCK_H__ +#ifndef HEADER_SUPERTUX_BADGUY_MRICEBLOCK_HPP +#define HEADER_SUPERTUX_BADGUY_MRICEBLOCK_HPP -#include "walking_badguy.hpp" +#include "badguy/walking_badguy.hpp" #include "object/portable.hpp" -class MrIceBlock : public WalkingBadguy, public Portable +class MrIceBlock : public WalkingBadguy, + public Portable { public: - MrIceBlock(const lisp::Lisp& reader); + MrIceBlock(const Reader& reader); MrIceBlock(const Vector& pos, Direction d); - void activate(); - void write(lisp::Writer& writer); + void initialize(); HitResponse collision(GameObject& object, const CollisionHit& hit); void collision_solid(const CollisionHit& hit); HitResponse collision_badguy(BadGuy& badguy, const CollisionHit& hit); @@ -40,14 +37,11 @@ public: void grab(MovingObject& object, const Vector& pos, Direction dir); void ungrab(MovingObject& object, Direction dir); - bool can_break(); + bool is_portable() const; - virtual MrIceBlock* clone() const { return new MrIceBlock(*this); } + bool can_break(); protected: - bool collision_squished(Player& player); - -private: enum IceState { ICESTATE_NORMAL, ICESTATE_FLAT, @@ -55,11 +49,23 @@ private: ICESTATE_KICKED }; - void set_state(IceState state); +protected: + bool collision_squished(GameObject& object); + void set_state(IceState state, bool up = false); +private: IceState ice_state; + Timer nokick_timer; Timer flat_timer; int squishcount; }; +class SmartBlock : public MrIceBlock +{ +public: + SmartBlock(const Reader& reader); +}; + #endif + +/* EOF */