diff options
-rw-r--r-- | engines/illusions/illusions.cpp | 23 | ||||
-rw-r--r-- | engines/illusions/illusions.h | 5 | ||||
-rw-r--r-- | engines/illusions/sound.cpp | 87 | ||||
-rw-r--r-- | engines/illusions/sound.h | 29 | ||||
-rw-r--r-- | engines/illusions/talkthread.cpp | 13 | ||||
-rw-r--r-- | engines/illusions/talkthread_duckman.cpp | 20 |
6 files changed, 132 insertions, 45 deletions
diff --git a/engines/illusions/illusions.cpp b/engines/illusions/illusions.cpp index 1260714d17..c58eb85c0d 100644 --- a/engines/illusions/illusions.cpp +++ b/engines/illusions/illusions.cpp @@ -257,32 +257,9 @@ void IllusionsEngine::playVideo(uint32 videoId, uint32 objectId, uint32 priority bool IllusionsEngine::isSoundActive() { // TODO - return false; -} - -bool IllusionsEngine::cueVoice(byte *voiceName) { - // TODO return true; } -bool IllusionsEngine::isVoiceCued() { - // TODO - return false; -} - -void IllusionsEngine::startVoice(int volume, int panX) { - // TODO -} - -void IllusionsEngine::stopVoice() { - // TODO -} - -bool IllusionsEngine::isVoicePlaying() { - // TODO - return false; -} - void IllusionsEngine::updateFader() { if (_fader && !_fader->_paused && _fader->_active) { int32 currTime = getCurrentTime(); diff --git a/engines/illusions/illusions.h b/engines/illusions/illusions.h index 1a1f542001..522d1dc9c3 100644 --- a/engines/illusions/illusions.h +++ b/engines/illusions/illusions.h @@ -157,11 +157,6 @@ public: bool calcPointDirection(Common::Point &srcPt, Common::Point &dstPt, uint &facing); void playVideo(uint32 videoId, uint32 objectId, uint32 value, uint32 threadId); bool isSoundActive(); - bool cueVoice(byte *voiceName); - bool isVoiceCued(); - void startVoice(int volume, int panX); - void stopVoice(); - bool isVoicePlaying(); void updateFader(); diff --git a/engines/illusions/sound.cpp b/engines/illusions/sound.cpp index 632b842d6f..0f60e5d14c 100644 --- a/engines/illusions/sound.cpp +++ b/engines/illusions/sound.cpp @@ -33,6 +33,7 @@ MusicPlayer::MusicPlayer(Audio::Mixer *mixer) } MusicPlayer::~MusicPlayer() { + stop(); } void MusicPlayer::play(uint32 musicId, bool looping, int16 volume, int16 pan) { @@ -40,7 +41,6 @@ void MusicPlayer::play(uint32 musicId, bool looping, int16 volume, int16 pan) { if (_flags & 1) { stop(); _musicId = musicId; - Common::String filename = Common::String::format("%08x.wav", _musicId); _flags |= 2; _flags &= ~4; if (looping) { @@ -48,6 +48,7 @@ void MusicPlayer::play(uint32 musicId, bool looping, int16 volume, int16 pan) { } else { _flags &= ~8; } + Common::String filename = Common::String::format("%08x.wav", _musicId); Common::File *fd = new Common::File(); fd->open(filename); Audio::AudioStream *audioStream = Audio::makeLoopingAudioStream(Audio::makeWAVStream(fd, DisposeAfterUse::YES), looping ? 0 : 1); @@ -71,15 +72,71 @@ bool MusicPlayer::isPlaying() { return (_flags & 1) && (_flags & 2) && _mixer->isSoundHandleActive(_soundHandle); } +// VoicePlayer + +VoicePlayer::VoicePlayer(Audio::Mixer *mixer) + : _mixer(mixer) { +} + +VoicePlayer::~VoicePlayer() { + stop(); +} + +bool VoicePlayer::cue(const char *voiceName) { +debug("VoicePlayer::cue(%s)", voiceName); + _voiceName = voiceName; + _voiceStatus = 2; + if (!isEnabled()) { + _voiceStatus = 3; + return false; + } + return true; +} + +void VoicePlayer::stopCueing() { + _voiceStatus = 3; +} + +void VoicePlayer::start(int16 volume, int16 pan) { + Common::String filename = Common::String::format("%s.wav", _voiceName.c_str()); + Common::File *fd = new Common::File(); + fd->open(filename); + Audio::AudioStream *audioStream = Audio::makeWAVStream(fd, DisposeAfterUse::YES); + _mixer->playStream(Audio::Mixer::kSpeechSoundType, &_soundHandle, audioStream, -1, volume, pan); + _voiceStatus = 4; +} + +void VoicePlayer::stop() { + if (_mixer->isSoundHandleActive(_soundHandle)) + _mixer->stopHandle(_soundHandle); + _voiceStatus = 1; + _voiceName.clear(); +} + +bool VoicePlayer::isPlaying() { + return _mixer->isSoundHandleActive(_soundHandle); +} + +bool VoicePlayer::isEnabled() { + // TODO + return true; +} + +bool VoicePlayer::isCued() { + return _voiceStatus == 2; +} + // SoundMan SoundMan::SoundMan(IllusionsEngine *vm) : _vm(vm), _musicNotifyThreadId(0) { _musicPlayer = new MusicPlayer(_vm->_mixer); + _voicePlayer = new VoicePlayer(_vm->_mixer); } SoundMan::~SoundMan() { delete _musicPlayer; + delete _voicePlayer; } void SoundMan::update() { @@ -98,4 +155,32 @@ void SoundMan::stopMusic() { _musicPlayer->stop(); } +bool SoundMan::cueVoice(const char *voiceName) { + return _voicePlayer->cue(voiceName); +} + +void SoundMan::stopCueingVoice() { + _voicePlayer->stopCueing(); +} + +void SoundMan::startVoice(int16 volume, int16 pan) { + _voicePlayer->start(volume, pan); +} + +void SoundMan::stopVoice() { + _voicePlayer->stop(); +} + +bool SoundMan::isVoicePlaying() { + return _voicePlayer->isPlaying(); +} + +bool SoundMan::isVoiceEnabled() { + return _voicePlayer->isEnabled(); +} + +bool SoundMan::isVoiceCued() { + return _voicePlayer->isCued(); +} + } // End of namespace Illusions diff --git a/engines/illusions/sound.h b/engines/illusions/sound.h index e5139d3161..9e2cd43fa1 100644 --- a/engines/illusions/sound.h +++ b/engines/illusions/sound.h @@ -47,17 +47,46 @@ protected: uint _flags; }; +class VoicePlayer { +public: + VoicePlayer(Audio::Mixer *mixer); + ~VoicePlayer(); + bool cue(const char *voiceName); + void stopCueing(); + void start(int16 volume, int16 pan); + void stop(); + bool isPlaying(); + bool isEnabled(); + bool isCued(); +protected: + Audio::Mixer *_mixer; + Audio::SoundHandle _soundHandle; + Common::String _voiceName; + uint _voiceStatus; +}; + class SoundMan { public: SoundMan(IllusionsEngine *vm); ~SoundMan(); void update(); + void playMusic(uint32 musicId, int16 type, int16 volume, int16 pan, uint32 notifyThreadId); void stopMusic(); + + bool cueVoice(const char *voiceName); + void stopCueingVoice(); + void startVoice(int16 volume, int16 pan); + void stopVoice(); + bool isVoicePlaying(); + bool isVoiceEnabled(); + bool isVoiceCued(); + protected: IllusionsEngine *_vm; uint32 _musicNotifyThreadId; MusicPlayer *_musicPlayer; + VoicePlayer *_voicePlayer; }; } // End of namespace Illusions diff --git a/engines/illusions/talkthread.cpp b/engines/illusions/talkthread.cpp index 5ad6f7214a..783e9d2361 100644 --- a/engines/illusions/talkthread.cpp +++ b/engines/illusions/talkthread.cpp @@ -26,6 +26,7 @@ #include "illusions/dictionary.h" #include "illusions/input.h" #include "illusions/scriptman.h" +#include "illusions/sound.h" #include "illusions/talkresource.h" #include "illusions/time.h" @@ -118,7 +119,7 @@ int TalkThread::onUpdate() { _flags |= 1; } if (_vm->isSoundActive()) { - if (!_vm->cueVoice(talkEntry->_voiceName) && !_durationMult) + if (!_vm->_soundMan->cueVoice((char*)talkEntry->_voiceName) && !_durationMult) _durationMult = _defDurationMult; } else { _flags |= 4; @@ -131,7 +132,7 @@ int TalkThread::onUpdate() { // Fallthrough to status 4 case 4: - if (!(_flags & 4) && !_vm->isVoiceCued()) + if (!(_flags & 4) && !_vm->_soundMan->isVoiceCued()) return kTSYield; _status = 5; // Fallthrough to status 5 @@ -149,14 +150,14 @@ int TalkThread::onUpdate() { // TODO pt.x = (unsigned int)artcntrlGetNamedPointPosition((Point)_namedPointId); // TODO panX = convertPanXCoord(pt.x); } - _vm->startVoice(255, panX); + _vm->_soundMan->startVoice(255, panX); } _vm->_input->discardButtons(0x10); _status = 6; return kTSYield; case 6: - if (!(_flags & 4) && !_vm->isVoicePlaying()) + if (!(_flags & 4) && !_vm->_soundMan->isVoicePlaying()) _flags |= 4; if (!(_flags & 8) && isTimerExpired(_textStartTime, _textEndTime)) { // TODO _vm->removeText(); @@ -188,7 +189,7 @@ int TalkThread::onUpdate() { } if (_flags & 8) { if (!(_flags & 4)) { - _vm->stopVoice(); + _vm->_soundMan->stopVoice(); _flags |= 4; } if (!(_flags & 2)) { @@ -228,7 +229,7 @@ int TalkThread::onUpdate() { _flags |= 8; } if (!(_flags & 4)) { - _vm->stopVoice(); + _vm->_soundMan->stopVoice(); _flags |= 4; } return kTSTerminate; diff --git a/engines/illusions/talkthread_duckman.cpp b/engines/illusions/talkthread_duckman.cpp index 990d1be90b..788126810b 100644 --- a/engines/illusions/talkthread_duckman.cpp +++ b/engines/illusions/talkthread_duckman.cpp @@ -27,6 +27,7 @@ #include "illusions/input.h" #include "illusions/screentext.h" #include "illusions/scriptman.h" +#include "illusions/sound.h" #include "illusions/talkresource.h" #include "illusions/time.h" @@ -79,24 +80,23 @@ int TalkThread_Duckman::onUpdate() { case 2: talkEntry = getTalkResourceEntry(_talkId); _flags = 0; - _entryText = talkEntry->_text; _currEntryText = 0; + _entryText = talkEntry->_text; _entryTblPtr = talkEntry->_tblPtr; - _flags = 0; if (_sequenceId1) { - _pauseCtr = 0; _pauseCtrPtr = &_pauseCtr; + _pauseCtr = 0; } else { _pauseCtrPtr = 0; _flags |= 2; _flags |= 1; } if (_vm->isSoundActive()) { - if (!_vm->cueVoice(talkEntry->_voiceName) && !_durationMult) + if (!_vm->_soundMan->cueVoice((char*)talkEntry->_voiceName) && !_durationMult) _durationMult = _defDurationMult; } else { _flags |= 4; - if (!_durationMult) + if (_durationMult == 0) _durationMult = _defDurationMult; } if (_objectId == 0 || _durationMult == 0) @@ -105,7 +105,7 @@ int TalkThread_Duckman::onUpdate() { // Fallthrough to status 3 case 3: - if (!(_flags & 4) && !_vm->isVoiceCued()) + if (!(_flags & 4) && !_vm->_soundMan->isVoiceCued()) return kTSYield; _status = 4; // Fallthrough to status 4 @@ -132,14 +132,14 @@ int TalkThread_Duckman::onUpdate() { panX = control->getActorPosition().x; panX = _vm->convertPanXCoord(panX); } - _vm->startVoice(255, panX); + _vm->_soundMan->startVoice(255, panX); } _vm->_input->discardButtons(0x20); _status = 5; return kTSYield; case 5: - if (!(_flags & 4) && !_vm->isVoicePlaying()) + if (!(_flags & 4) && !_vm->_soundMan->isVoicePlaying()) _flags |= 4; if (!(_flags & 8) && isTimerExpired(_textStartTime, _textEndTime)) { _vm->_screenText->removeText(); @@ -168,7 +168,7 @@ int TalkThread_Duckman::onUpdate() { } if (_flags & 8) { if (!(_flags & 4)) { - _vm->stopVoice(); + _vm->_soundMan->stopVoice(); _flags |= 4; } if (!(_flags & 2)) { @@ -219,7 +219,7 @@ void TalkThread_Duckman::onResume() { void TalkThread_Duckman::onTerminated() { if (_status == 5) { if (!(_flags & 4)) - _vm->stopVoice(); + _vm->_soundMan->stopVoice(); if (!(_flags & 8)) { _vm->_screenText->removeText(); } |