]> git.localhorst.tv Git - l2e.git/blobdiff - src/battle/BattleState.h
reworked Application's state stack
[l2e.git] / src / battle / BattleState.h
index 8fa7d951ac393bcf5dd5917cc36d2b34f44bbce5..12c55f71856d1536cc12e432ec7cca0777f72b03 100644 (file)
@@ -8,10 +8,12 @@
 #ifndef BATTLE_BATTLESTATE_H_
 #define BATTLE_BATTLESTATE_H_
 
+#include "AttackChoice.h"
 #include "AttackTypeMenu.h"
 #include "Hero.h"
 #include "HeroTag.h"
 #include "Monster.h"
+#include "MoveMenu.h"
 #include "../app/State.h"
 #include "../geometry/Point.h"
 #include "../geometry/Vector.h"
@@ -31,11 +33,13 @@ class BattleState
 : public app::State {
 
 public:
-       BattleState(SDL_Surface *background, const PartyLayout &monstersLayout, const PartyLayout &heroesLayout, const graphics::Sprite *attackIcons)
+       BattleState(SDL_Surface *background, const PartyLayout &monstersLayout, const PartyLayout &heroesLayout, const graphics::Sprite *attackIcons, const graphics::Sprite *moveIcons)
        : background(background)
        , monstersLayout(&monstersLayout)
        , heroesLayout(&heroesLayout)
-       , attackTypeMenu(attackIcons) { }
+       , attackTypeMenu(attackIcons)
+       , moveMenu(moveIcons)
+       , activeHero(-1) { }
 
 public:
        void AddMonster(const Monster &);
@@ -43,7 +47,9 @@ public:
 
 public:
        virtual void EnterState(app::Application &ctrl, SDL_Surface *screen);
-       virtual void ExitState();
+       virtual void ExitState(app::Application &ctrl, SDL_Surface *screen);
+       virtual void ResumeState(app::Application &ctrl, SDL_Surface *screen);
+       virtual void PauseState(app::Application &ctrl, SDL_Surface *screen);
 
        virtual void Resize(int width, int height);
 
@@ -51,23 +57,43 @@ public:
        virtual void UpdateWorld(float deltaT);
        virtual void Render(SDL_Surface *);
 
-private:
+public:
+       AttackTypeMenu &GetAttackTypeMenu() { return attackTypeMenu; }
+       MoveMenu &GetMoveMenu() { return moveMenu; }
+
+       bool HasMoreHeroes() const { return activeHero < (int) heroes.size(); }
+       void NextHero() { ++activeHero; }
+       bool HasChosenAttackType() const { return attackChoices[activeHero].GetType() != AttackChoice::UNDECIDED; }
+       void SetAttackType(AttackChoice::Type t) { attackChoices[activeHero].SetType(t); }
+       bool AttackSelectionDone() const { return activeHero >= (int) heroes.size(); }
+
+public:
+       geometry::Vector<int> CalculateScreenOffset(SDL_Surface *screen) const {
+               return geometry::Vector<int>(
+                               (screen->w - background->w) / 2,
+                               (screen->h - background->h) / 2);
+       }
+       int BackgroundWidth() const { return background->w; }
+       int BackgroundHeight() const { return background->h; }
+
        void RenderBackground(SDL_Surface *screen, const geometry::Vector<int> &offset);
        void RenderMonsters(SDL_Surface *screen, const geometry::Vector<int> &offset);
        void RenderHeroes(SDL_Surface *screen, const geometry::Vector<int> &offset);
        void RenderHeroTags(SDL_Surface *screen, const geometry::Vector<int> &offset);
-       void RenderAttackTypeMenu(SDL_Surface *screen, const geometry::Vector<int> &offset);
 
 private:
        SDL_Surface *background;
        const PartyLayout *monstersLayout;
        const PartyLayout *heroesLayout;
        AttackTypeMenu attackTypeMenu;
+       MoveMenu moveMenu;
        std::vector<geometry::Point<int> > monsterPositions;
        std::vector<geometry::Point<int> > heroesPositions;
        std::vector<Monster> monsters;
        std::vector<Hero> heroes;
        std::vector<HeroTag> heroTags;
+       std::vector<AttackChoice> attackChoices;
+       int activeHero;
 
 };