X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fbattle%2FBattleState.cpp;h=5ba84db2583a17711e20304988bd0cf361e4ba48;hb=4a1816af30dcfe53181a25355bd51cc7b24a83f1;hp=5f50109b7585682c520d8ff09921de6787a80f20;hpb=6dd817d079315c392d1a8c2e5d5abcfce1500d30;p=l2e.git diff --git a/src/battle/BattleState.cpp b/src/battle/BattleState.cpp index 5f50109..5ba84db 100644 --- a/src/battle/BattleState.cpp +++ b/src/battle/BattleState.cpp @@ -10,9 +10,11 @@ #include "PartyLayout.h" #include "../graphics/Sprite.h" +#include #include using app::Application; +using geometry::Point; using std::vector; @@ -26,8 +28,16 @@ void BattleState::AddMonster(const Monster &m) { } +void BattleState::Resize(int w, int h) { + width = w; + height = h; +} + + void BattleState::EnterState(Application &ctrl, SDL_Surface *screen) { monstersLayout->CalculatePositions(background->w, background->h, monsterPositions); + width = screen->w; + height = screen->h; } void BattleState::ExitState() { @@ -44,10 +54,22 @@ void BattleState::UpdateWorld(float deltaT) { } void BattleState::Render(SDL_Surface *screen) { + // black for now + SDL_FillRect(screen, 0, SDL_MapRGB(screen->format, 0, 0, 0)); + SDL_Rect destRect; + destRect.x = (width - background->w) / 2; + destRect.y = (height - background->h) / 2; + destRect.w = background->w; + destRect.h = background->h; + + std::cout << "screen: " << screen->w << "x" << screen->h << std::endl; + std::cout << "drawing to " << destRect.w << "x" << destRect.h << "+" << destRect.x << "+" << destRect.y << std::endl; + // TODO: center background if screen bigger - SDL_BlitSurface(background, 0, screen, 0); + SDL_BlitSurface(background, 0, screen, &destRect); + for (vector::size_type i(0), end(monsters.size()); i < end; ++i) { - monsters[i].Sprite()->DrawCenterBottom(screen, monsterPositions[i]); + monsters[i].Sprite()->DrawCenterBottom(screen, Point(monsterPositions[i].X() + destRect.x, monsterPositions[i].Y() + destRect.y)); } }