diff options
author | Johannes Schickel | 2010-01-07 16:34:56 +0000 |
---|---|---|
committer | Johannes Schickel | 2010-01-07 16:34:56 +0000 |
commit | d5fe29c3c949fda84a5a7a276160d57e646fc952 (patch) | |
tree | ba643bf1510a6fd061500abef7f08d432bbc7693 /engines/agos | |
parent | ca5e1379452f7777fd032baeb342ce88634d1836 (diff) | |
download | scummvm-rg350-d5fe29c3c949fda84a5a7a276160d57e646fc952.tar.gz scummvm-rg350-d5fe29c3c949fda84a5a7a276160d57e646fc952.tar.bz2 scummvm-rg350-d5fe29c3c949fda84a5a7a276160d57e646fc952.zip |
Make makeWAVStream return a RewindableAudioStream.
svn-id: r47129
Diffstat (limited to 'engines/agos')
-rw-r--r-- | engines/agos/sound.cpp | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/engines/agos/sound.cpp b/engines/agos/sound.cpp index ac965ac65f..d929574ac6 100644 --- a/engines/agos/sound.cpp +++ b/engines/agos/sound.cpp @@ -783,12 +783,15 @@ void Sound::playVoiceData(byte *soundData, uint sound) { void Sound::playSoundData(Audio::SoundHandle *handle, byte *soundData, uint sound, int pan, int vol, bool loop) { int size = READ_LE_UINT32(soundData + 4); Common::MemoryReadStream *stream = new Common::MemoryReadStream(soundData, size); - Audio::AudioStream *sndStream = Audio::makeWAVStream(stream, true, loop); + Audio::RewindableAudioStream *sndStream = Audio::makeWAVStream(stream, true); convertVolume(vol); convertPan(pan); - _mixer->playInputStream(Audio::Mixer::kSFXSoundType, handle, sndStream, -1, vol, pan); + if (loop) + _mixer->playInputStreamLooping(Audio::Mixer::kSFXSoundType, handle, sndStream, 0, -1, vol, pan); + else + _mixer->playInputStream(Audio::Mixer::kSFXSoundType, handle, sndStream, -1, vol, pan); } void Sound::stopSfx5() { |