From 08386210025c65d7199d26962a00a4206e06a899 Mon Sep 17 00:00:00 2001 From: Paul Gilbert Date: Fri, 21 Feb 2014 20:16:08 -0500 Subject: MADS: Added remaining commands from the asound.001 player --- engines/mads/nebular/sound_nebular.cpp | 53 +++++++++++++++++++++++++--------- engines/mads/nebular/sound_nebular.h | 14 +++++---- 2 files changed, 49 insertions(+), 18 deletions(-) (limited to 'engines') diff --git a/engines/mads/nebular/sound_nebular.cpp b/engines/mads/nebular/sound_nebular.cpp index 9c3ac61f2d..dba4b363bb 100644 --- a/engines/mads/nebular/sound_nebular.cpp +++ b/engines/mads/nebular/sound_nebular.cpp @@ -303,9 +303,9 @@ void ASound::playSound(int offset, int size) { playSound(loadData(offset, size)); } -void ASound::playSound(byte *pData) { +void ASound::playSound(byte *pData, int startingChannel) { // Scan for a high level free channel - for (int i = 5; i < ADLIB_CHANNEL_COUNT; ++i) { + for (int i = startingChannel; i < ADLIB_CHANNEL_COUNT; ++i) { if (!_channels[i]._activeCount) { _channels[i].load(pData); return; @@ -313,7 +313,7 @@ void ASound::playSound(byte *pData) { } // None found, do a secondary scan for an interruptable channel - for (int i = ADLIB_CHANNEL_COUNT - 1; i >= ADLIB_CHANNEL_MIDWAY; --i) { + for (int i = ADLIB_CHANNEL_COUNT - 1; i >= startingChannel; --i) { if (_channels[i]._fieldE == 0xFF) { _channels[i].load(pData); return; @@ -928,10 +928,11 @@ ASound1::ASound1(Audio::Mixer *mixer): ASound(mixer, "asound.001", 0x1520) { _samples.push_back(AdlibSample(_soundFile)); } -int ASound1::command(int commandId) { +int ASound1::command(int commandId, int param) { if (commandId > 41) return 0; + _commandParam = param; _frameCounter = 0; return (this->*_commandList[commandId])(); } @@ -1060,12 +1061,22 @@ int ASound1::command25() { } int ASound1::command26() { - error("TODO: command26"); + byte *pData = loadData(0xEEC, 10); + pData[5] = (command2627293032() + 0x7F) & 0xFF; + + if (!isSoundActive(pData)) + _channels[6].load(pData); + return 0; } int ASound1::command27() { - error("TODO: ASound::command27"); + byte *pData = loadData(0xEE2, 10); + pData[5] = (command2627293032() + 0x40) & 0xFF; + + if (!isSoundActive(pData)) + _channels[7].load(pData); + return 0; } @@ -1075,12 +1086,23 @@ int ASound1::command28() { } int ASound1::command29() { - error("TODO: ASound::command29"); + byte *pData = loadData(0xC82, 36); + byte v = (command2627293032() + 0x40) & 0xFF; + pData[7] = pData[13] = pData[21] = pData[27] = v; + + if (!isSoundActive(pData)) + playSound(pData, 0); + return 0; } int ASound1::command30() { - error("TODO: ASound::command30"); + byte *pData = loadData(0xEA6, 16); + pData[7] = (command2627293032() + 0x40) & 0xFF; + + if (!isSoundActive(pData)) + playSound(pData, 0); + return 0; } @@ -1093,7 +1115,14 @@ int ASound1::command31() { } int ASound1::command32() { - error("TODO: ASound::command32"); + byte *pData = loadData(0xEB4, 46); + int v = command2627293032() + 0x40; + pData[9] = pData[17] = pData[25] = pData[33] = v & 0xFF; + pData[11] = pData[19] = pData[27] = pData[35] = v >> 8; + + if (!isSoundActive(pData)) + playSound(pData, 0); + return 0; } @@ -1169,10 +1198,8 @@ void ASound1::command111213() { } } -void ASound1::command2627293032() { - // TODO: This method takes a parameter off the stack for several levels up. - // i.e. something the caller's caller pushed onto the stack. Need to figure - // out a better way to pass parameters down if this is actually in use. +int ASound1::command2627293032() { + return (_commandParam > 0x40) ? _commandParam - 0x40 : _commandParam & 0xff00; } } // End of namespace Nebular diff --git a/engines/mads/nebular/sound_nebular.h b/engines/mads/nebular/sound_nebular.h index 11836e6559..c7a28620be 100644 --- a/engines/mads/nebular/sound_nebular.h +++ b/engines/mads/nebular/sound_nebular.h @@ -226,8 +226,9 @@ protected: /** * Play the specified raw sound data * @param pData Pointer to data block containing sound data + * @param startingChannel Channel to start scan from */ - void playSound(byte *pData); + void playSound(byte *pData, int startingChannel = ADLIB_CHANNEL_COUNT); /** * Checks to see whether the given block of data is already loaded into a channel. @@ -307,9 +308,11 @@ public: /** * Execute a player command. Most commands represent sounds to play, but some - * low number commands also provide control operations + * low number commands also provide control operations. + * @param commandId Player ommand to execute. + * @param param Optional parameter used by a few commands */ - virtual int command(int commandId) = 0; + virtual int command(int commandId, int param = 0) = 0; /** * Stop all currently playing sounds @@ -358,6 +361,7 @@ private: typedef int (ASound1::*CommandPtr)(); static const CommandPtr _commandList[42]; bool _cmd23Toggle; + int _commandParam; int command9(); int command10(); @@ -394,11 +398,11 @@ private: int command41(); void command111213(); - void command2627293032(); + int command2627293032(); public: ASound1(Audio::Mixer *mixer); - virtual int command(int commandId); + virtual int command(int commandId, int param = 0); }; } // End of namespace Nebular -- cgit v1.2.3