X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;ds=sidebyside;f=src%2Fmenu%2FStatusMenu.cpp;h=aea11b9cda0ffd9888b0aea38982281ed6247cc3;hb=fab9883177573c105579a37cbc5b9bbbe69d0280;hp=c56e796f13f5fe4fc21652657f5d7919d198674e;hpb=317100aa5878503dad034a1e1eb734d1e952f842;p=l2e.git diff --git a/src/menu/StatusMenu.cpp b/src/menu/StatusMenu.cpp index c56e796..aea11b9 100644 --- a/src/menu/StatusMenu.cpp +++ b/src/menu/StatusMenu.cpp @@ -85,12 +85,20 @@ void StatusMenu::Render(SDL_Surface *screen) { Vector equipOffset( 17 * parent->Res().statusFont->CharWidth(), 4 * parent->Res().statusFont->CharHeight() - parent->Res().statusFont->CharHeight() / 8); + Vector experienceOffset( + 11 * parent->Res().statusFont->CharWidth(), + 17 * parent->Res().statusFont->CharHeight() - parent->Res().statusFont->CharHeight() / 8); + Vector nextLevelOffset( + 11 * parent->Res().statusFont->CharWidth(), + 19 * parent->Res().statusFont->CharHeight() - parent->Res().statusFont->CharHeight() / 8); parent->RenderBackground(screen); parent->Res().shoulderNav->Draw(screen, offset + shoulderNavOffset); RenderStatus(screen, offset + parent->StatusOffset(0)); RenderStats(screen, offset + statsOffset); RenderEquipment(screen, offset + equipOffset); + RenderExperience(screen, experienceOffset); + RenderNextLevel(screen, nextLevelOffset); } int StatusMenu::Width() const { @@ -106,7 +114,7 @@ void StatusMenu::RenderStatus(SDL_Surface *screen, const Vector &offset) co } void StatusMenu::RenderStats(SDL_Surface *screen, const Vector &offset) const { - const Stats &stats(parent->Game().state->party[cursor]->GetStats()); + const Stats &stats(GetHero().GetStats()); Vector lineBreak(0, parent->Res().statusFont->CharHeight()); Vector position(offset); @@ -140,7 +148,7 @@ void StatusMenu::RenderStatsLine(const char *label, int number, SDL_Surface *scr } void StatusMenu::RenderEquipment(SDL_Surface *screen, const Vector &offset) const { - const Hero &hero(*parent->Game().state->party[cursor]); + const Hero &hero(GetHero()); Vector lineBreak(0, 2 * parent->Res().statusFont->CharHeight()); Vector position(offset); @@ -175,6 +183,22 @@ void StatusMenu::RenderEquipmentLine(const Item *item, SDL_Surface *screen, cons } } +void StatusMenu::RenderExperience(SDL_Surface *screen, const geometry::Vector &offset) const { + const Font &font(*parent->Res().statusFont); + font.DrawStringRight(parent->Res().experienceLabel, screen, offset, 10); + + Vector numberOffset(offset.X(), offset.Y() + font.CharHeight()); + font.DrawNumberRight(GetHero().Experience(), screen, numberOffset, 7); +} + +void StatusMenu::RenderNextLevel(SDL_Surface *screen, const geometry::Vector &offset) const { + const Font &font(*parent->Res().statusFont); + font.DrawStringRight(parent->Res().nextLevelLabel, screen, offset, 10); + + Vector numberOffset(offset.X(), offset.Y() + font.CharHeight()); + font.DrawNumberRight(GetHero().NextLevel(), screen, numberOffset, 7); +} + void StatusMenu::NextHero() { cursor = (cursor + 1) % parent->Game().state->partySize; @@ -184,4 +208,8 @@ void StatusMenu::PreviousHero() { cursor = (cursor + parent->Game().state->partySize - 1) % parent->Game().state->partySize; } +const Hero &StatusMenu::GetHero() const { + return *parent->Game().state->party[cursor]; +} + }