X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fbattle%2FBattleState.h;h=cfd344dea4bce431b8f9a67adb534d1097a23520;hb=e1dab8a680a76f8621e967a693dbf2b481ba8f75;hp=3a9500c5d5228d41c2bd71ba42a27d593c41a4a3;hpb=e1edc92c4fb834c8061118e89c0d7e239742b030;p=l2e.git diff --git a/src/battle/BattleState.h b/src/battle/BattleState.h index 3a9500c..cfd344d 100644 --- a/src/battle/BattleState.h +++ b/src/battle/BattleState.h @@ -1,8 +1,20 @@ #ifndef BATTLE_BATTLESTATE_H_ #define BATTLE_BATTLESTATE_H_ -#include "fwd.h" +namespace battle { + class PartyLayout; +} +namespace common { + class Item; + struct GameConfig; +} +namespace math { + template + class Vector; +} + #include "AttackTypeMenu.h" +#include "Battle.h" #include "Capsule.h" #include "Hero.h" #include "HeroTag.h" @@ -10,14 +22,10 @@ #include "MoveMenu.h" #include "Resources.h" #include "SmallHeroTag.h" -#include "../app/fwd.h" #include "../app/State.h" #include "../common/GameConfig.h" -#include "../common/fwd.h" #include "../common/Stats.h" -#include "../geometry/Vector.h" #include "../graphics/Animation.h" -#include "../graphics/fwd.h" #include "../graphics/Menu.h" #include @@ -33,17 +41,12 @@ public: BattleState(common::GameConfig *game, SDL_Surface *background, const PartyLayout *monstersLayout) : game(game) , background(background) - , monstersLayout(monstersLayout) - , heroesLayout(game->heroesLayout) , res(game->battleResources) + , battle(game->heroesLayout, monstersLayout) , attackTypeMenu(res->attackIcons) , moveMenu(res->moveIcons) - , numHeroes(0) - , activeHero(-1) - , attackCursor(-1) - , expReward(0) - , goldReward(0) - , ranAway(false) { assert(background && monstersLayout && game); } + , ranAway(false), alreadyPushed(false) + { assert(background && game); } public: void AddMonster(const Monster &); @@ -52,10 +55,12 @@ public: public: virtual void HandleEvents(const app::Input &); - virtual void UpdateWorld(float deltaT); + virtual void UpdateWorld(Uint32 deltaT); virtual void Render(SDL_Surface *); public: + Battle &GetBattle() { return battle; } + const Battle &GetBattle() const { return battle; } const Resources &Res() const { return *res; } AttackTypeMenu &GetAttackTypeMenu() { return attackTypeMenu; } MoveMenu &GetMoveMenu() { return moveMenu; } @@ -63,68 +68,33 @@ public: graphics::Menu &ItemMenu() { return itemMenu; } const graphics::Menu &ItemMenu() const { return itemMenu; } - void NextHero(); - bool BeforeFirstHero() const { return activeHero < 0; } - void PreviousHero(); - void SwapHeroes(int lhs, int rhs); - Hero &ActiveHero() { assert(activeHero >= 0 && activeHero < NumHeroes()); return heroes[activeHero]; } - const Hero &ActiveHero() const { assert(activeHero >= 0 && activeHero < NumHeroes()); return heroes[activeHero]; } - - Hero &HeroAt(int index) { assert(index >= 0 && index < NumHeroes()); return heroes[index]; } - const Hero &HeroAt(int index) const { assert(index >= 0 && index < NumHeroes()); return heroes[index]; } - Monster &MonsterAt(int index) { assert(index >= 0 && index < NumHeroes()); return monsters[index]; } - const Monster &MonsterAt(int index) const { assert(index >= 0 && index < NumHeroes()); return monsters[index]; } + Hero &HeroAt(int index) { return battle.HeroAt(index); } + const Hero &HeroAt(int index) const { return battle.HeroAt(index); } + Monster &MonsterAt(int index) { return battle.MonsterAt(index); } + const Monster &MonsterAt(int index) const { return battle.MonsterAt(index); } const HeroTag &HeroTagAt(int index) const { assert(index >= 0 && index < NumHeroes()); return heroTags[index]; } - const geometry::Vector &HeroTagPositionAt(int index) const { assert(index >= 0 && index < NumHeroes()); return heroTagPositions[index]; } + const math::Vector &HeroTagPositionAt(int index) const { assert(index >= 0 && index < NumHeroes()); return heroTagPositions[index]; } - bool HasChosenAttackType() const { return ActiveHero().GetAttackChoice().GetType() != AttackChoice::UNDECIDED; } - bool AttackSelectionDone() const { return activeHero >= numHeroes; } - - int NumHeroes() const { return numHeroes; } - int MaxHeroes() const { return 4; } - int MaxMonsters() const { return monsters.size(); } - - bool MonsterPositionOccupied(int index) { return index >= 0 && index < int(monsters.size()) && monsters[index].Health() > 0; } - bool HeroPositionOccupied(int index) const { return index >= 0 && index < numHeroes; } + int NumHeroes() const { return battle.NumHeroes(); } + int MaxHeroes() const { return battle.MaxHeroes(); } + int NumMonsters() const { return battle.NumMonsters(); } + int MaxMonsters() const { return battle.MaxMonsters(); } void SetRunaway() { ranAway = true; } - struct Order { - Order(int index, bool isMonster) - : index(index), isMonster(isMonster) { } - int index; - bool isMonster; - }; - - void CalculateAttackOrder(); - void NextAttack(); - bool AttacksFinished() const; - void CalculateDamage(); - void ApplyDamage(); - const Order &CurrentAttack() const { assert(attackCursor >= 0 && attackCursor < int(attackOrder.size())); return attackOrder[attackCursor]; }; - AttackChoice &CurrentAttackAttackChoice(); - void ClearAllAttacks(); - - bool Victory() const; - bool Defeat() const; - public: - geometry::Vector CalculateScreenOffset(SDL_Surface *screen) const { - return geometry::Vector( - (screen->w - background->w) / 2, - (screen->h - background->h) / 2); - } + const math::Vector &ScreenOffset() const { return offset; } int Width() const { return background->w; } int Height() const { return background->h; } - geometry::Vector Size() const { return geometry::Vector(Width(), Height()); } + math::Vector Size() const { return math::Vector(Width(), Height()); } - void RenderBackground(SDL_Surface *screen, const geometry::Vector &offset); - void RenderMonsters(SDL_Surface *screen, const geometry::Vector &offset); - void RenderHeroes(SDL_Surface *screen, const geometry::Vector &offset); - void RenderCapsule(SDL_Surface *screen, const geometry::Vector &offset); - void RenderHeroTags(SDL_Surface *screen, const geometry::Vector &offset); - void RenderSmallHeroTags(SDL_Surface *screen, const geometry::Vector &offset); + void RenderBackground(SDL_Surface *screen); + void RenderMonsters(SDL_Surface *screen); + void RenderHeroes(SDL_Surface *screen); + void RenderCapsule(SDL_Surface *screen); + void RenderHeroTags(SDL_Surface *screen); + void RenderSmallHeroTags(SDL_Surface *screen); private: virtual void OnEnterState(SDL_Surface *screen); @@ -137,36 +107,26 @@ private: private: void LoadInventory(); - void DecideMonsterAttack(Monster &) const; - void CalculateDamage(const common::Stats &attackerStats, TargetSelection &targets) const; - Uint16 CalculateDamage(const common::Stats &attacker, const common::Stats &defender) const; - private: common::GameConfig *game; SDL_Surface *background; - const PartyLayout *monstersLayout; - const PartyLayout *heroesLayout; const Resources *res; + Battle battle; AttackTypeMenu attackTypeMenu; MoveMenu moveMenu; - std::vector monsters; - std::vector attackOrder; - Hero heroes[4]; graphics::Menu itemMenu; HeroTag heroTags[4]; SmallHeroTag smallHeroTags[4]; - geometry::Vector heroTagPositions[4]; - geometry::Vector smallHeroTagPositions[4]; - Capsule capsule; - int numHeroes; - int activeHero; - int attackCursor; - int expReward; - int goldReward; + math::Vector heroTagPositions[4]; + math::Vector smallHeroTagPositions[4]; + + math::Vector offset; + bool ranAway; + bool alreadyPushed; }; } -#endif /* BATTLE_BATTLESTATE_H_ */ +#endif