summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog5
-rw-r--r--src/engine.cpp15
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 <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;
}
}