blob: 4839966a883b33da3daa8e068b71529568f1f72a (
plain) (
tree)
|
|
/*
* The Mana World
* Copyright 2004 The Mana World Development Team
*
* This file is part of The Mana World.
*
* The Mana World 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
* any later version.
*
* The Mana World 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 The Mana World; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* $Id: monster.h 3690 2007-10-26 12:50:49Z crush_tmw $
*/
#ifndef _TMW_MONSTER_H
#define _TMW_MONSTER_H
#include "being.h"
class MonsterInfo;
class Text;
class Monster : public Being
{
public:
Monster(Uint32 id, Uint16 job, Map *map);
~Monster();
virtual void logic();
virtual void setAction(Action action);
virtual Type getType() const;
virtual TargetCursorSize
getTargetCursorSize() const;
/**
* Handles an attack of another being by this monster. Plays a hit or
* miss sound when appropriate.
*
* @param victim The attacked being.
* @param damage The amount of damage dealt (0 means miss).
*/
virtual void handleAttack(Being *victim, int damage);
/**
* Puts a damage bubble above this monster and plays the hurt sound
*
* @param amount The amount of damage.
*/
virtual void takeDamage(int amount);
/**
* Returns the MonsterInfo, with static data about this monster.
*/
const MonsterInfo&
getInfo() const;
/**
* Determine whether the mob should show it's name
*/
void showName(bool show);
protected:
/**
* Update the text when the monster moves
*/
void updateCoords();
private:
Text *mText; /**< holds a text object when the mod displays it's name, 0 otherwise */
};
#endif
|