diff options
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | src/engine.cpp | 15 |
2 files changed, 14 insertions, 6 deletions
@@ -1,3 +1,8 @@ +2005-08-09 Björn Steinbrink <B.Steinbrink@gmx.de> + + * src/engine.cpp: Adjust drawing offset to have the player centered in + higher resolutions as well. + 2005-08-04 Björn Steinbrink <B.Steinbrink@gmx.de> * 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; } } |