aboutsummaryrefslogtreecommitdiff
path: root/engines/groovie
diff options
context:
space:
mode:
authorJohannes Schickel2013-09-16 17:10:57 -0700
committerJohannes Schickel2013-09-16 17:10:57 -0700
commit46a69c89f47451ec2a69cf66025624399ca1c2a2 (patch)
tree88bcf27a7d060c59e41dccd2c3413d3bcf5dba23 /engines/groovie
parentce63a325103234a0bd382891b81a7a6ac4f857a2 (diff)
parent4063de40705c2b21e092f2a275182b0f41070b15 (diff)
downloadscummvm-rg350-46a69c89f47451ec2a69cf66025624399ca1c2a2.tar.gz
scummvm-rg350-46a69c89f47451ec2a69cf66025624399ca1c2a2.tar.bz2
scummvm-rg350-46a69c89f47451ec2a69cf66025624399ca1c2a2.zip
Merge pull request #376 from lordhoto/libjpeg
GRAPHICS: Implement JPEGDecoder based on libjpeg.
Diffstat (limited to 'engines/groovie')
-rw-r--r--engines/groovie/roq.cpp12
1 files changed, 4 insertions, 8 deletions
diff --git a/engines/groovie/roq.cpp b/engines/groovie/roq.cpp
index f9a938bfd4..5592d848a9 100644
--- a/engines/groovie/roq.cpp
+++ b/engines/groovie/roq.cpp
@@ -435,17 +435,13 @@ bool ROQPlayer::processBlockStill(ROQBlockHeader &blockHeader) {
warning("Groovie::ROQ: JPEG frame (unfinished)");
Graphics::JPEGDecoder *jpg = new Graphics::JPEGDecoder();
+ jpg->setOutputColorSpace(Graphics::JPEGDecoder::kColorSpaceYUV);
jpg->loadStream(*_file);
- const byte *y = (const byte *)jpg->getComponent(1)->getPixels();
- const byte *u = (const byte *)jpg->getComponent(2)->getPixels();
- const byte *v = (const byte *)jpg->getComponent(3)->getPixels();
+ const Graphics::Surface *srcSurf = jpg->getSurface();
+ const byte *src = (const byte *)srcSurf->getPixels();
byte *ptr = (byte *)_currBuf->getPixels();
- for (int i = 0; i < _currBuf->w * _currBuf->h; i++) {
- *ptr++ = *y++;
- *ptr++ = *u++;
- *ptr++ = *v++;
- }
+ memcpy(ptr, src, _currBuf->w * _currBuf->h);
delete jpg;
return true;