X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fbattle%2FBattleState.cpp;h=0f3fad94838f56e88a16bda2b6efbce8a788b624;hb=35f8a25fc914f10a8e987357bab94584af0992fb;hp=9e84206b3908dde82be2eba8fec5da82bf4e8661;hpb=4956380d5109fe57722a968ad1ffbf2fa0a5ed2e;p=l2e.git diff --git a/src/battle/BattleState.cpp b/src/battle/BattleState.cpp index 9e84206..0f3fad9 100644 --- a/src/battle/BattleState.cpp +++ b/src/battle/BattleState.cpp @@ -43,14 +43,15 @@ void BattleState::AddMonster(const Monster &m) { } void BattleState::AddHero(const Hero &h) { - if (heroes.size() >= heroesLayout->NumPositions()) { + if (numHeroes >= 4 || numHeroes >= (int)heroesLayout->NumPositions()) { throw std::overflow_error("too many heroes for layout"); } - heroes.push_back(h); + heroes[numHeroes] = h; + ++numHeroes; } -void BattleState::SwapHeroes(std::vector::size_type lhs, std::vector::size_type rhs) { - if (lhs < 0 || lhs >= heroes.size() || rhs < 0 || rhs >= heroes.size() || lhs == rhs) return; +void BattleState::SwapHeroes(int lhs, int rhs) { + if (lhs < 0 || lhs >= numHeroes || rhs < 0 || rhs >= numHeroes || lhs == rhs) return; std::swap(heroes[lhs], heroes[rhs]); } @@ -63,7 +64,7 @@ void BattleState::Resize(int w, int h) { void BattleState::EnterState(Application &ctrl, SDL_Surface *screen) { monstersLayout->CalculatePositions(background->w, background->h, monsterPositions); heroesLayout->CalculatePositions(background->w, background->h, heroesPositions); - for (vector::size_type i(0), end(heroes.size()); i < end; ++i) { + for (int i(0); i < 4; ++i) { spellMenus[i] = res->spellMenuPrototype; LoadSpellMenu(i); ikariMenus[i] = res->ikariMenuPrototype; @@ -208,7 +209,7 @@ void BattleState::PauseState(Application &ctrl, SDL_Surface *screen) { void BattleState::ClearAllAttacks() { activeHero = -1; - for (vector::size_type i(0), end(heroes.size()); i < end; ++i) { + for (int i(0); i < numHeroes; ++i) { attackChoices[i] = AttackChoice(this); } } @@ -249,7 +250,7 @@ void BattleState::RenderMonsters(SDL_Surface *screen, const Vector &offset) } void BattleState::RenderHeroes(SDL_Surface *screen, const Vector &offset) { - for (vector::size_type i(0), end(heroes.size()); i < end; ++i) { + for (int i(0); i < numHeroes; ++i) { heroes[i].Sprite()->DrawCenterBottom(screen, heroesPositions[i] + offset, 0, 1); } } @@ -258,7 +259,7 @@ void BattleState::RenderHeroTags(SDL_Surface *screen, const Vector &offset) int tagHeight(attackTypeMenu.Height()); int tagWidth(attackTypeMenu.Width() * 2 + attackTypeMenu.Width() / 2); - for (vector::size_type i(0), end(heroes.size()); i < end; ++i) { + for (int i(0); i < numHeroes; ++i) { heroTags[i].Render(screen, tagWidth, tagHeight, heroTagPositions[i] + offset, (int)i == activeHero); } }