From 1de9019665d8e1d2791684ae84d4ca45f652bb38 Mon Sep 17 00:00:00 2001 From: Filippos Karapetis Date: Mon, 26 Sep 2016 06:44:03 +0300 Subject: CHEWY: Remove some unused CFO video custom sub chunks --- engines/chewy/chewy.cpp | 5 +++++ engines/chewy/video/cfo_decoder.cpp | 45 +++++++++++++++---------------------- engines/chewy/video/cfo_decoder.h | 2 +- 3 files changed, 24 insertions(+), 28 deletions(-) diff --git a/engines/chewy/chewy.cpp b/engines/chewy/chewy.cpp index b2b8cd1b22..e5dd7ec265 100644 --- a/engines/chewy/chewy.cpp +++ b/engines/chewy/chewy.cpp @@ -72,6 +72,11 @@ Common::Error ChewyEngine::run() { initialize(); + /*for (uint i = 0; i < 161; i++) { + debug("Video %d", i); + _graphics->playVideo(i); + }*/ + //_graphics->playVideo(0); _graphics->drawImage("episode1.tgp", 0); //_sound->playSpeech(1); diff --git a/engines/chewy/video/cfo_decoder.cpp b/engines/chewy/video/cfo_decoder.cpp index bfdf0656bb..9ec11cc4a1 100644 --- a/engines/chewy/video/cfo_decoder.cpp +++ b/engines/chewy/video/cfo_decoder.cpp @@ -33,27 +33,27 @@ namespace Chewy { enum CustomSubChunk { - kChunkFadeIn = 0, + kChunkFadeIn = 0, // unused kChunkFadeOut = 1, kChunkLoadMusic = 2, - kChunkLoadRaw = 3, + kChunkLoadRaw = 3, // unused kChunkLoadVoc = 4, kChunkPlayMusic = 5, - kChunkPlaySeq = 6, - kChunkPlayPattern = 7, + kChunkPlaySeq = 6, // unused + kChunkPlayPattern = 7, // unused kChunkStopMusic = 8, kChunkWaitMusicEnd = 9, kChunkSetMusicVolume = 10, - kChunkSetLoopMode = 11, - kChunkPlayRaw = 12, + kChunkSetLoopMode = 11, // unused + kChunkPlayRaw = 12, // unused kChunkPlayVoc = 13, kChunkSetSoundVolume = 14, kChunkSetChannelVolume = 15, kChunkFreeSoundEffect = 16, - kChunkMusicFadeIn = 17, + kChunkMusicFadeIn = 17, // unused kChunkMusicFadeOut = 18, kChunkSetBalance = 19, - kChunkSetSpeed = 20, + kChunkSetSpeed = 20, // unused kChunkClearScreen = 21 }; @@ -182,18 +182,17 @@ void CfoDecoder::CfoVideoTrack::handleCustomFrame() { switch (frameType) { case kChunkFadeIn: - delay = _fileStream->readUint16LE(); - - warning("kChunkFadeIn, delay %d", delay); - // TODO + error("Unused chunk kChunkFadeIn found"); break; case kChunkFadeOut: + // Used in video 0 delay = _fileStream->readUint16LE(); warning("kChunkFadeOut, delay %d", delay); // TODO break; case kChunkLoadMusic: + // Used in videos 0, 18, 34, 71 warning("kChunkLoadMusic"); // TODO _fileStream->skip(frameSize); @@ -211,19 +210,16 @@ void CfoDecoder::CfoVideoTrack::handleCustomFrame() { _fileStream->read(_soundEffects[number], frameSize - 2); break; case kChunkPlayMusic: + // Used in videos 0, 18, 34, 71 warning("kChunkPlayMusic"); // TODO _fileStream->skip(frameSize); break; case kChunkPlaySeq: - warning("kChunkPlaySeq"); - // TODO - _fileStream->skip(frameSize); + error("Unused chunk kChunkPlaySeq found"); break; case kChunkPlayPattern: - warning("kChunkPlayPattern"); - // TODO - _fileStream->skip(frameSize); + error("Unused chunk kChunkPlayPattern found"); break; case kChunkStopMusic: g_engine->_mixer->stopHandle(_musicHandle); @@ -239,9 +235,7 @@ void CfoDecoder::CfoVideoTrack::handleCustomFrame() { g_engine->_mixer->setVolumeForSoundType(Audio::Mixer::SoundType::kMusicSoundType, volume); break; case kChunkSetLoopMode: - warning("kChunkSetLoopMode"); - // TODO - _fileStream->skip(frameSize); + error("Unused chunk kChunkSetLoopMode found"); break; case kChunkPlayRaw: error("Unused chunk kChunkPlayRaw found"); @@ -283,11 +277,10 @@ void CfoDecoder::CfoVideoTrack::handleCustomFrame() { _soundEffects[number] = nullptr; break; case kChunkMusicFadeIn: - warning("kChunkMusicFadeIn"); - // TODO - _fileStream->skip(frameSize); + error("Unused chunk kChunkMusicFadeIn found"); break; case kChunkMusicFadeOut: + // Used in videos 0, 71 warning("kChunkMusicFadeOut"); // TODO _fileStream->skip(frameSize); @@ -300,9 +293,7 @@ void CfoDecoder::CfoVideoTrack::handleCustomFrame() { g_engine->_mixer->setChannelBalance(_soundHandle[channel], balance); break; case kChunkSetSpeed: - warning("kChunkSetSpeed"); - // TODO - _fileStream->skip(frameSize); + error("Unused chunk kChunkSetSpeed found"); break; case kChunkClearScreen: g_system->fillScreen(0); diff --git a/engines/chewy/video/cfo_decoder.h b/engines/chewy/video/cfo_decoder.h index 9150d681a1..4396205607 100644 --- a/engines/chewy/video/cfo_decoder.h +++ b/engines/chewy/video/cfo_decoder.h @@ -29,7 +29,7 @@ namespace Chewy { -#define MAX_SOUND_EFFECTS 10 +#define MAX_SOUND_EFFECTS 14 // A FLIC decoder, with a modified header and additional custom frames class CfoDecoder : public Video::FlicDecoder { -- cgit v1.2.3