diff options
| author | Johannes Schickel | 2013-09-16 17:10:57 -0700 |
|---|---|---|
| committer | Johannes Schickel | 2013-09-16 17:10:57 -0700 |
| commit | 46a69c89f47451ec2a69cf66025624399ca1c2a2 (patch) | |
| tree | 88bcf27a7d060c59e41dccd2c3413d3bcf5dba23 /engines/groovie | |
| parent | ce63a325103234a0bd382891b81a7a6ac4f857a2 (diff) | |
| parent | 4063de40705c2b21e092f2a275182b0f41070b15 (diff) | |
| download | scummvm-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.cpp | 12 |
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; |
