X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fbattle%2FMonster.h;h=bb44bb48ed2ce525b4612811ab49790f683e5868;hb=a3ba4dc677ad7c92eeb78b20b642241563605c9d;hp=8338cb18e59f8e6836c0fb6c617e280ff9f74a2f;hpb=9718062e6ed305d9f8f1674ff172079688e78088;p=l2e.git diff --git a/src/battle/Monster.h b/src/battle/Monster.h index 8338cb1..bb44bb4 100644 --- a/src/battle/Monster.h +++ b/src/battle/Monster.h @@ -1,29 +1,22 @@ -/* - * Monster.h - * - * Created on: Aug 3, 2012 - * Author: holy - */ - #ifndef BATTLE_MONSTER_H_ #define BATTLE_MONSTER_H_ #include "AttackChoice.h" -#include "Stats.h" -#include "../geometry/Point.h" +#include "../common/fwd.h" +#include "../common/Stats.h" +#include "../math/Vector.h" #include "../graphics/Animation.h" +#include "../graphics/fwd.h" #include -namespace common { class Item; } -namespace graphics { - class Sprite; -} - namespace battle { class Monster { +public: + static const int TYPE_ID = 202; + public: Monster(); ~Monster(); @@ -42,8 +35,8 @@ public: Uint16 Mana() const { return mana; } int RelativeMana(int max) const { return mana * max / maxMana; } - Stats &GetStats() { return stats; } - const Stats &GetStats() const { return stats; } + common::Stats &GetStats() { return stats; } + const common::Stats &GetStats() const { return stats; } Uint16 ExpReward() const { return expReward; } Uint16 GoldReward() const { return goldReward; } @@ -62,8 +55,8 @@ public: const graphics::Animation *AttackAnimation() const { return attackAnimation; } const graphics::Animation *SpellAnimation() const { return spellAnimation; } - geometry::Point &Position() { return position; } - const geometry::Point &Position() const { return position; } + math::Vector &Position() { return position; } + const math::Vector &Position() const { return position; } // temporary setters until loader is implemented public: @@ -74,7 +67,7 @@ public: void SetHealth(Uint16 h) { health = h; } void SetMaxMana(Uint16 m) { maxMana = m; } void SetMana(Uint16 m) { mana = m; } - void SetStats(const Stats &s) { stats = s; } + void SetStats(const common::Stats &s) { stats = s; } void SetReward(Uint16 exp, Uint16 gold) { expReward = exp; goldReward = gold; } void SetMeleeAnimation(const graphics::Animation *a) { meleeAnimation = a; } @@ -84,6 +77,9 @@ public: AttackChoice &GetAttackChoice() { return attackChoice; } const AttackChoice &GetAttackChoice() const { return attackChoice; } + static void CreateTypeDescription(); + static void Construct(void *); + private: const char *name; graphics::Sprite *sprite; @@ -97,19 +93,19 @@ private: graphics::AnimationRunner animation; - geometry::Point position; + math::Vector position; AttackChoice attackChoice; - Uint16 maxHealth, health; - Uint16 maxMana, mana; + int maxHealth, health; + int maxMana, mana; - Stats stats; + common::Stats stats; - Uint16 expReward, goldReward; + int expReward, goldReward; - Uint8 level; - Uint8 dropChance; + int level; + int dropChance; };