184 lines
4.9 KiB
C++
184 lines
4.9 KiB
C++
// NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/>
|
|
// Copyright (C) 2010 Winch Gate Property Limited
|
|
//
|
|
// This program is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU Affero General Public License as
|
|
// published by the Free Software Foundation, either version 3 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 Affero General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Affero General Public License
|
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
#ifndef NL_PS_SOUND_H
|
|
#define NL_PS_SOUND_H
|
|
|
|
#include "nel/misc/types_nl.h"
|
|
#include "nel/misc/string_mapper.h"
|
|
#include "nel/3d/ps_located.h"
|
|
#include "nel/3d/ps_attrib.h"
|
|
#include "nel/misc/sheet_id.h"
|
|
|
|
|
|
|
|
namespace NL3D
|
|
{
|
|
|
|
|
|
template <class T>
|
|
class CPSAttribMaker;
|
|
struct UPSSoundInstance;
|
|
|
|
/**
|
|
* This is a goup of sound instances sound instance. sounds are produced during the motion pass
|
|
* \author Nicolas Vizerie
|
|
* \author Nevrax France
|
|
* \date 2001
|
|
*/
|
|
class CPSSound : public CPSLocatedBindable
|
|
{
|
|
public:
|
|
NLMISC_DECLARE_CLASS(CPSSound);
|
|
///\name object
|
|
//@{
|
|
/// ctor
|
|
CPSSound();
|
|
/// dtor
|
|
~CPSSound();
|
|
/// serialisation. Derivers must override this, and call their parent version
|
|
virtual void serial(NLMISC::IStream &f) throw(NLMISC::EStream);
|
|
//@}
|
|
|
|
/// return this bindable type
|
|
uint32 getType(void) const;
|
|
/// return priority
|
|
virtual uint32 getPriority(void) const { return 500; }
|
|
|
|
/**
|
|
* process one pass for the sound. This is usually done during the motion pass
|
|
*/
|
|
virtual void step(TPSProcessPass pass);
|
|
|
|
/// set the name of the sound
|
|
void setSoundName(const NLMISC::CSheetId &soundName)
|
|
{
|
|
_SoundName = soundName;
|
|
}
|
|
|
|
/// get the name of the sound
|
|
const NLMISC::CSheetId &getSoundName(void) const
|
|
{
|
|
return _SoundName;
|
|
}
|
|
|
|
/// set a constant gain. Any previous gain scheme is discarded.
|
|
void setGain(float gain);
|
|
|
|
/// get the current gain. meningful only if a scheme is not used
|
|
float getGain(void) const
|
|
{
|
|
return _Gain;
|
|
}
|
|
|
|
/** Set a gain scheme. It must have been allocated by new, and is then owned by this object
|
|
*/
|
|
void setGainScheme(CPSAttribMaker<float> *gain);
|
|
|
|
/// get the current gain scheme
|
|
CPSAttribMaker<float> *getGainScheme(void)
|
|
{
|
|
return _GainScheme;
|
|
}
|
|
|
|
/// get the current gain scheme (const version)
|
|
const CPSAttribMaker<float> *getGainScheme(void) const
|
|
{
|
|
return _GainScheme;
|
|
}
|
|
|
|
/// set a constant pitch. Any previous pitch scheme is discarded.
|
|
void setPitch(float pitch);
|
|
|
|
/// get the current pitch. meaningful only if a scheme is not used
|
|
float getPitch(void) const
|
|
{
|
|
return _Pitch;
|
|
}
|
|
|
|
/** Set a pitch scheme. It must have been allocated by new, and is then owned by this object
|
|
*/
|
|
void setPitchScheme(CPSAttribMaker<float> *pitch);
|
|
|
|
/// get the current pitch scheme
|
|
CPSAttribMaker<float> *getPitchScheme(void)
|
|
{
|
|
return _PitchScheme;
|
|
}
|
|
|
|
/// get the current pitch scheme (const version)
|
|
const CPSAttribMaker<float> *getPitchScheme(void) const
|
|
{
|
|
return _PitchScheme;
|
|
}
|
|
|
|
/// set a percent of sound emission. If set to 1, it try to emit all sounds
|
|
void setEmissionPercent(float percent) { _EmissionPercent = percent; }
|
|
|
|
|
|
/// get the percent of sound emission.
|
|
float getEmissionPercent(void) const { return _EmissionPercent; }
|
|
|
|
/// tells whether sound emissions are spawned or not
|
|
void setSpawn(bool enabled = true) { _SpawnSounds = enabled; }
|
|
|
|
/// test whether sound spawning is enabled
|
|
bool getSpawn(void) const { return _SpawnSounds; }
|
|
|
|
///set mute on/off. The default is off. WARNING : It is not saved by this object
|
|
void setMute(bool enabled = true) { _Mute = enabled; }
|
|
|
|
/// test whether mute has been activated
|
|
bool getMute(void) const { return _Mute; }
|
|
|
|
|
|
void stopSound();
|
|
|
|
void reactivateSound();
|
|
|
|
/** force the sound to use original pitch that has been entered in the .sound sheet
|
|
* This remove any existing pitchScheme
|
|
*/
|
|
void setUseOriginalPitchFlag(bool useOriginalPitch);
|
|
bool getUseOriginalPitchFlag() const { return _UseOriginalPitch; }
|
|
|
|
protected:
|
|
virtual void newElement(const CPSEmitterInfo &info);
|
|
virtual void deleteElement(uint32 index);
|
|
virtual void resize(uint32 size);
|
|
void removeAllSources();
|
|
|
|
CPSAttrib<UPSSoundInstance *> _Sounds;
|
|
NLMISC::CSheetId _SoundName;
|
|
float _Gain;
|
|
CPSAttribMaker<float> * _GainScheme;
|
|
float _Pitch;
|
|
CPSAttribMaker<float> * _PitchScheme;
|
|
float _EmissionPercent;
|
|
bool _SpawnSounds;
|
|
bool _Mute;
|
|
bool _SoundStopped;
|
|
bool _SoundReactivated;
|
|
bool _UseOriginalPitch;
|
|
};
|
|
|
|
|
|
} // NL3D
|
|
|
|
|
|
#endif // NL_PS_SOUND_H
|
|
|
|
/* End of ps_sound.h */
|