aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRobert Göffringmann2005-11-08 10:21:02 +0000
committerRobert Göffringmann2005-11-08 10:21:02 +0000
commit243f99df401f7455578affe754013ae3834d1e6d (patch)
tree2d0dec36b76831dce20b9fcde58afbab15d0075d
parentbe5bae910619c7902640f8d650a94af3ee3cbbb4 (diff)
downloadscummvm-rg350-243f99df401f7455578affe754013ae3834d1e6d.tar.gz
scummvm-rg350-243f99df401f7455578affe754013ae3834d1e6d.tar.bz2
scummvm-rg350-243f99df401f7455578affe754013ae3834d1e6d.zip
another scrolling fix, the engine didn't scroll all the way to the end of the screens before.
svn-id: r19516
-rw-r--r--sword1/screen.cpp4
1 files changed, 2 insertions, 2 deletions
diff --git a/sword1/screen.cpp b/sword1/screen.cpp
index 1e5787be59..8d070b0d51 100644
--- a/sword1/screen.cpp
+++ b/sword1/screen.cpp
@@ -89,8 +89,8 @@ void Screen::setScrolling(int16 offsetX, int16 offsetY) {
_oldScrollY = Logic::_scriptVars[SCROLL_OFFSET_Y];
int dx = offsetX - Logic::_scriptVars[SCROLL_OFFSET_X];
int dy = offsetY - Logic::_scriptVars[SCROLL_OFFSET_Y];
- int scrlDistX = inRange(-MAX_SCROLL_DISTANCE, ((1 + ABS(dx)) / SCROLL_FRACTION) * ((dx > 0) ? 1 : -1), MAX_SCROLL_DISTANCE);
- int scrlDistY = inRange(-MAX_SCROLL_DISTANCE, ((1 + ABS(dy)) / SCROLL_FRACTION) * ((dy > 0) ? 1 : -1), MAX_SCROLL_DISTANCE);
+ int scrlDistX = inRange(-MAX_SCROLL_DISTANCE, (((SCROLL_FRACTION - 1) + ABS(dx)) / SCROLL_FRACTION) * ((dx > 0) ? 1 : -1), MAX_SCROLL_DISTANCE);
+ int scrlDistY = inRange(-MAX_SCROLL_DISTANCE, (((SCROLL_FRACTION - 1) + ABS(dy)) / SCROLL_FRACTION) * ((dy > 0) ? 1 : -1), MAX_SCROLL_DISTANCE);
if ((scrlDistX != 0) || (scrlDistY != 0))
_fullRefresh = true;
Logic::_scriptVars[SCROLL_OFFSET_X] = inRange(0, Logic::_scriptVars[SCROLL_OFFSET_X] + scrlDistX, Logic::_scriptVars[MAX_SCROLL_OFFSET_X]);