diff options
author | Marisa-Chan | 2014-06-13 21:43:04 +0700 |
---|---|---|
committer | Marisa-Chan | 2014-06-13 21:43:04 +0700 |
commit | 45589950c0fb1a449351e6a00ef10d42290d8bae (patch) | |
tree | 44e4eedcb7e69d5fc386155b000ed038af07251d /engines/bbvs/sound.cpp | |
parent | 48360645dcd5f8fddb135b6e31ae5cae4be8d77f (diff) | |
parent | 5c005ad3a3f1df0bc968c85c1cf0fc48e36ab0b2 (diff) | |
download | scummvm-rg350-45589950c0fb1a449351e6a00ef10d42290d8bae.tar.gz scummvm-rg350-45589950c0fb1a449351e6a00ef10d42290d8bae.tar.bz2 scummvm-rg350-45589950c0fb1a449351e6a00ef10d42290d8bae.zip |
Merge remote-tracking branch 'upstream/master' into zvision
Conflicts:
engines/zvision/animation/rlf_animation.cpp
engines/zvision/animation_control.h
engines/zvision/core/console.cpp
engines/zvision/core/events.cpp
engines/zvision/cursors/cursor.cpp
engines/zvision/cursors/cursor_manager.cpp
engines/zvision/cursors/cursor_manager.h
engines/zvision/fonts/truetype_font.cpp
engines/zvision/graphics/render_manager.cpp
engines/zvision/graphics/render_manager.h
engines/zvision/inventory/inventory_manager.h
engines/zvision/inventory_manager.h
engines/zvision/meta_animation.h
engines/zvision/module.mk
engines/zvision/scripting/actions.cpp
engines/zvision/scripting/control.h
engines/zvision/scripting/controls/animation_control.cpp
engines/zvision/scripting/controls/animation_control.h
engines/zvision/scripting/controls/input_control.cpp
engines/zvision/scripting/controls/lever_control.cpp
engines/zvision/scripting/controls/timer_node.cpp
engines/zvision/scripting/controls/timer_node.h
engines/zvision/scripting/puzzle.h
engines/zvision/scripting/scr_file_handling.cpp
engines/zvision/scripting/script_manager.cpp
engines/zvision/scripting/script_manager.h
engines/zvision/sidefx.cpp
engines/zvision/sound/zork_raw.cpp
engines/zvision/sound/zork_raw.h
engines/zvision/video/video.cpp
engines/zvision/video/zork_avi_decoder.h
engines/zvision/zvision.cpp
engines/zvision/zvision.h
Diffstat (limited to 'engines/bbvs/sound.cpp')
-rw-r--r-- | engines/bbvs/sound.cpp | 107 |
1 files changed, 107 insertions, 0 deletions
diff --git a/engines/bbvs/sound.cpp b/engines/bbvs/sound.cpp new file mode 100644 index 0000000000..7f9c00ad48 --- /dev/null +++ b/engines/bbvs/sound.cpp @@ -0,0 +1,107 @@ +/* ScummVM - Graphic Adventure Engine + * + * ScummVM is the legal property of its developers, whose names + * are too numerous to list here. Please refer to the COPYRIGHT + * file distributed with this source distribution. + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + * + */ + +#include "bbvs/sound.h" +#include "audio/decoders/aiff.h" +#include "common/debug.h" +#include "common/file.h" +#include "common/system.h" + +namespace Bbvs { + +Sound::Sound() : _stream(0) { +} + +Sound::~Sound() { + stop(); + delete _stream; +} + +void Sound::load(const Common::String &filename) { + Common::File *fd = new Common::File(); + if (!fd->open(filename)) { + delete fd; + error("SoundMan::loadSound() Could not load %s", filename.c_str()); + } + _stream = Audio::makeAIFFStream(fd, DisposeAfterUse::YES); + _filename = filename; +} + +void Sound::play(bool loop) { + debug(0, "Sound::play() [%s] loop:%d", _filename.c_str(), loop); + stop(); + _stream->rewind(); + Audio::AudioStream *audioStream = Audio::makeLoopingAudioStream(_stream, loop ? 0 : 1); + g_system->getMixer()->playStream(Audio::Mixer::kSFXSoundType, &_handle, audioStream, + -1, Audio::Mixer::kMaxChannelVolume, 0, DisposeAfterUse::NO); +} + +void Sound::stop() { + g_system->getMixer()->stopHandle(_handle); +} + +bool Sound::isPlaying() { + return g_system->getMixer()->isSoundHandleActive(_handle); +} + +SoundMan::~SoundMan() { + stopAllSounds(); + unloadSounds(); +} + +void SoundMan::loadSound(const Common::String &filename) { + Sound *sound = new Sound(); + sound->load(filename); + _sounds.push_back(sound); +} + +void SoundMan::playSound(uint index, bool loop) { + _sounds[index]->play(loop); +} + +void SoundMan::stopSound(uint index) { + _sounds[index]->stop(); +} + +bool SoundMan::isSoundPlaying(uint index) { + return _sounds[index]->isPlaying(); +} + +bool SoundMan::isAnySoundPlaying(uint *indices, uint count) { + for (uint i = 0; i < count; ++i) + if (isSoundPlaying(indices[i])) + return true; + return false; +} + +void SoundMan::unloadSounds() { + for (uint i = 0; i < _sounds.size(); ++i) + delete _sounds[i]; + _sounds.clear(); +} + +void SoundMan::stopAllSounds() { + for (uint i = 0; i < _sounds.size(); ++i) + _sounds[i]->stop(); +} + +} // End of namespace Bbvs |