X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Fbadguy%2Fmriceblock.hpp;h=c08870b1c4ab02fd6a5a447d7c4defc77e4e7c6c;hb=830aabe0656083bcd0353e2da2220fa709fb8e3b;hp=bd0ff53dcd618a7a5681e83d53ecdbdc5c863e2b;hpb=7ffe0f4a7fe4ee1d4041a684638d07557676624c;p=supertux.git diff --git a/src/badguy/mriceblock.hpp b/src/badguy/mriceblock.hpp index bd0ff53dc..c08870b1c 100644 --- a/src/badguy/mriceblock.hpp +++ b/src/badguy/mriceblock.hpp @@ -1,51 +1,47 @@ -// $Id$ -// // SuperTux -// Copyright (C) 2005 Matthias Braun +// 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 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // 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 "badguy.hpp" +#include "badguy/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 Reader& reader); + MrIceBlock(const Vector& pos, Direction d); - void activate(); - void write(lisp::Writer& writer); + void initialize(); 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; -protected: - bool collision_squished(Player& player); + bool can_break(); -private: +protected: enum IceState { ICESTATE_NORMAL, ICESTATE_FLAT, @@ -53,14 +49,17 @@ 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; - bool set_direction; - Direction initial_direction; }; #endif +/* EOF */