From 4d338e801f8b1175585de6b5e7b8b2ca331b682f Mon Sep 17 00:00:00 2001 From: Björn Steinbrink Date: Tue, 9 Aug 2005 03:08:03 +0000 Subject: Adjust drawing offset to have the player centered in higher resolutions as well. --- ChangeLog | 5 +++++ src/engine.cpp | 15 +++++++++------ 2 files changed, 14 insertions(+), 6 deletions(-) diff --git a/ChangeLog b/ChangeLog index ff58f119..995169ad 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +2005-08-09 Björn Steinbrink + + * src/engine.cpp: Adjust drawing offset to have the player centered in + higher resolutions as well. + 2005-08-04 Björn Steinbrink * src/main.cpp: Use "true" instead of "1" as bool argument. diff --git a/src/engine.cpp b/src/engine.cpp index 7901acac..7fe4d4df 100644 --- a/src/engine.cpp +++ b/src/engine.cpp @@ -329,8 +329,11 @@ void Engine::draw() int mouseX, mouseY; SDL_GetMouseState(&mouseX, &mouseY); - int map_x = (player_node->x - 13) * 32 + get_x_offset(player_node); - int map_y = (player_node->y - 9) * 32 + get_y_offset(player_node); + int midTileX = guiGraphics->getWidth() / 32 / 2; + int midTileY = guiGraphics->getHeight() / 32 / 2; + + int map_x = (player_node->x - midTileX) * 32 + get_x_offset(player_node); + int map_y = (player_node->y - midTileY) * 32 + get_y_offset(player_node); if (map_x < 0) { map_x = 0; @@ -340,11 +343,11 @@ void Engine::draw() } if (mCurrentMap) { - if (map_x > (mCurrentMap->getWidth() - 13) * 32) { - map_x = (mCurrentMap->getWidth() - 13) * 32; + if (map_x > (mCurrentMap->getWidth() - midTileX) * 32) { + map_x = (mCurrentMap->getWidth() - midTileX) * 32; } - if (map_y > (mCurrentMap->getHeight() - 9) * 32) { - map_y = (mCurrentMap->getHeight() - 9) * 32; + if (map_y > (mCurrentMap->getHeight() - midTileY) * 32) { + map_y = (mCurrentMap->getHeight() - midTileY) * 32; } } -- cgit v1.2.3-70-g09d2