diff options
-rw-r--r-- | engines/sci/sound/midiparser_sci.cpp | 14 | ||||
-rw-r--r-- | engines/sci/sound/midiparser_sci.h | 2 | ||||
-rw-r--r-- | engines/sci/sound/music.h | 10 | ||||
-rw-r--r-- | engines/sci/sound/soundcmd.cpp | 8 |
4 files changed, 20 insertions, 14 deletions
diff --git a/engines/sci/sound/midiparser_sci.cpp b/engines/sci/sound/midiparser_sci.cpp index 70421d7e15..ded7b59846 100644 --- a/engines/sci/sound/midiparser_sci.cpp +++ b/engines/sci/sound/midiparser_sci.cpp @@ -199,7 +199,7 @@ void MidiParser_SCI::parseNextEvent(EventInfo &info) { } } if (info.basic.param1 == 7) // channel volume change -scale it - info.basic.param2 = info.basic.param2 * _volume / 0x7F; + info.basic.param2 = info.basic.param2 * _volume / MUSIC_VOLUME_MAX; info.length = 0; break; @@ -474,18 +474,16 @@ byte *MidiParser_SCI::midiFilterChannels(int channelMask) { return _mixedData; } -void MidiParser_SCI::setVolume(byte bVolume) { - if (bVolume > 0x7F) - bVolume = 0x7F; - if (_volume != bVolume) { - _volume = bVolume; +void MidiParser_SCI::setVolume(byte volume) { + assert(volume <= MUSIC_VOLUME_MAX); + if (_volume != volume) { + _volume = volume; switch (_soundVersion) { case SCI_VERSION_0_EARLY: case SCI_VERSION_0_LATE: { - MidiPlayer *SCIDriver = (MidiPlayer *)_driver; int16 globalVolume = _volume * 15 / 127; - SCIDriver->setVolume(globalVolume); + ((MidiPlayer *)_driver)->setVolume(globalVolume); break; } diff --git a/engines/sci/sound/midiparser_sci.h b/engines/sci/sound/midiparser_sci.h index a5b2074fbc..ff818eb381 100644 --- a/engines/sci/sound/midiparser_sci.h +++ b/engines/sci/sound/midiparser_sci.h @@ -54,7 +54,7 @@ public: return false; } void unloadMusic(); - void setVolume(byte bVolume); + void setVolume(byte volume); void stop() { _abort_parse = true; allNotesOff(); diff --git a/engines/sci/sound/music.h b/engines/sci/sound/music.h index eaed0af64d..3c7b1492a6 100644 --- a/engines/sci/sound/music.h +++ b/engines/sci/sound/music.h @@ -154,6 +154,16 @@ public: uint16 soundGetVoices(); uint32 soundGetTempo() const { return _dwTempo; } + bool soundIsActive(MusicEntry *pSnd) { + assert(pSnd->pStreamAud != 0); + return _pMixer->isSoundHandleActive(pSnd->hCurrentAud); + } + + void updateAudioStreamTicker(MusicEntry *pSnd) { + assert(pSnd->pStreamAud != 0); + pSnd->ticker = (uint16)(_pMixer->getSoundElapsedTime(pSnd->hCurrentAud) * 0.06); + } + MusicEntry *getSlot(reg_t obj); void pushBackSlot(MusicEntry *slotEntry) { diff --git a/engines/sci/sound/soundcmd.cpp b/engines/sci/sound/soundcmd.cpp index 06b87afdfd..f6059724f4 100644 --- a/engines/sci/sound/soundcmd.cpp +++ b/engines/sci/sound/soundcmd.cpp @@ -804,22 +804,20 @@ void SoundCommandParser::cmdUpdateCues(reg_t obj, int16 value) { if (musicSlot->pStreamAud) { // Update digital sound effect slots here - Audio::Mixer *mixer = g_system->getMixer(); - uint currentLoopCounter = musicSlot->pStreamAud->getNumPlayedLoops(); if (currentLoopCounter != musicSlot->sampleLoopCounter) { // during last time we looped at least one time, update loop accordingly musicSlot->loop -= currentLoopCounter - musicSlot->sampleLoopCounter; musicSlot->sampleLoopCounter = currentLoopCounter; } - if (!mixer->isSoundHandleActive(musicSlot->hCurrentAud)) { + if (!_music->soundIsActive(musicSlot)) { cmdStopSound(obj, 0); } else { - musicSlot->ticker = (uint16)(mixer->getSoundElapsedTime(musicSlot->hCurrentAud) * 0.06); + _music->updateAudioStreamTicker(musicSlot); } // We get a flag from MusicEntry::doFade() here to set volume for the stream if (musicSlot->fadeSetVolume) { - mixer->setChannelVolume(musicSlot->hCurrentAud, musicSlot->volume); + _music->soundSetVolume(musicSlot, musicSlot->volume); musicSlot->fadeSetVolume = false; } } else { |