aboutsummaryrefslogtreecommitdiff
path: root/engines/pink/sound.cpp
diff options
context:
space:
mode:
authorwhiterandrek2018-06-09 20:26:32 +0300
committerEugene Sandulenko2018-06-28 23:51:32 +0200
commitcf04fb20c76f4c0ce52939e074cb79c40367f93a (patch)
tree134120264f1de871f3ecffadb003ae27bb4a001e /engines/pink/sound.cpp
parent4fd0ec3ff71614ecbf66ec7f8b414d99c74b1e32 (diff)
downloadscummvm-rg350-cf04fb20c76f4c0ce52939e074cb79c40367f93a.tar.gz
scummvm-rg350-cf04fb20c76f4c0ce52939e074cb79c40367f93a.tar.bz2
scummvm-rg350-cf04fb20c76f4c0ce52939e074cb79c40367f93a.zip
PINK: rework sound system
Diffstat (limited to 'engines/pink/sound.cpp')
-rw-r--r--engines/pink/sound.cpp42
1 files changed, 10 insertions, 32 deletions
diff --git a/engines/pink/sound.cpp b/engines/pink/sound.cpp
index 333093e063..81463b29bf 100644
--- a/engines/pink/sound.cpp
+++ b/engines/pink/sound.cpp
@@ -30,44 +30,22 @@
namespace Pink {
-Sound::Sound(Audio::Mixer *mixer, Common::SafeSeekableSubReadStream *stream)
- : _mixer(mixer), _fileStream(stream) {}
-
-Sound::~Sound() {
- _mixer->stopHandle(_handle);
- delete _fileStream;
-}
-
-bool Sound::isPlaying() {
- return _mixer->isSoundHandleActive(_handle);
-}
-
-void Sound::pause(bool paused) {
- _mixer->pauseHandle(_handle, paused);
-}
-
-void Sound::play(Audio::Mixer::SoundType type, int volume, bool isLoop) {
+void Sound::play(Common::SafeSeekableSubReadStream *stream, Audio::Mixer::SoundType type, byte volume, int8 balance, bool isLoop) {
// Vox files in pink have wave format.
// RIFF (little-endian) data, WAVE audio, Microsoft PCM, 8 bit, mono 22050 Hz
- _mixer->stopHandle(_handle);
- _fileStream->seek(0);
- Audio::AudioStream *audioStream ;
- Audio::SeekableAudioStream *wavStream = Audio::makeWAVStream(_fileStream, DisposeAfterUse::NO);
- if (isLoop) {
+ volume = ((int) volume * 255) / 100;
+ Audio::Mixer *mixer = g_system->getMixer();
+ mixer->stopHandle(_handle);
+
+ Audio::AudioStream *audioStream;
+ Audio::SeekableAudioStream *wavStream = Audio::makeWAVStream(stream, DisposeAfterUse::NO);
+ if (isLoop)
audioStream = Audio::makeLoopingAudioStream(wavStream, 0, 0, 0);
- } else
+ else
audioStream = wavStream;
- _mixer->playStream(type, &_handle , audioStream, -1 , 50, 0, DisposeAfterUse::YES);
-}
-
-void Sound::setBalance(int8 balance) {
- _mixer->setChannelBalance(_handle, balance);
-}
-
-uint32 Sound::getCurrentSample() {
- return _mixer->getSoundElapsedTime(_handle) * kSampleRate / 1000;
+ mixer->playStream(type, &_handle , audioStream, -1, volume, balance, DisposeAfterUse::YES);
}
} // End of namespace Pink