aboutsummaryrefslogtreecommitdiff
path: root/engines
diff options
context:
space:
mode:
Diffstat (limited to 'engines')
-rw-r--r--engines/zvision/render_manager.cpp66
1 files changed, 42 insertions, 24 deletions
diff --git a/engines/zvision/render_manager.cpp b/engines/zvision/render_manager.cpp
index e4106109ba..7d8ba75b8d 100644
--- a/engines/zvision/render_manager.cpp
+++ b/engines/zvision/render_manager.cpp
@@ -38,8 +38,8 @@ RenderManager::RenderManager(OSystem *system, const Common::Rect workingWindow,
: _system(system),
_workingWidth(workingWindow.width()),
_workingHeight(workingWindow.height()),
- _screenCenterX((workingWindow.left + workingWindow.right) /2),
- _screenCenterY((workingWindow.top + workingWindow.bottom) /2),
+ _screenCenterX(_workingWidth / 2),
+ _screenCenterY(_workingHeight / 2),
_workingWindow(workingWindow),
_pixelFormat(pixelFormat),
_currentBackground(0),
@@ -75,7 +75,7 @@ void RenderManager::update(uint deltaTimeInMillis) {
}
// Choose the direction of movement using the sign of the velocity
- moveBackground(_backgroundInverseVelocity < 0 ? numberOfSteps : -numberOfSteps);
+ moveBackground(_backgroundInverseVelocity < 0 ? -numberOfSteps : numberOfSteps);
}
}
@@ -85,32 +85,20 @@ void RenderManager::renderSubRectToScreen(Graphics::Surface &surface, int16 dest
// Take care of negative destinations
if (destinationX < 0) {
- subRectX = destinationX + surface.w;
+ subRectX = -destinationX;
destinationX = 0;
- if (wrap) {
- _backgroundOffset.x += surface.w;
- }
} else if (destinationX >= surface.w) {
// Take care of extreme positive destinations
destinationX -= surface.w;
- if (wrap) {
- _backgroundOffset.x -= surface.w;
- }
}
// Take care of negative destinations
if (destinationY < 0) {
- subRectY = destinationY + surface.h;
+ subRectY = -destinationY;
destinationY = 0;
- if (wrap) {
- _backgroundOffset.y += surface.h;
- }
} else if (destinationY >= surface.h) {
// Take care of extreme positive destinations
destinationY -= surface.h;
- if (wrap) {
- _backgroundOffset.y -= surface.h;
- }
}
if (wrap) {
@@ -224,15 +212,25 @@ const Common::Point RenderManager::screenSpaceToImageSpace(const Common::Point &
// Convert from screen space to working window space
Common::Point newPoint(point - Common::Point(_workingWindow.left, _workingWindow.top));
- if (_renderTable.getRenderState() == RenderTable::PANORAMA || _renderTable.getRenderState() == RenderTable::TILT) {
+ RenderTable::RenderState state = _renderTable.getRenderState();
+ if (state == RenderTable::PANORAMA || state == RenderTable::TILT) {
newPoint = _renderTable.convertWarpedCoordToFlatCoord(newPoint);
}
- newPoint -= _backgroundOffset;
+ if (state == RenderTable::PANORAMA) {
+ newPoint -= (Common::Point(_screenCenterX, 0) - _backgroundOffset);
+ } else if (state == RenderTable::TILT) {
+ newPoint -= (Common::Point(0, _screenCenterY) - _backgroundOffset);
+ }
+
if (newPoint.x < 0)
newPoint.x += _backgroundWidth;
+ else if (newPoint.x >= _backgroundWidth)
+ newPoint.x -= _backgroundWidth;
if (newPoint.y < 0)
newPoint.y += _backgroundHeight;
+ else if (newPoint.y >= _backgroundHeight)
+ newPoint.y -= _backgroundHeight;
return newPoint;
}
@@ -254,16 +252,16 @@ void RenderManager::setBackgroundImage(const Common::String &fileName) {
}
_currentBackground = file;
- renderImageToScreen(*_currentBackground, _backgroundOffset.x, _backgroundOffset.y, true);
+ moveBackground(0);
}
void RenderManager::setBackgroundPosition(int offset) {
RenderTable::RenderState state = _renderTable.getRenderState();
if (state == RenderTable::TILT) {
_backgroundOffset.x = 0;
- _backgroundOffset.y = _screenCenterY - offset;
+ _backgroundOffset.y = offset;
} else if (state == RenderTable::PANORAMA) {
- _backgroundOffset.x = _screenCenterX - offset;
+ _backgroundOffset.x = offset;
_backgroundOffset.y = 0;
} else {
_backgroundOffset.x = 0;
@@ -290,11 +288,31 @@ void RenderManager::moveBackground(int offset) {
if (state == RenderTable::TILT) {
_backgroundOffset += Common::Point(0, offset);
- renderImageToScreen(*_currentBackground, 0, _backgroundOffset.y, true);
+ if (_backgroundOffset.x <= -_backgroundWidth)
+ _backgroundOffset.x += _backgroundWidth;
+ else if (_backgroundOffset.x >= _backgroundWidth)
+ _backgroundOffset.x += _backgroundWidth;
+
+ if (_backgroundOffset.y <= -_backgroundHeight)
+ _backgroundOffset.y += _backgroundHeight;
+ else if (_backgroundOffset.y >= _backgroundHeight)
+ _backgroundOffset.y += _backgroundHeight;
+
+ renderImageToScreen(*_currentBackground, 0, _screenCenterY - _backgroundOffset.y, true);
} else if (state == RenderTable::PANORAMA) {
_backgroundOffset += Common::Point(offset, 0);
- renderImageToScreen(*_currentBackground, _backgroundOffset.x, 0, true);
+ if (_backgroundOffset.x <= -_backgroundWidth)
+ _backgroundOffset.x += _backgroundWidth;
+ else if (_backgroundOffset.x >= _backgroundWidth)
+ _backgroundOffset.x += _backgroundWidth;
+
+ if (_backgroundOffset.y <= -_backgroundHeight)
+ _backgroundOffset.y += _backgroundHeight;
+ else if (_backgroundOffset.y >= _backgroundHeight)
+ _backgroundOffset.y += _backgroundHeight;
+
+ renderImageToScreen(*_currentBackground, _screenCenterX - _backgroundOffset.x, 0, true);
} else {
renderImageToScreen(*_currentBackground, 0, 0);
}