aboutsummaryrefslogtreecommitdiff
path: root/engines/zvision
diff options
context:
space:
mode:
authorrichiesams2013-08-16 12:19:00 -0500
committerrichiesams2013-08-16 12:19:00 -0500
commita3c39f48767b06a8015269e48ca929fbc5bfa637 (patch)
tree4a50b4e8ce9fa07e4668855e1d477757034a931e /engines/zvision
parent1c6ffd133acdddb8d08249d3a49caf523fd1d01e (diff)
downloadscummvm-rg350-a3c39f48767b06a8015269e48ca929fbc5bfa637.tar.gz
scummvm-rg350-a3c39f48767b06a8015269e48ca929fbc5bfa637.tar.bz2
scummvm-rg350-a3c39f48767b06a8015269e48ca929fbc5bfa637.zip
ZVISION: Fix memory corruption in copyTransposedRectToBackBuffer
Diffstat (limited to 'engines/zvision')
-rw-r--r--engines/zvision/render_manager.cpp34
-rw-r--r--engines/zvision/render_manager.h2
2 files changed, 20 insertions, 16 deletions
diff --git a/engines/zvision/render_manager.cpp b/engines/zvision/render_manager.cpp
index d8b8ce167d..1f2c3a20c7 100644
--- a/engines/zvision/render_manager.cpp
+++ b/engines/zvision/render_manager.cpp
@@ -77,13 +77,16 @@ void RenderManager::update(uint deltaTimeInMillis) {
}
// Warp the entire backbuffer
- //RenderTable::RenderState state = _renderTable.getRenderState();
- //if (state == RenderTable::PANORAMA || state == RenderTable::TILT) {
- // _renderTable.mutateImage((uint16 *)_backbuffer.getBasePtr(0, 0), _warpedBackbuffer, _workingWidth, _workingHeight);
- //}
+ RenderTable::RenderState state = _renderTable.getRenderState();
+ if (state == RenderTable::PANORAMA || state == RenderTable::TILT) {
+ _renderTable.mutateImage((uint16 *)_backbuffer.getBasePtr(0, 0), _warpedBackbuffer, _workingWidth, _workingHeight);
+ _system->copyRectToScreen(_warpedBackbuffer, _backbuffer.pitch, _workingWindow.left, _workingWindow.top, _backbuffer.w, _backbuffer.h);
+ } else {
+ _system->copyRectToScreen(_backbuffer.getBasePtr(0, 0), _backbuffer.pitch, _workingWindow.left, _workingWindow.top, _backbuffer.w, _backbuffer.h);
+ }
// Blit the backbuffer to the screen
- _system->copyRectToScreen(_backbuffer.getBasePtr(0, 0), _backbuffer.pitch, _workingWindow.left, _workingWindow.top, _backbuffer.w, _backbuffer.h);
+
}
void RenderManager::renderSubRectToBackbuffer(Graphics::Surface &surface, uint32 destinationX, uint32 destinationY, Common::Rect subRectangle, bool wrap, bool isTransposed) {
@@ -153,23 +156,24 @@ void RenderManager::renderSubRectToBackbuffer(Graphics::Surface &surface, uint32
return;
if (isTransposed) {
- copyTransposedRectToBackbuffer((uint16 *)surface.getBasePtr(subRectangle.left, subRectangle.top), surface.h, destRect.left, destRect.top, destRect.width(), destRect.height());
+ copyTransposedRectToBackbuffer((uint16 *)surface.getBasePtr(0, 0), surface.h, destRect.left, destRect.top, destRect.width(), destRect.height(), subRectangle);
} else {
_backbuffer.copyRectToSurface(surface.getBasePtr(subRectangle.left, subRectangle.top), surface.pitch, destRect.left, destRect.top, destRect.width(), destRect.height());
}
}
-void RenderManager::copyTransposedRectToBackbuffer(const uint16 *buffer, int imageWidth, int x, int y, int width, int height) {
- uint16 *dest = (uint16 *)_backbuffer.getBasePtr(x, y);
+void RenderManager::copyTransposedRectToBackbuffer(const uint16 *buffer, int imageWidth, int destinationX, int destinationY, int width, int height, const Common::Rect &subRect) {
+ uint16 *dest = (uint16 *)_backbuffer.getBasePtr(0, 0);
+
+ for (int16 x = subRect.left; x < subRect.right; x++) {
+ int16 normalizedX = x - subRect.left + destinationX;
+ int columnOffset = x * imageWidth;
- for (int i = 0; i < width; i++) {
- int columnOffset = i * imageWidth;
- for (int j = 0; j < height; j++) {
- *dest = buffer[columnOffset + j];
- dest++;
- }
+ for (int16 y = subRect.top; y < subRect.bottom; y++) {
+ int16 normalizeY = y - subRect.top + destinationY;
- dest += _backbuffer.w;
+ dest[normalizeY * _backbuffer.w + normalizedX] = buffer[columnOffset + y];
+ }
}
}
diff --git a/engines/zvision/render_manager.h b/engines/zvision/render_manager.h
index d5bf61f6a0..f59f50d4d7 100644
--- a/engines/zvision/render_manager.h
+++ b/engines/zvision/render_manager.h
@@ -171,7 +171,7 @@ private:
*/
void renderSubRectToBackbuffer(Graphics::Surface &surface, uint32 destinationX, uint32 destinationY, Common::Rect subRectangle, bool wrap, bool isTransposed);
- void copyTransposedRectToBackbuffer(const uint16 *buffer, int imageHeight, int x, int y, int width, int height);
+ void copyTransposedRectToBackbuffer(const uint16 *buffer, int imageWidth, int destinationX, int destinationY, int width, int height, const Common::Rect &subRect);
void moveBackground(int offset);
};