X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fbattle%2FMonster.h;h=232da8fae99bd9f705229bc5684400eb0a49b78d;hb=8967f42789c619df6e5874f5c6a9ea4b6b6c33db;hp=e4d787e741e87856be256f9f626554b78d49263b;hpb=c6156f6b3dc88a97a78694a2652dfbc874fcc8e4;p=l2e.git diff --git a/src/battle/Monster.h b/src/battle/Monster.h index e4d787e..232da8f 100644 --- a/src/battle/Monster.h +++ b/src/battle/Monster.h @@ -8,13 +8,14 @@ #ifndef BATTLE_MONSTER_H_ #define BATTLE_MONSTER_H_ +#include "AttackChoice.h" #include "Stats.h" +#include "../graphics/Animation.h" #include namespace common { class Item; } namespace graphics { - class Animation; class Sprite; } @@ -52,9 +53,12 @@ public: const /* Script */ void *AttackScript() { return attackScript; } const /* Script */ void *DefenseScript() { return defenseScript; } - graphics::Animation *AttackAnimation() { return attackAnimation; } + graphics::AnimationRunner &GetAnimation() { return animation; } + const graphics::AnimationRunner &GetAnimation() const { return animation; } + void SetAnimation(const graphics::AnimationRunner &a) { animation = a; } + + const graphics::Animation *MeleeAnimation() const { return meleeAnimation; } const graphics::Animation *AttackAnimation() const { return attackAnimation; } - graphics::Animation *SpellAnimation() { return spellAnimation; } const graphics::Animation *SpellAnimation() const { return spellAnimation; } // temporary setters until loader is implemented @@ -69,8 +73,12 @@ public: void SetStats(const Stats &s) { stats = s; } void SetReward(Uint16 exp, Uint16 gold) { expReward = exp; goldReward = gold; } - void SetAttackAnimation(graphics::Animation *a) { attackAnimation = a; } - void SetSpellAnimation(graphics::Animation *a) { spellAnimation = a; } + void SetMeleeAnimation(const graphics::Animation *a) { meleeAnimation = a; } + void SetAttackAnimation(const graphics::Animation *a) { attackAnimation = a; } + void SetSpellAnimation(const graphics::Animation *a) { spellAnimation = a; } + + AttackChoice &GetAttackChoice() { return attackChoice; } + const AttackChoice &GetAttackChoice() const { return attackChoice; } private: const char *name; @@ -79,8 +87,13 @@ private: /* Script */ void *attackScript; /* Script */ void *defenseScript; - graphics::Animation *attackAnimation; - graphics::Animation *spellAnimation; + const graphics::Animation *meleeAnimation; + const graphics::Animation *attackAnimation; + const graphics::Animation *spellAnimation; + + graphics::AnimationRunner animation; + + AttackChoice attackChoice; Uint16 maxHealth, health; Uint16 maxMana, mana;