2014-12-26 03:37:20 +00:00
|
|
|
/* 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.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef XEEN_SOUND_H
|
|
|
|
#define XEEN_SOUND_H
|
|
|
|
|
2016-08-27 20:33:32 +00:00
|
|
|
#include "audio/mixer.h"
|
|
|
|
#include "audio/audiostream.h"
|
2015-01-02 00:57:56 +00:00
|
|
|
#include "xeen/files.h"
|
2018-02-19 15:17:33 +00:00
|
|
|
#include "xeen/sound_driver.h"
|
2014-12-26 03:37:20 +00:00
|
|
|
|
|
|
|
namespace Xeen {
|
|
|
|
|
2018-02-19 15:17:33 +00:00
|
|
|
|
|
|
|
class Sound {
|
2016-09-16 01:25:06 +00:00
|
|
|
private:
|
2018-02-19 15:17:33 +00:00
|
|
|
SoundDriver *_SoundDriver;
|
|
|
|
const byte *_effectsData;
|
|
|
|
Common::Array<uint16> _effectsOffsets;
|
|
|
|
const byte *_songData;
|
2016-09-16 01:25:06 +00:00
|
|
|
Audio::Mixer *_mixer;
|
2016-09-17 03:27:26 +00:00
|
|
|
Audio::SoundHandle _soundHandle;
|
2018-03-06 12:11:33 +00:00
|
|
|
byte _musicPercent;
|
2018-02-19 15:17:33 +00:00
|
|
|
private:
|
|
|
|
/**
|
|
|
|
* Loads effects data that was embedded in the music driver
|
|
|
|
*/
|
|
|
|
void loadEffectsData();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Updates any playing music
|
|
|
|
*/
|
|
|
|
void update();
|
2016-09-18 21:31:12 +00:00
|
|
|
public:
|
2018-03-06 02:37:08 +00:00
|
|
|
bool _fxOn;
|
2018-02-19 15:17:33 +00:00
|
|
|
bool _musicOn;
|
|
|
|
Common::String _currentMusic, _priorMusic;
|
|
|
|
int _musicSide;
|
2014-12-26 03:37:20 +00:00
|
|
|
public:
|
2018-02-19 15:17:33 +00:00
|
|
|
Sound(Audio::Mixer *mixer);
|
2016-09-17 03:27:26 +00:00
|
|
|
virtual ~Sound();
|
2014-12-26 03:37:20 +00:00
|
|
|
|
2018-02-19 15:17:33 +00:00
|
|
|
/**
|
|
|
|
* Starts an effect playing
|
|
|
|
*/
|
|
|
|
void playFX(uint effectId);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Stops any currently playing FX
|
|
|
|
*/
|
|
|
|
void stopFX();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Executes special music command
|
|
|
|
*/
|
|
|
|
int songCommand(uint commandId, byte volume = 0);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Stops any currently playing music
|
|
|
|
*/
|
|
|
|
void stopSong() { songCommand(STOP_SONG); }
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Restart a previously playing song (which must still be loaded)
|
|
|
|
*/
|
|
|
|
void restartSong() { songCommand(RESTART_SONG); }
|
|
|
|
|
|
|
|
/**
|
2018-03-06 12:11:33 +00:00
|
|
|
* Sets the in-game music volume percent. This is separate from the ScummVM volume
|
2018-02-19 15:17:33 +00:00
|
|
|
*/
|
2018-03-06 12:11:33 +00:00
|
|
|
void setMusicPercent(byte percent);
|
2018-02-19 15:17:33 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Plays a song
|
|
|
|
*/
|
|
|
|
void playSong(Common::SeekableReadStream &stream);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Plays a song
|
|
|
|
*/
|
|
|
|
void playSong(const Common::String &name, int param = 0);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Plays a song
|
|
|
|
*/
|
|
|
|
void playSong(const byte *data) {
|
|
|
|
_SoundDriver->playSong(data);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns true if music is playing
|
|
|
|
*/
|
|
|
|
bool isMusicPlaying() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets whether music is on
|
|
|
|
*/
|
|
|
|
void setMusicOn(bool isOn);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets whether sound effects is on
|
|
|
|
*/
|
2018-03-06 02:37:08 +00:00
|
|
|
void setFxOn(bool isOn);
|
2018-02-19 15:17:33 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Called to reload sound settings
|
|
|
|
*/
|
|
|
|
void updateSoundSettings();
|
|
|
|
|
2016-09-17 03:27:26 +00:00
|
|
|
/**
|
|
|
|
* Play a given sound
|
|
|
|
*/
|
|
|
|
void playSound(Common::SeekableReadStream &s, int unused = 0);
|
2014-12-26 11:00:39 +00:00
|
|
|
|
2016-08-27 20:33:32 +00:00
|
|
|
/**
|
|
|
|
* Play a given sound
|
|
|
|
*/
|
2016-09-17 03:27:26 +00:00
|
|
|
void playSound(const Common::String &name, int unused = 0);
|
2016-09-04 20:52:35 +00:00
|
|
|
|
2018-02-03 01:07:55 +00:00
|
|
|
/**
|
|
|
|
* Play a given sound
|
|
|
|
*/
|
|
|
|
void playSound(const Common::String &name, int ccNum, int unused);
|
|
|
|
|
2016-08-27 20:33:32 +00:00
|
|
|
/**
|
2018-02-19 15:17:33 +00:00
|
|
|
* Stop playing a sound loaded from a .m file
|
2016-09-17 03:27:26 +00:00
|
|
|
* @remarks In the original, passing 1 to playSound stopped the sound
|
2016-08-27 20:33:32 +00:00
|
|
|
*/
|
2016-09-17 03:27:26 +00:00
|
|
|
void stopSound();
|
2015-01-19 17:13:03 +00:00
|
|
|
|
2016-09-17 03:27:26 +00:00
|
|
|
/**
|
2018-02-19 15:17:33 +00:00
|
|
|
* Returns true if a sound file is currently playing
|
2016-09-17 03:27:26 +00:00
|
|
|
* @remarks In the original, passing 0 to playSound returned play status
|
|
|
|
*/
|
2018-02-19 15:17:33 +00:00
|
|
|
bool isSoundPlaying() const;
|
2016-09-18 16:07:34 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Stops all playing music, FX, and sound samples
|
|
|
|
*/
|
|
|
|
void stopAllAudio();
|
2014-12-26 03:37:20 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
} // End of namespace Xeen
|
|
|
|
|
|
|
|
#endif /* XEEN_SOUND_H */
|