2010-07-03 13:04:00 +00:00
|
|
|
#ifndef GAME_SOUND_SOUNDMANAGER_H
|
|
|
|
#define GAME_SOUND_SOUNDMANAGER_H
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
|
2012-03-07 15:46:51 +00:00
|
|
|
#include <components/files/filelibrary.hpp>
|
2010-07-03 15:59:30 +00:00
|
|
|
|
2012-03-05 23:21:00 +00:00
|
|
|
#include "../mwworld/ptr.hpp"
|
2011-10-09 07:28:36 +00:00
|
|
|
|
|
|
|
|
2010-08-12 14:13:54 +00:00
|
|
|
namespace Ogre
|
|
|
|
{
|
|
|
|
class Root;
|
|
|
|
class Camera;
|
|
|
|
}
|
|
|
|
|
2011-10-09 07:28:36 +00:00
|
|
|
namespace MWWorld
|
|
|
|
{
|
|
|
|
struct Environment;
|
|
|
|
}
|
|
|
|
|
2010-07-03 13:04:00 +00:00
|
|
|
namespace MWSound
|
|
|
|
{
|
2012-03-17 05:12:17 +00:00
|
|
|
class Sound_Output;
|
|
|
|
|
2010-07-03 13:04:00 +00:00
|
|
|
class SoundManager
|
|
|
|
{
|
2012-03-17 05:12:17 +00:00
|
|
|
// This is used for case insensitive and slash-type agnostic file
|
|
|
|
// finding. It takes DOS paths (any case, \\ slashes or / slashes)
|
|
|
|
// relative to the sound dir, and translates them into full paths
|
|
|
|
// of existing files in the filesystem, if they exist.
|
|
|
|
bool mFSStrict;
|
|
|
|
|
|
|
|
MWWorld::Environment& mEnvironment;
|
|
|
|
|
|
|
|
std::auto_ptr<Sound_Output> Output;
|
|
|
|
|
|
|
|
void streamMusicFull(const std::string& filename);
|
|
|
|
///< Play a soundifle
|
|
|
|
/// \param absolute filename
|
|
|
|
|
|
|
|
// A list of all sound files used to lookup paths
|
|
|
|
Files::PathContainer mSoundFiles;
|
|
|
|
|
|
|
|
// A library of all Music file paths stored by the folder they are contained in
|
|
|
|
Files::FileLibrary mMusicLibrary;
|
|
|
|
|
|
|
|
// Points to the current playlist of music files stored in the music library
|
|
|
|
const Files::PathContainer* mCurrentPlaylist;
|
|
|
|
|
|
|
|
std::string lookup(const std::string &soundId,
|
|
|
|
float &volume, float &min, float &max);
|
|
|
|
void add(const std::string &file,
|
|
|
|
MWWorld::Ptr ptr, const std::string &id,
|
|
|
|
float volume, float pitch, float min, float max,
|
|
|
|
bool loop, bool untracked=false);
|
|
|
|
void remove(MWWorld::Ptr ptr, const std::string &id = "");
|
|
|
|
bool isPlaying(MWWorld::Ptr ptr, const std::string &id) const;
|
|
|
|
void removeCell(const MWWorld::Ptr::CellStore *cell);
|
|
|
|
void updatePositions(MWWorld::Ptr ptr);
|
|
|
|
|
|
|
|
public:
|
|
|
|
SoundManager(Ogre::Root*, Ogre::Camera*,
|
|
|
|
const Files::PathContainer& dataDir, bool useSound, bool fsstrict,
|
|
|
|
MWWorld::Environment& environment);
|
|
|
|
~SoundManager();
|
2012-03-07 00:20:15 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
void stopMusic();
|
|
|
|
///< Stops music if it's playing
|
2012-03-07 15:46:51 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
void streamMusic(const std::string& filename);
|
|
|
|
///< Play a soundifle
|
|
|
|
/// \param filename name of a sound file in "Music/" in the data directory.
|
2012-03-07 00:20:15 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
void startRandomTitle();
|
|
|
|
///< Starts a random track from the current playlist
|
2012-03-05 23:21:00 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
bool isMusicPlaying();
|
|
|
|
///< Returns true if music is playing
|
2011-06-12 00:01:21 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
bool setPlaylist(std::string playlist="");
|
|
|
|
///< Set the playlist to an existing folder
|
|
|
|
/// \param name of the folder that contains the playlist
|
|
|
|
/// if none is set then it is set to an empty playlist
|
|
|
|
/// \return Return true if the previous playlist was the same
|
2010-11-12 00:47:26 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
void playPlaylist(std::string playlist="");
|
|
|
|
///< Start playing music from the selected folder
|
|
|
|
/// \param name of the folder that contains the playlist
|
|
|
|
/// if none is set then it plays from the current playlist
|
2012-03-09 01:56:29 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
void say(MWWorld::Ptr reference, const std::string& filename);
|
|
|
|
///< Make an actor say some text.
|
|
|
|
/// \param filename name of a sound file in "Sound/Vo/" in the data directory.
|
2011-06-15 20:33:31 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
bool sayDone(MWWorld::Ptr reference) const;
|
|
|
|
///< Is actor not speaking?
|
2011-06-15 20:33:31 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
void playSound(const std::string& soundId, float volume, float pitch, bool loop=false);
|
|
|
|
///< Play a sound, independently of 3D-position
|
2010-10-31 16:23:03 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
void playSound3D(MWWorld::Ptr reference, const std::string& soundId,
|
|
|
|
float volume, float pitch, bool loop,
|
|
|
|
bool untracked=false);
|
|
|
|
///< Play a sound from an object
|
2012-03-07 15:46:51 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
void stopSound3D(MWWorld::Ptr reference, const std::string& soundId="");
|
|
|
|
///< Stop the given object from playing the given sound, If no soundId is given,
|
|
|
|
/// all sounds for this reference will stop.
|
2012-03-07 15:46:51 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
void stopSound(MWWorld::Ptr::CellStore *cell);
|
|
|
|
///< Stop all sounds for the given cell.
|
2010-08-14 05:54:51 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
void stopSound(const std::string& soundId);
|
|
|
|
///< Stop a non-3d looping sound
|
2010-07-03 13:04:00 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
bool getSoundPlaying(MWWorld::Ptr reference, const std::string& soundId) const;
|
|
|
|
///< Is the given sound currently playing on the given object?
|
2010-08-14 05:54:51 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
void updateObject(MWWorld::Ptr reference);
|
|
|
|
///< Update the position of all sounds connected to the given object.
|
2010-07-03 13:04:00 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
void update(float duration);
|
|
|
|
};
|
2010-07-03 13:04:00 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
class Sound_Output
|
|
|
|
{
|
|
|
|
SoundManager &mgr;
|
2010-08-14 07:26:00 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
virtual bool Initialize(const std::string &devname="") = 0;
|
|
|
|
virtual void Deinitialize() = 0;
|
2012-03-09 16:10:23 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
Sound_Output(SoundManager &mgr) : mgr(mgr) { }
|
2010-08-14 12:28:17 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
public:
|
|
|
|
virtual ~Sound_Output() { }
|
2011-10-09 07:28:36 +00:00
|
|
|
|
2012-03-17 05:12:17 +00:00
|
|
|
friend class OpenAL_Output;
|
|
|
|
friend class SoundManager;
|
2010-07-03 13:04:00 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|