aboutsummaryrefslogtreecommitdiff
path: root/engines/startrek/sound.cpp
diff options
context:
space:
mode:
authorMatthew Stewart2018-05-30 21:06:56 -0400
committerEugene Sandulenko2018-08-09 08:37:30 +0200
commitc17bef8285086d438a03fcff6ae5f3d15b5532e8 (patch)
tree03aea9b3d6beb68f6eaa11cb87e283fbf019d345 /engines/startrek/sound.cpp
parentfe5658ca175810f7ea6cbcaa078e6fc86faf36f1 (diff)
downloadscummvm-rg350-c17bef8285086d438a03fcff6ae5f3d15b5532e8.tar.gz
scummvm-rg350-c17bef8285086d438a03fcff6ae5f3d15b5532e8.tar.bz2
scummvm-rg350-c17bef8285086d438a03fcff6ae5f3d15b5532e8.zip
STARTREK: Loop audio
Diffstat (limited to 'engines/startrek/sound.cpp')
-rw-r--r--engines/startrek/sound.cpp13
1 files changed, 11 insertions, 2 deletions
diff --git a/engines/startrek/sound.cpp b/engines/startrek/sound.cpp
index 128c968820..f3447462b7 100644
--- a/engines/startrek/sound.cpp
+++ b/engines/startrek/sound.cpp
@@ -160,8 +160,11 @@ void Sound::playVoc(const Common::String &baseSoundName) {
playMacSoundEffect(baseSoundName);
else
*/
- if (baseSoundName.size() == 8 && baseSoundName.hasSuffixIgnoreCase("loop"))
+ bool loop = false;
+ if (baseSoundName.size() == 8 && baseSoundName.hasSuffixIgnoreCase("loop")) {
_loopingAudioName = baseSoundName;
+ loop = true;
+ }
if (!_vm->_sfxEnabled || !_vm->_sfxWorking)
return;
@@ -182,7 +185,13 @@ void Sound::playVoc(const Common::String &baseSoundName) {
error("Couldn't open '%s'", soundName.c_str());
debugC(5, kDebugSound, "Playing sound effect '%s'", soundName.c_str());
- Audio::AudioStream *audioStream = Audio::makeVOCStream(readStream, Audio::FLAG_UNSIGNED, DisposeAfterUse::YES);
+
+ Audio::RewindableAudioStream *srcStream = Audio::makeVOCStream(readStream, Audio::FLAG_UNSIGNED, DisposeAfterUse::YES);
+ Audio::AudioStream *audioStream;
+ if (loop)
+ audioStream = new Audio::LoopingAudioStream(srcStream, 0, DisposeAfterUse::YES);
+ else
+ audioStream = srcStream;
_vm->_system->getMixer()->playStream(Audio::Mixer::kSFXSoundType, &_sfxHandles[i], audioStream);
return;
}