diff options
author | richiesams | 2013-08-17 11:36:42 -0500 |
---|---|---|
committer | richiesams | 2013-08-18 19:52:56 -0500 |
commit | acea03a9cd9ce14b210fe4b2fc650e34e8ae657b (patch) | |
tree | 2ec8714d850b179d9dc82c04da41baeb2f1e8a98 /engines | |
parent | 7e6a04dc62161f1b013445ba20ee7465b57d6412 (diff) | |
download | scummvm-rg350-acea03a9cd9ce14b210fe4b2fc650e34e8ae657b.tar.gz scummvm-rg350-acea03a9cd9ce14b210fe4b2fc650e34e8ae657b.tar.bz2 scummvm-rg350-acea03a9cd9ce14b210fe4b2fc650e34e8ae657b.zip |
ZVISION: Allow RenderTable indicies to be negative
Diffstat (limited to 'engines')
-rw-r--r-- | engines/zvision/render_table.cpp | 18 |
1 files changed, 9 insertions, 9 deletions
diff --git a/engines/zvision/render_table.cpp b/engines/zvision/render_table.cpp index 23394b7bc2..7188530075 100644 --- a/engines/zvision/render_table.cpp +++ b/engines/zvision/render_table.cpp @@ -100,18 +100,18 @@ uint16 mixTwoRGB(uint16 colorOne, uint16 colorTwo, float percentColorOne) { void RenderTable::mutateImage(uint16 *sourceBuffer, uint16* destBuffer, int16 imageWidth, int16 imageHeight, int16 destinationX, int16 destinationY, const Common::Rect &subRect, bool wrap, bool isTransposed) { for (int16 y = subRect.top; y < subRect.bottom; y++) { - uint16 normalizedY = y - subRect.top; - uint32 internalColumnIndex = (normalizedY + destinationY) * _numColumns; - uint32 destColumnIndex = normalizedY * _numColumns; + int16 normalizedY = y - subRect.top; + int32 internalColumnIndex = (normalizedY + destinationY) * _numColumns; + int32 destColumnIndex = normalizedY * _numColumns; for (int16 x = subRect.left; x < subRect.right; x++) { - uint16 normalizedX = x - subRect.left; + int16 normalizedX = x - subRect.left; - uint32 index = internalColumnIndex + normalizedX + destinationX; + int32 index = internalColumnIndex + normalizedX + destinationX; // RenderTable only stores offsets from the original coordinates - uint16 sourceYIndex = y + _internalBuffer[index].y; - uint16 sourceXIndex = x + _internalBuffer[index].x; + int16 sourceYIndex = y + _internalBuffer[index].y; + int16 sourceXIndex = x + _internalBuffer[index].x; if (wrap) { if (sourceXIndex >= imageWidth) { @@ -127,10 +127,10 @@ void RenderTable::mutateImage(uint16 *sourceBuffer, uint16* destBuffer, int16 im } } else { // Clamp the yIndex to the size of the image - sourceYIndex = CLIP<uint32>(sourceYIndex, 0, imageHeight - 1); + sourceYIndex = CLIP<int32>(sourceYIndex, 0, imageHeight - 1); // Clamp the xIndex to the size of the image - sourceXIndex = CLIP<uint32>(sourceXIndex, 0, imageWidth - 1); + sourceXIndex = CLIP<int32>(sourceXIndex, 0, imageWidth - 1); } if (isTransposed) { |