aboutsummaryrefslogtreecommitdiff
path: root/engines/sherlock
diff options
context:
space:
mode:
authorPaul Gilbert2015-06-04 22:06:05 -0400
committerPaul Gilbert2015-06-04 22:06:05 -0400
commitfb8e745e11a196ab345559740d70df248e127443 (patch)
tree094682bde8b33adebe21529332311bb2162a9a88 /engines/sherlock
parentbb1ebffbea325eeb10ffbe04ba6406b0e68217a2 (diff)
downloadscummvm-rg350-fb8e745e11a196ab345559740d70df248e127443.tar.gz
scummvm-rg350-fb8e745e11a196ab345559740d70df248e127443.tar.bz2
scummvm-rg350-fb8e745e11a196ab345559740d70df248e127443.zip
SHERLOCK: Simplify decompressFrame, and fix RT transparencies
Diffstat (limited to 'engines/sherlock')
-rw-r--r--engines/sherlock/resources.cpp22
1 files changed, 9 insertions, 13 deletions
diff --git a/engines/sherlock/resources.cpp b/engines/sherlock/resources.cpp
index cd2cd9d663..0b04d3c3cc 100644
--- a/engines/sherlock/resources.cpp
+++ b/engines/sherlock/resources.cpp
@@ -456,24 +456,23 @@ void ImageFile::loadPalette(Common::SeekableReadStream &stream) {
void ImageFile::decompressFrame(ImageFrame &frame, const byte *src) {
frame._frame.create(frame._width, frame._height, Graphics::PixelFormat::createFormatCLUT8());
+ byte *dest = (byte *)frame._frame.getPixels();
+ Common::fill(dest, dest + frame._width * frame._height, 0xff);
if (frame._paletteBase) {
// Nibble-packed
- byte *pDest = (byte *)frame._frame.getPixels();
for (uint idx = 0; idx < frame._size; ++idx, ++src) {
- *pDest++ = *src & 0xF;
- *pDest++ = (*src >> 4);
+ *dest++ = *src & 0xF;
+ *dest++ = (*src >> 4);
}
} else if (frame._rleEncoded && _vm->getGameID() == GType_RoseTattoo) {
// Rose Tattoo run length encoding doesn't use the RLE marker byte
- byte *dst = (byte *)frame._frame.getPixels();
-
for (int yp = 0; yp < frame._height; ++yp) {
int xSize = frame._width;
while (xSize > 0) {
// Skip a given number of pixels
byte skip = *src++;
- dst += skip;
+ dest += skip;
xSize -= skip;
if (!xSize)
break;
@@ -482,14 +481,12 @@ void ImageFile::decompressFrame(ImageFrame &frame, const byte *src) {
int rleCount = *src++;
xSize -= rleCount;
while (rleCount-- > 0)
- *dst++ = *src++;
+ *dest++ = *src++;
}
assert(xSize == 0);
}
} else if (frame._rleEncoded) {
// RLE encoded
- byte *dst = (byte *)frame._frame.getPixels();
-
int frameSize = frame._width * frame._height;
while (frameSize > 0) {
if (*src == frame._rleMarker) {
@@ -498,17 +495,16 @@ void ImageFile::decompressFrame(ImageFrame &frame, const byte *src) {
src += 3;
frameSize -= rleCount;
while (rleCount--)
- *dst++ = rleColor;
+ *dest++ = rleColor;
} else {
- *dst++ = *src++;
+ *dest++ = *src++;
--frameSize;
}
}
assert(frameSize == 0);
} else {
// Uncompressed frame
- Common::copy(src, src + frame._width * frame._height,
- (byte *)frame._frame.getPixels());
+ Common::copy(src, src + frame._width * frame._height, dest);
}
}