2012-08-09 12:33:21 +00:00
|
|
|
#ifndef GAME_MWBASE_SOUNDMANAGER_H
|
|
|
|
#define GAME_MWBASE_SOUNDMANAGER_H
|
|
|
|
|
2017-05-05 19:21:11 +00:00
|
|
|
#include <memory>
|
2012-08-09 12:33:21 +00:00
|
|
|
#include <string>
|
2015-02-02 23:53:30 +00:00
|
|
|
#include <set>
|
2012-08-09 12:33:21 +00:00
|
|
|
|
|
|
|
#include "../mwworld/ptr.hpp"
|
|
|
|
|
|
|
|
namespace MWWorld
|
|
|
|
{
|
|
|
|
class CellStore;
|
|
|
|
}
|
|
|
|
|
|
|
|
namespace MWSound
|
|
|
|
{
|
|
|
|
class Sound;
|
2015-11-30 15:32:42 +00:00
|
|
|
class Stream;
|
2015-03-06 08:36:42 +00:00
|
|
|
struct Sound_Decoder;
|
2017-05-05 17:26:09 +00:00
|
|
|
typedef std::shared_ptr<Sound_Decoder> DecoderPtr;
|
2012-08-09 12:33:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
namespace MWBase
|
|
|
|
{
|
2017-09-12 04:33:18 +00:00
|
|
|
using Sound = MWSound::Sound;
|
|
|
|
using SoundStream = MWSound::Stream;
|
2012-08-09 12:33:21 +00:00
|
|
|
|
|
|
|
/// \brief Interface for sound manager (implemented in MWSound)
|
|
|
|
class SoundManager
|
|
|
|
{
|
|
|
|
public:
|
2012-12-18 09:35:20 +00:00
|
|
|
/* These must all fit together */
|
2012-08-09 12:33:21 +00:00
|
|
|
enum PlayMode {
|
2015-11-25 07:24:42 +00:00
|
|
|
Play_Normal = 0, /* non-looping, affected by environment */
|
2012-08-09 12:33:21 +00:00
|
|
|
Play_Loop = 1<<0, /* Sound will continually loop until explicitly stopped */
|
|
|
|
Play_NoEnv = 1<<1, /* Do not apply environment effects (eg, underwater filters) */
|
2015-11-25 07:24:42 +00:00
|
|
|
Play_RemoveAtDistance = 1<<2, /* (3D only) If the listener gets further than 2000 units away
|
2014-12-08 22:26:54 +00:00
|
|
|
from the sound source, the sound is removed.
|
|
|
|
This is weird stuff but apparently how vanilla works for sounds
|
|
|
|
played by the PlayLoopSound family of script functions. Perhaps we
|
|
|
|
can make this cut off a more subtle fade later, but have to
|
|
|
|
be careful to not change the overall volume of areas by too much. */
|
2015-11-27 09:02:53 +00:00
|
|
|
Play_NoPlayerLocal = 1<<3, /* (3D only) Don't play the sound local to the listener even if the
|
|
|
|
player is making it. */
|
2014-12-08 22:26:54 +00:00
|
|
|
Play_LoopNoEnv = Play_Loop | Play_NoEnv,
|
|
|
|
Play_LoopRemoveAtDistance = Play_Loop | Play_RemoveAtDistance
|
2012-12-18 09:35:20 +00:00
|
|
|
};
|
|
|
|
enum PlayType {
|
2015-11-27 09:02:53 +00:00
|
|
|
Play_TypeSfx = 1<<4, /* Normal SFX sound */
|
|
|
|
Play_TypeVoice = 1<<5, /* Voice sound */
|
|
|
|
Play_TypeFoot = 1<<6, /* Footstep sound */
|
|
|
|
Play_TypeMusic = 1<<7, /* Music track */
|
|
|
|
Play_TypeMovie = 1<<8, /* Movie audio track */
|
2013-07-19 02:01:13 +00:00
|
|
|
Play_TypeMask = Play_TypeSfx|Play_TypeVoice|Play_TypeFoot|Play_TypeMusic|Play_TypeMovie
|
2012-08-09 12:33:21 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
SoundManager (const SoundManager&);
|
|
|
|
///< not implemented
|
|
|
|
|
|
|
|
SoundManager& operator= (const SoundManager&);
|
|
|
|
///< not implemented
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
SoundManager() {}
|
|
|
|
|
|
|
|
virtual ~SoundManager() {}
|
|
|
|
|
2015-02-02 23:53:30 +00:00
|
|
|
virtual void processChangedSettings(const std::set< std::pair<std::string, std::string> >& settings) = 0;
|
2012-08-09 12:33:21 +00:00
|
|
|
|
|
|
|
virtual void stopMusic() = 0;
|
|
|
|
///< Stops music if it's playing
|
|
|
|
|
|
|
|
virtual void streamMusic(const std::string& filename) = 0;
|
|
|
|
///< Play a soundifle
|
|
|
|
/// \param filename name of a sound file in "Music/" in the data directory.
|
|
|
|
|
|
|
|
virtual void startRandomTitle() = 0;
|
|
|
|
///< Starts a random track from the current playlist
|
|
|
|
|
|
|
|
virtual bool isMusicPlaying() = 0;
|
|
|
|
///< Returns true if music is playing
|
|
|
|
|
|
|
|
virtual void playPlaylist(const std::string &playlist) = 0;
|
|
|
|
///< Start playing music from the selected folder
|
|
|
|
/// \param name of the folder that contains the playlist
|
|
|
|
|
2015-12-18 17:11:30 +00:00
|
|
|
virtual void say(const MWWorld::ConstPtr &reference, const std::string& filename) = 0;
|
2012-08-09 12:33:21 +00:00
|
|
|
///< Make an actor say some text.
|
|
|
|
/// \param filename name of a sound file in "Sound/" in the data directory.
|
|
|
|
|
|
|
|
virtual void say(const std::string& filename) = 0;
|
|
|
|
///< Say some text, without an actor ref
|
|
|
|
/// \param filename name of a sound file in "Sound/" in the data directory.
|
|
|
|
|
2015-12-18 17:11:30 +00:00
|
|
|
virtual bool sayDone(const MWWorld::ConstPtr &reference=MWWorld::ConstPtr()) const = 0;
|
2012-08-09 12:33:21 +00:00
|
|
|
///< Is actor not speaking?
|
|
|
|
|
2015-12-18 17:11:30 +00:00
|
|
|
virtual void stopSay(const MWWorld::ConstPtr &reference=MWWorld::ConstPtr()) = 0;
|
2012-08-09 12:33:21 +00:00
|
|
|
///< Stop an actor speaking
|
|
|
|
|
2015-12-18 17:11:30 +00:00
|
|
|
virtual float getSaySoundLoudness(const MWWorld::ConstPtr& reference) const = 0;
|
2014-07-28 22:26:26 +00:00
|
|
|
///< Check the currently playing say sound for this actor
|
|
|
|
/// and get an average loudness value (scale [0,1]) at the current time position.
|
|
|
|
/// If the actor is not saying anything, returns 0.
|
|
|
|
|
2017-09-12 04:33:18 +00:00
|
|
|
virtual SoundStream *playTrack(const MWSound::DecoderPtr& decoder, PlayType type) = 0;
|
2012-12-13 08:05:57 +00:00
|
|
|
///< Play a 2D audio track, using a custom decoder
|
|
|
|
|
2017-09-12 04:33:18 +00:00
|
|
|
virtual void stopTrack(SoundStream *stream) = 0;
|
2015-11-30 13:42:51 +00:00
|
|
|
///< Stop the given audio track from playing
|
|
|
|
|
2017-09-12 04:33:18 +00:00
|
|
|
virtual double getTrackTimeDelay(SoundStream *stream) = 0;
|
2015-11-30 13:42:51 +00:00
|
|
|
///< Retives the time delay, in seconds, of the audio track (must be a sound
|
|
|
|
/// returned by \ref playTrack). Only intended to be called by the track
|
|
|
|
/// decoder's read method.
|
|
|
|
|
2017-09-12 04:33:18 +00:00
|
|
|
virtual Sound *playSound(const std::string& soundId, float volume, float pitch,
|
|
|
|
PlayType type=Play_TypeSfx, PlayMode mode=Play_Normal,
|
|
|
|
float offset=0) = 0;
|
2012-08-09 12:33:21 +00:00
|
|
|
///< Play a sound, independently of 3D-position
|
2015-11-27 07:40:02 +00:00
|
|
|
///< @param offset Number of seconds into the sound to start playback.
|
2012-08-09 12:33:21 +00:00
|
|
|
|
2017-09-12 04:33:18 +00:00
|
|
|
virtual Sound *playSound3D(const MWWorld::ConstPtr &reference, const std::string& soundId,
|
|
|
|
float volume, float pitch, PlayType type=Play_TypeSfx,
|
|
|
|
PlayMode mode=Play_Normal, float offset=0) = 0;
|
2014-05-16 11:09:23 +00:00
|
|
|
///< Play a 3D sound attached to an MWWorld::Ptr. Will be updated automatically with the Ptr's position, unless Play_NoTrack is specified.
|
2015-11-27 07:40:02 +00:00
|
|
|
///< @param offset Number of seconds into the sound to start playback.
|
2012-08-09 12:33:21 +00:00
|
|
|
|
2017-09-12 04:33:18 +00:00
|
|
|
virtual Sound *playSound3D(const osg::Vec3f& initialPos, const std::string& soundId,
|
|
|
|
float volume, float pitch, PlayType type=Play_TypeSfx,
|
|
|
|
PlayMode mode=Play_Normal, float offset=0) = 0;
|
2015-11-25 07:24:42 +00:00
|
|
|
///< Play a 3D sound at \a initialPos. If the sound should be moving, it must be updated using Sound::setPosition.
|
2014-05-16 11:09:23 +00:00
|
|
|
|
2017-09-12 04:33:18 +00:00
|
|
|
virtual void stopSound(Sound *sound) = 0;
|
2015-11-30 13:42:51 +00:00
|
|
|
///< Stop the given sound from playing
|
|
|
|
|
2015-12-18 17:11:30 +00:00
|
|
|
virtual void stopSound3D(const MWWorld::ConstPtr &reference, const std::string& soundId) = 0;
|
2012-08-09 12:33:21 +00:00
|
|
|
///< Stop the given object from playing the given sound,
|
|
|
|
|
2015-12-18 17:11:30 +00:00
|
|
|
virtual void stopSound3D(const MWWorld::ConstPtr &reference) = 0;
|
2012-08-09 12:33:21 +00:00
|
|
|
///< Stop the given object from playing all sounds.
|
|
|
|
|
|
|
|
virtual void stopSound(const MWWorld::CellStore *cell) = 0;
|
|
|
|
///< Stop all sounds for the given cell.
|
|
|
|
|
|
|
|
virtual void stopSound(const std::string& soundId) = 0;
|
|
|
|
///< Stop a non-3d looping sound
|
|
|
|
|
2015-12-18 17:11:30 +00:00
|
|
|
virtual void fadeOutSound3D(const MWWorld::ConstPtr &reference, const std::string& soundId, float duration) = 0;
|
2013-07-26 16:43:06 +00:00
|
|
|
///< Fade out given sound (that is already playing) of given object
|
|
|
|
///< @param reference Reference to object, whose sound is faded out
|
|
|
|
///< @param soundId ID of the sound to fade out.
|
|
|
|
///< @param duration Time until volume reaches 0.
|
|
|
|
|
2015-12-18 17:11:30 +00:00
|
|
|
virtual bool getSoundPlaying(const MWWorld::ConstPtr &reference, const std::string& soundId) const = 0;
|
2012-08-09 12:33:21 +00:00
|
|
|
///< Is the given sound currently playing on the given object?
|
2013-08-08 17:16:05 +00:00
|
|
|
/// If you want to check if sound played with playSound is playing, use empty Ptr
|
2012-08-09 12:33:21 +00:00
|
|
|
|
2012-12-18 12:19:35 +00:00
|
|
|
virtual void pauseSounds(int types=Play_TypeMask) = 0;
|
2012-12-12 10:33:12 +00:00
|
|
|
///< Pauses all currently playing sounds, including music.
|
|
|
|
|
2012-12-18 12:19:35 +00:00
|
|
|
virtual void resumeSounds(int types=Play_TypeMask) = 0;
|
2012-12-12 10:33:12 +00:00
|
|
|
///< Resumes all previously paused sounds.
|
|
|
|
|
2012-08-09 12:33:21 +00:00
|
|
|
virtual void update(float duration) = 0;
|
2012-08-09 14:12:10 +00:00
|
|
|
|
2015-12-03 14:16:20 +00:00
|
|
|
virtual void setListenerPosDir(const osg::Vec3f &pos, const osg::Vec3f &dir, const osg::Vec3f &up, bool underwater) = 0;
|
2014-01-20 11:05:13 +00:00
|
|
|
|
2015-12-18 17:11:30 +00:00
|
|
|
virtual void updatePtr(const MWWorld::ConstPtr& old, const MWWorld::ConstPtr& updated) = 0;
|
2014-02-01 17:16:32 +00:00
|
|
|
|
2014-01-21 13:13:13 +00:00
|
|
|
virtual void clear() = 0;
|
2012-08-09 12:33:21 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|