aboutsummaryrefslogtreecommitdiff
path: root/scene/audio/sample_player.cpp
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--scene/audio/sample_player.cpp581
1 files changed, 269 insertions, 312 deletions
diff --git a/scene/audio/sample_player.cpp b/scene/audio/sample_player.cpp
index 64992081f..dfccc5c7c 100644
--- a/scene/audio/sample_player.cpp
+++ b/scene/audio/sample_player.cpp
@@ -30,107 +30,103 @@
#include "servers/audio_server.h"
+bool SamplePlayer::_set(const StringName &p_name, const Variant &p_value) {
-bool SamplePlayer::_set(const StringName& p_name, const Variant& p_value) {
+ String name = p_name;
- String name=p_name;
-
- if (name=="play/play") {
+ if (name == "play/play") {
if (library.is_valid()) {
- String what=p_value;
- if (what=="")
+ String what = p_value;
+ if (what == "")
stop_all();
else
play(what);
- played_back=what;
+ played_back = what;
}
- } else if (name=="config/samples")
+ } else if (name == "config/samples")
set_sample_library(p_value);
- else if (name=="config/polyphony")
+ else if (name == "config/polyphony")
set_polyphony(p_value);
else if (name.begins_with("default/")) {
- String what=name.right(8);
+ String what = name.right(8);
- if (what=="volume_db")
+ if (what == "volume_db")
set_default_volume_db(p_value);
- else if (what=="pitch_scale")
+ else if (what == "pitch_scale")
set_default_pitch_scale(p_value);
- else if (what=="pan")
- _default.pan=p_value;
- else if (what=="depth")
- _default.depth=p_value;
- else if (what=="height")
- _default.height=p_value;
- else if (what=="filter/type")
- _default.filter_type=FilterType(p_value.operator int());
- else if (what=="filter/cutoff")
- _default.filter_cutoff=p_value;
- else if (what=="filter/resonance")
- _default.filter_resonance=p_value;
- else if (what=="filter/gain")
- _default.filter_gain=p_value;
- else if (what=="reverb_room")
- _default.reverb_room=ReverbRoomType(p_value.operator int());
- else if (what=="reverb_send")
- _default.reverb_send=p_value;
- else if (what=="chorus_send")
- _default.chorus_send=p_value;
+ else if (what == "pan")
+ _default.pan = p_value;
+ else if (what == "depth")
+ _default.depth = p_value;
+ else if (what == "height")
+ _default.height = p_value;
+ else if (what == "filter/type")
+ _default.filter_type = FilterType(p_value.operator int());
+ else if (what == "filter/cutoff")
+ _default.filter_cutoff = p_value;
+ else if (what == "filter/resonance")
+ _default.filter_resonance = p_value;
+ else if (what == "filter/gain")
+ _default.filter_gain = p_value;
+ else if (what == "reverb_room")
+ _default.reverb_room = ReverbRoomType(p_value.operator int());
+ else if (what == "reverb_send")
+ _default.reverb_send = p_value;
+ else if (what == "chorus_send")
+ _default.chorus_send = p_value;
else
return false;
-
} else
return false;
return true;
}
-bool SamplePlayer::_get(const StringName& p_name,Variant &r_ret) const {
-
+bool SamplePlayer::_get(const StringName &p_name, Variant &r_ret) const {
- String name=p_name;
+ String name = p_name;
- if (name=="play/play") {
- r_ret=played_back;
- } else if (name=="config/polyphony") {
- r_ret= get_polyphony();
- } else if (name=="config/samples") {
+ if (name == "play/play") {
+ r_ret = played_back;
+ } else if (name == "config/polyphony") {
+ r_ret = get_polyphony();
+ } else if (name == "config/samples") {
- r_ret= get_sample_library();
+ r_ret = get_sample_library();
} else if (name.begins_with("default/")) {
- String what=name.right(8);
-
- if (what=="volume_db")
- r_ret= get_default_volume_db();
- else if (what=="pitch_scale")
- r_ret= get_default_pitch_scale();
- else if (what=="pan")
- r_ret= _default.pan;
- else if (what=="depth")
- r_ret= _default.depth;
- else if (what=="height")
- r_ret= _default.height;
- else if (what=="filter/type")
- r_ret= _default.filter_type;
- else if (what=="filter/cutoff")
- r_ret= _default.filter_cutoff;
- else if (what=="filter/resonance")
- r_ret= _default.filter_resonance;
- else if (what=="filter/gain")
- r_ret= _default.filter_gain;
- else if (what=="reverb_room")
- r_ret= _default.reverb_room;
- else if (what=="reverb_send")
- r_ret= _default.reverb_send;
- else if (what=="chorus_send")
- r_ret= _default.chorus_send;
- else
- return false;
+ String what = name.right(8);
+ if (what == "volume_db")
+ r_ret = get_default_volume_db();
+ else if (what == "pitch_scale")
+ r_ret = get_default_pitch_scale();
+ else if (what == "pan")
+ r_ret = _default.pan;
+ else if (what == "depth")
+ r_ret = _default.depth;
+ else if (what == "height")
+ r_ret = _default.height;
+ else if (what == "filter/type")
+ r_ret = _default.filter_type;
+ else if (what == "filter/cutoff")
+ r_ret = _default.filter_cutoff;
+ else if (what == "filter/resonance")
+ r_ret = _default.filter_resonance;
+ else if (what == "filter/gain")
+ r_ret = _default.filter_gain;
+ else if (what == "reverb_room")
+ r_ret = _default.reverb_room;
+ else if (what == "reverb_send")
+ r_ret = _default.reverb_send;
+ else if (what == "chorus_send")
+ r_ret = _default.chorus_send;
+ else
+ return false;
} else
return false;
@@ -140,72 +136,66 @@ bool SamplePlayer::_get(const StringName& p_name,Variant &r_ret) const {
void SamplePlayer::_get_property_list(List<PropertyInfo> *p_list) const {
- String en="";
+ String en = "";
if (library.is_valid()) {
List<StringName> samples;
- Ref<SampleLibrary> ncl=library;
+ Ref<SampleLibrary> ncl = library;
ncl->get_sample_list(&samples);
- for (List<StringName>::Element *E=samples.front();E;E=E->next()) {
+ for (List<StringName>::Element *E = samples.front(); E; E = E->next()) {
- en+=",";
- en+=E->get();
+ en += ",";
+ en += E->get();
}
}
- p_list->push_back( PropertyInfo( Variant::STRING, "play/play", PROPERTY_HINT_ENUM, en,PROPERTY_USAGE_EDITOR|PROPERTY_USAGE_ANIMATE_AS_TRIGGER));
- p_list->push_back( PropertyInfo( Variant::INT, "config/polyphony", PROPERTY_HINT_RANGE, "1,256,1"));
- p_list->push_back( PropertyInfo( Variant::OBJECT, "config/samples", PROPERTY_HINT_RESOURCE_TYPE, "SampleLibrary"));
- p_list->push_back( PropertyInfo( Variant::REAL, "default/volume_db", PROPERTY_HINT_RANGE, "-80,24,0.01"));
- p_list->push_back( PropertyInfo( Variant::REAL, "default/pitch_scale", PROPERTY_HINT_RANGE, "0.01,48,0.01"));
- p_list->push_back( PropertyInfo( Variant::REAL, "default/pan", PROPERTY_HINT_RANGE, "-1,1,0.01"));
- p_list->push_back( PropertyInfo( Variant::REAL, "default/depth", PROPERTY_HINT_RANGE, "-1,1,0.01"));
- p_list->push_back( PropertyInfo( Variant::REAL, "default/height", PROPERTY_HINT_RANGE, "-1,1,0.01"));
- p_list->push_back( PropertyInfo( Variant::INT, "default/filter/type", PROPERTY_HINT_ENUM, "Disabled,Lowpass,Bandpass,Highpass,Notch,Peak,BandLimit,LowShelf,HighShelf"));
- p_list->push_back( PropertyInfo( Variant::REAL, "default/filter/cutoff", PROPERTY_HINT_RANGE, "20,16384.0,0.01"));
- p_list->push_back( PropertyInfo( Variant::REAL, "default/filter/resonance", PROPERTY_HINT_RANGE, "0,4,0.01"));
- p_list->push_back( PropertyInfo( Variant::REAL, "default/filter/gain", PROPERTY_HINT_RANGE, "0,2,0.01"));
- p_list->push_back( PropertyInfo( Variant::INT, "default/reverb_room", PROPERTY_HINT_ENUM, "Small,Medium,Large,Hall"));
- p_list->push_back( PropertyInfo( Variant::REAL, "default/reverb_send", PROPERTY_HINT_RANGE, "0,1,0.01"));
- p_list->push_back( PropertyInfo( Variant::REAL, "default/chorus_send", PROPERTY_HINT_RANGE, "0,1,0.01"));
-
-
+ p_list->push_back(PropertyInfo(Variant::STRING, "play/play", PROPERTY_HINT_ENUM, en, PROPERTY_USAGE_EDITOR | PROPERTY_USAGE_ANIMATE_AS_TRIGGER));
+ p_list->push_back(PropertyInfo(Variant::INT, "config/polyphony", PROPERTY_HINT_RANGE, "1,256,1"));
+ p_list->push_back(PropertyInfo(Variant::OBJECT, "config/samples", PROPERTY_HINT_RESOURCE_TYPE, "SampleLibrary"));
+ p_list->push_back(PropertyInfo(Variant::REAL, "default/volume_db", PROPERTY_HINT_RANGE, "-80,24,0.01"));
+ p_list->push_back(PropertyInfo(Variant::REAL, "default/pitch_scale", PROPERTY_HINT_RANGE, "0.01,48,0.01"));
+ p_list->push_back(PropertyInfo(Variant::REAL, "default/pan", PROPERTY_HINT_RANGE, "-1,1,0.01"));
+ p_list->push_back(PropertyInfo(Variant::REAL, "default/depth", PROPERTY_HINT_RANGE, "-1,1,0.01"));
+ p_list->push_back(PropertyInfo(Variant::REAL, "default/height", PROPERTY_HINT_RANGE, "-1,1,0.01"));
+ p_list->push_back(PropertyInfo(Variant::INT, "default/filter/type", PROPERTY_HINT_ENUM, "Disabled,Lowpass,Bandpass,Highpass,Notch,Peak,BandLimit,LowShelf,HighShelf"));
+ p_list->push_back(PropertyInfo(Variant::REAL, "default/filter/cutoff", PROPERTY_HINT_RANGE, "20,16384.0,0.01"));
+ p_list->push_back(PropertyInfo(Variant::REAL, "default/filter/resonance", PROPERTY_HINT_RANGE, "0,4,0.01"));
+ p_list->push_back(PropertyInfo(Variant::REAL, "default/filter/gain", PROPERTY_HINT_RANGE, "0,2,0.01"));
+ p_list->push_back(PropertyInfo(Variant::INT, "default/reverb_room", PROPERTY_HINT_ENUM, "Small,Medium,Large,Hall"));
+ p_list->push_back(PropertyInfo(Variant::REAL, "default/reverb_send", PROPERTY_HINT_RANGE, "0,1,0.01"));
+ p_list->push_back(PropertyInfo(Variant::REAL, "default/chorus_send", PROPERTY_HINT_RANGE, "0,1,0.01"));
}
-
SamplePlayer::Voice::Voice() {
- voice=AudioServer::get_singleton()->voice_create();
+ voice = AudioServer::get_singleton()->voice_create();
clear();
}
-
void SamplePlayer::Voice::clear() {
- check=0;
-
- mix_rate=44100;
- volume=1;
- pan=0;
- pan_depth=0;
- pan_height=0;
- filter_type=FILTER_NONE;
- filter_cutoff=0;
- filter_resonance=0;
- chorus_send=0;
- reverb_room=REVERB_HALL;
- reverb_send=0;
- active=false;
+ check = 0;
+ mix_rate = 44100;
+ volume = 1;
+ pan = 0;
+ pan_depth = 0;
+ pan_height = 0;
+ filter_type = FILTER_NONE;
+ filter_cutoff = 0;
+ filter_resonance = 0;
+ chorus_send = 0;
+ reverb_room = REVERB_HALL;
+ reverb_send = 0;
+ active = false;
}
SamplePlayer::Voice::~Voice() {
AudioServer::get_singleton()->free(voice);
}
-
void SamplePlayer::set_polyphony(int p_voice_count) {
- ERR_FAIL_COND( p_voice_count <1 || p_voice_count >0xFFFE );
+ ERR_FAIL_COND(p_voice_count < 1 || p_voice_count > 0xFFFE);
voices.resize(p_voice_count);
}
@@ -215,11 +205,11 @@ int SamplePlayer::get_polyphony() const {
return voices.size();
}
-SamplePlayer::VoiceID SamplePlayer::play(const String& p_name,bool unique) {
+SamplePlayer::VoiceID SamplePlayer::play(const String &p_name, bool unique) {
if (library.is_null())
return INVALID_VOICE_ID;
- ERR_FAIL_COND_V( !library->has_sample(p_name), INVALID_VOICE_ID );
+ ERR_FAIL_COND_V(!library->has_sample(p_name), INVALID_VOICE_ID);
Ref<Sample> sample = library->get_sample(p_name);
float vol_change = library->sample_get_volume_db(p_name);
@@ -228,56 +218,53 @@ SamplePlayer::VoiceID SamplePlayer::play(const String& p_name,bool unique) {
last_check++;
last_id = (last_id + 1) % voices.size();
- Voice&v = voices[last_id];
+ Voice &v = voices[last_id];
v.clear();
+ v.mix_rate = sample->get_mix_rate() * (_default.pitch_scale * pitch_change);
+ v.sample_mix_rate = sample->get_mix_rate();
+ v.check = last_check;
+ v.volume = Math::db2linear(_default.volume_db + vol_change);
+ v.pan = _default.pan;
+ v.pan_depth = _default.depth;
+ v.pan_height = _default.height;
+ v.filter_type = _default.filter_type;
+ v.filter_cutoff = _default.filter_cutoff;
+ v.filter_resonance = _default.filter_resonance;
+ v.filter_gain = _default.filter_gain;
+ v.chorus_send = _default.chorus_send;
+ v.reverb_room = _default.reverb_room;
+ v.reverb_send = _default.reverb_send;
- v.mix_rate=sample->get_mix_rate()*(_default.pitch_scale*pitch_change);
- v.sample_mix_rate=sample->get_mix_rate();
- v.check=last_check;
- v.volume=Math::db2linear(_default.volume_db+vol_change);
- v.pan=_default.pan;
- v.pan_depth=_default.depth;
- v.pan_height=_default.height;
- v.filter_type=_default.filter_type;
- v.filter_cutoff=_default.filter_cutoff;
- v.filter_resonance=_default.filter_resonance;
- v.filter_gain=_default.filter_gain;
- v.chorus_send=_default.chorus_send;
- v.reverb_room=_default.reverb_room;
- v.reverb_send=_default.reverb_send;
-
- AudioServer::get_singleton()->voice_play(v.voice,sample->get_rid());
- AudioServer::get_singleton()->voice_set_mix_rate(v.voice,v.mix_rate);
- AudioServer::get_singleton()->voice_set_volume(v.voice,v.volume);
- AudioServer::get_singleton()->voice_set_pan(v.voice,v.pan,v.pan_depth,v.pan_height);
- AudioServer::get_singleton()->voice_set_filter(v.voice,(AudioServer::FilterType)v.filter_type,v.filter_cutoff,v.filter_resonance,v.filter_gain);
- AudioServer::get_singleton()->voice_set_chorus(v.voice,v.chorus_send);
- AudioServer::get_singleton()->voice_set_reverb(v.voice,(AudioServer::ReverbRoomType)v.reverb_room,v.reverb_send);
+ AudioServer::get_singleton()->voice_play(v.voice, sample->get_rid());
+ AudioServer::get_singleton()->voice_set_mix_rate(v.voice, v.mix_rate);
+ AudioServer::get_singleton()->voice_set_volume(v.voice, v.volume);
+ AudioServer::get_singleton()->voice_set_pan(v.voice, v.pan, v.pan_depth, v.pan_height);
+ AudioServer::get_singleton()->voice_set_filter(v.voice, (AudioServer::FilterType)v.filter_type, v.filter_cutoff, v.filter_resonance, v.filter_gain);
+ AudioServer::get_singleton()->voice_set_chorus(v.voice, v.chorus_send);
+ AudioServer::get_singleton()->voice_set_reverb(v.voice, (AudioServer::ReverbRoomType)v.reverb_room, v.reverb_send);
- v.active=true;
+ v.active = true;
if (unique) {
- for(int i=0;i<voices.size();i++) {
+ for (int i = 0; i < voices.size(); i++) {
- if (!voices[i].active || uint32_t(i)==last_id)
+ if (!voices[i].active || uint32_t(i) == last_id)
continue;
AudioServer::get_singleton()->voice_stop(voices[i].voice);
voices[i].clear();
}
-
}
- return last_id | (last_check<<16);
+ return last_id | (last_check << 16);
}
void SamplePlayer::stop_all() {
-
- for(int i=0;i<voices.size();i++) {
+ for (int i = 0; i < voices.size(); i++) {
if (!voices[i].active)
continue;
@@ -285,15 +272,14 @@ void SamplePlayer::stop_all() {
AudioServer::get_singleton()->voice_stop(voices[i].voice);
voices[i].clear();
}
-
}
-#define _GET_VOICE\
- uint32_t voice=p_voice&0xFFFF;\
- ERR_FAIL_COND(voice >= (uint32_t)voices.size());\
- Voice &v=voices[voice];\
- if (v.check!=uint32_t(p_voice>>16))\
- return;\
+#define _GET_VOICE \
+ uint32_t voice = p_voice & 0xFFFF; \
+ ERR_FAIL_COND(voice >= (uint32_t)voices.size()); \
+ Voice &v = voices[voice]; \
+ if (v.check != uint32_t(p_voice >> 16)) \
+ return; \
ERR_FAIL_COND(!v.active);
void SamplePlayer::stop(VoiceID p_voice) {
@@ -301,92 +287,81 @@ void SamplePlayer::stop(VoiceID p_voice) {
_GET_VOICE
AudioServer::get_singleton()->voice_stop(v.voice);
- v.active=false;
-
+ v.active = false;
}
void SamplePlayer::set_mix_rate(VoiceID p_voice, int p_mix_rate) {
_GET_VOICE
- v.mix_rate=p_mix_rate;
- AudioServer::get_singleton()->voice_set_mix_rate(v.voice,v.mix_rate);
-
+ v.mix_rate = p_mix_rate;
+ AudioServer::get_singleton()->voice_set_mix_rate(v.voice, v.mix_rate);
}
void SamplePlayer::set_pitch_scale(VoiceID p_voice, float p_pitch_scale) {
_GET_VOICE
- v.mix_rate=v.sample_mix_rate*p_pitch_scale;
- AudioServer::get_singleton()->voice_set_mix_rate(v.voice,v.mix_rate);
-
+ v.mix_rate = v.sample_mix_rate * p_pitch_scale;
+ AudioServer::get_singleton()->voice_set_mix_rate(v.voice, v.mix_rate);
}
void SamplePlayer::set_volume(VoiceID p_voice, float p_volume) {
-
_GET_VOICE
- v.volume=p_volume;
- AudioServer::get_singleton()->voice_set_volume(v.voice,v.volume);
-
+ v.volume = p_volume;
+ AudioServer::get_singleton()->voice_set_volume(v.voice, v.volume);
}
void SamplePlayer::set_volume_db(VoiceID p_voice, float p_db) {
//@TODO handle 0 volume as -80db or something
_GET_VOICE
- v.volume=Math::db2linear(p_db);
- AudioServer::get_singleton()->voice_set_volume(v.voice,v.volume);
-
+ v.volume = Math::db2linear(p_db);
+ AudioServer::get_singleton()->voice_set_volume(v.voice, v.volume);
}
-void SamplePlayer::set_pan(VoiceID p_voice, float p_pan,float p_pan_depth,float p_pan_height) {
+void SamplePlayer::set_pan(VoiceID p_voice, float p_pan, float p_pan_depth, float p_pan_height) {
_GET_VOICE
- v.pan=p_pan;
- v.pan_depth=p_pan_depth;
- v.pan_height=p_pan_height;
-
- AudioServer::get_singleton()->voice_set_pan(v.voice,v.pan,v.pan_depth,v.pan_height);
+ v.pan = p_pan;
+ v.pan_depth = p_pan_depth;
+ v.pan_height = p_pan_height;
+ AudioServer::get_singleton()->voice_set_pan(v.voice, v.pan, v.pan_depth, v.pan_height);
}
-void SamplePlayer::set_filter(VoiceID p_voice,FilterType p_filter,float p_cutoff,float p_resonance,float p_gain) {
+void SamplePlayer::set_filter(VoiceID p_voice, FilterType p_filter, float p_cutoff, float p_resonance, float p_gain) {
_GET_VOICE
- v.filter_type=p_filter;
- v.filter_cutoff=p_cutoff;
- v.filter_resonance=p_resonance;
- v.filter_gain=p_gain;
-
- AudioServer::get_singleton()->voice_set_filter(v.voice,(AudioServer::FilterType)p_filter,p_cutoff,p_resonance);
+ v.filter_type = p_filter;
+ v.filter_cutoff = p_cutoff;
+ v.filter_resonance = p_resonance;
+ v.filter_gain = p_gain;
+ AudioServer::get_singleton()->voice_set_filter(v.voice, (AudioServer::FilterType)p_filter, p_cutoff, p_resonance);
}
-void SamplePlayer::set_chorus(VoiceID p_voice,float p_send) {
+void SamplePlayer::set_chorus(VoiceID p_voice, float p_send) {
_GET_VOICE
- v.chorus_send=p_send;
-
- AudioServer::get_singleton()->voice_set_chorus(v.voice,p_send);
+ v.chorus_send = p_send;
+ AudioServer::get_singleton()->voice_set_chorus(v.voice, p_send);
}
-void SamplePlayer::set_reverb(VoiceID p_voice,ReverbRoomType p_room,float p_send) {
+void SamplePlayer::set_reverb(VoiceID p_voice, ReverbRoomType p_room, float p_send) {
_GET_VOICE
- v.reverb_room=p_room;
- v.reverb_send=p_send;
-
- AudioServer::get_singleton()->voice_set_reverb(v.voice,(AudioServer::ReverbRoomType)p_room,p_send);
+ v.reverb_room = p_room;
+ v.reverb_send = p_send;
+ AudioServer::get_singleton()->voice_set_reverb(v.voice, (AudioServer::ReverbRoomType)p_room, p_send);
}
-#define _GET_VOICE_V(m_ret)\
- uint32_t voice=p_voice&0xFFFF;\
- ERR_FAIL_COND_V(voice >= (uint32_t)voices.size(),m_ret);\
- const Voice &v=voices[voice];\
- if (v.check!=(p_voice>>16))\
- return m_ret;\
- ERR_FAIL_COND_V(!v.active,m_ret);
-
+#define _GET_VOICE_V(m_ret) \
+ uint32_t voice = p_voice & 0xFFFF; \
+ ERR_FAIL_COND_V(voice >= (uint32_t)voices.size(), m_ret); \
+ const Voice &v = voices[voice]; \
+ if (v.check != (p_voice >> 16)) \
+ return m_ret; \
+ ERR_FAIL_COND_V(!v.active, m_ret);
int SamplePlayer::get_mix_rate(VoiceID p_voice) const {
@@ -397,7 +372,7 @@ int SamplePlayer::get_mix_rate(VoiceID p_voice) const {
float SamplePlayer::get_pitch_scale(VoiceID p_voice) const {
_GET_VOICE_V(0);
- return v.sample_mix_rate/(float)v.mix_rate;
+ return v.sample_mix_rate / (float)v.mix_rate;
}
float SamplePlayer::get_volume(VoiceID p_voice) const {
@@ -405,7 +380,6 @@ float SamplePlayer::get_volume(VoiceID p_voice) const {
return v.volume;
}
-
float SamplePlayer::get_volume_db(VoiceID p_voice) const {
_GET_VOICE_V(0);
@@ -419,7 +393,6 @@ float SamplePlayer::get_pan(VoiceID p_voice) const {
}
float SamplePlayer::get_pan_depth(VoiceID p_voice) const {
-
_GET_VOICE_V(0);
return v.pan_depth;
}
@@ -478,26 +451,21 @@ bool SamplePlayer::is_voice_active(VoiceID p_voice) const {
_GET_VOICE_V(false);
return v.active && AudioServer::get_singleton()->voice_is_active(v.voice);
-
}
bool SamplePlayer::is_active() const {
- for(int i=0;i<voices.size();i++) {
+ for (int i = 0; i < voices.size(); i++) {
if (voices[i].active && AudioServer::get_singleton()->voice_is_active(voices[i].voice))
return true;
-
-
}
return false;
}
+void SamplePlayer::set_sample_library(const Ref<SampleLibrary> &p_library) {
-
-void SamplePlayer::set_sample_library(const Ref<SampleLibrary>& p_library) {
-
- library=p_library;
+ library = p_library;
_change_notify();
}
@@ -506,43 +474,39 @@ Ref<SampleLibrary> SamplePlayer::get_sample_library() const {
return library;
}
-
-
void SamplePlayer::set_default_pitch_scale(float p_pitch_scale) {
- _default.pitch_scale=p_pitch_scale;
+ _default.pitch_scale = p_pitch_scale;
}
void SamplePlayer::set_default_volume(float p_volume) {
- _default.volume_db=Math::linear2db(p_volume);
+ _default.volume_db = Math::linear2db(p_volume);
}
void SamplePlayer::set_default_volume_db(float p_db) {
- _default.volume_db=p_db;
+ _default.volume_db = p_db;
}
-void SamplePlayer::set_default_pan(float p_pan,float p_pan_depth,float p_pan_height) {
-
- _default.pan=p_pan;
- _default.depth=p_pan_depth;
- _default.height=p_pan_height;
+void SamplePlayer::set_default_pan(float p_pan, float p_pan_depth, float p_pan_height) {
+ _default.pan = p_pan;
+ _default.depth = p_pan_depth;
+ _default.height = p_pan_height;
}
-void SamplePlayer::set_default_filter(FilterType p_filter,float p_cutoff,float p_resonance,float p_gain) {
+void SamplePlayer::set_default_filter(FilterType p_filter, float p_cutoff, float p_resonance, float p_gain) {
- _default.filter_type=p_filter;
- _default.filter_cutoff=p_cutoff;
- _default.filter_resonance=p_resonance;
- _default.filter_gain=p_gain;
+ _default.filter_type = p_filter;
+ _default.filter_cutoff = p_cutoff;
+ _default.filter_resonance = p_resonance;
+ _default.filter_gain = p_gain;
}
void SamplePlayer::set_default_chorus(float p_send) {
- _default.chorus_send=p_send;
-
+ _default.chorus_send = p_send;
}
-void SamplePlayer::set_default_reverb(ReverbRoomType p_room,float p_send) {
+void SamplePlayer::set_default_reverb(ReverbRoomType p_room, float p_send) {
- _default.reverb_room=p_room;
- _default.reverb_send=p_send;
+ _default.reverb_room = p_room;
+ _default.reverb_send = p_send;
}
float SamplePlayer::get_default_volume() const {
@@ -558,7 +522,6 @@ float SamplePlayer::get_default_pitch_scale() const {
return _default.pitch_scale;
}
-
float SamplePlayer::get_default_pan() const {
return _default.pan;
@@ -611,108 +574,102 @@ String SamplePlayer::get_configuration_warning() const {
void SamplePlayer::_bind_methods() {
- ObjectTypeDB::bind_method(_MD("set_sample_library","library:SampleLibrary"),&SamplePlayer::set_sample_library );
- ObjectTypeDB::bind_method(_MD("get_sample_library:SampleLibrary"),&SamplePlayer::get_sample_library );
-
- ObjectTypeDB::bind_method(_MD("set_polyphony","max_voices"),&SamplePlayer::set_polyphony );
- ObjectTypeDB::bind_method(_MD("get_polyphony"),&SamplePlayer::get_polyphony );
+ ObjectTypeDB::bind_method(_MD("set_sample_library", "library:SampleLibrary"), &SamplePlayer::set_sample_library);
+ ObjectTypeDB::bind_method(_MD("get_sample_library:SampleLibrary"), &SamplePlayer::get_sample_library);
- ObjectTypeDB::bind_method(_MD("play","name","unique"),&SamplePlayer::play, DEFVAL(false) );
- ObjectTypeDB::bind_method(_MD("stop","voice"),&SamplePlayer::stop );
- ObjectTypeDB::bind_method(_MD("stop_all"),&SamplePlayer::stop_all );
+ ObjectTypeDB::bind_method(_MD("set_polyphony", "max_voices"), &SamplePlayer::set_polyphony);
+ ObjectTypeDB::bind_method(_MD("get_polyphony"), &SamplePlayer::get_polyphony);
- ObjectTypeDB::bind_method(_MD("set_mix_rate","voice","hz"),&SamplePlayer::set_mix_rate );
- ObjectTypeDB::bind_method(_MD("set_pitch_scale","voice","ratio"),&SamplePlayer::set_pitch_scale );
- ObjectTypeDB::bind_method(_MD("set_volume","voice","volume"),&SamplePlayer::set_volume );
- ObjectTypeDB::bind_method(_MD("set_volume_db","voice","db"),&SamplePlayer::set_volume_db );
- ObjectTypeDB::bind_method(_MD("set_pan","voice","pan","depth","height"),&SamplePlayer::set_pan,DEFVAL(0),DEFVAL(0) );
- ObjectTypeDB::bind_method(_MD("set_filter","voice","type","cutoff_hz","resonance","gain"),&SamplePlayer::set_filter,DEFVAL(0) );
- ObjectTypeDB::bind_method(_MD("set_chorus","voice","send"),&SamplePlayer::set_chorus );
- ObjectTypeDB::bind_method(_MD("set_reverb","voice","room_type","send"),&SamplePlayer::set_reverb );
+ ObjectTypeDB::bind_method(_MD("play", "name", "unique"), &SamplePlayer::play, DEFVAL(false));
+ ObjectTypeDB::bind_method(_MD("stop", "voice"), &SamplePlayer::stop);
+ ObjectTypeDB::bind_method(_MD("stop_all"), &SamplePlayer::stop_all);
- ObjectTypeDB::bind_method(_MD("get_mix_rate","voice"),&SamplePlayer::get_mix_rate );
- ObjectTypeDB::bind_method(_MD("get_pitch_scale","voice"),&SamplePlayer::get_pitch_scale );
- ObjectTypeDB::bind_method(_MD("get_volume","voice"),&SamplePlayer::get_volume );
- ObjectTypeDB::bind_method(_MD("get_volume_db","voice"),&SamplePlayer::get_volume_db );
- ObjectTypeDB::bind_method(_MD("get_pan","voice"),&SamplePlayer::get_pan );
- ObjectTypeDB::bind_method(_MD("get_pan_depth","voice"),&SamplePlayer::get_pan_depth );
- ObjectTypeDB::bind_method(_MD("get_pan_height","voice"),&SamplePlayer::get_pan_height );
- ObjectTypeDB::bind_method(_MD("get_filter_type","voice"),&SamplePlayer::get_filter_type );
- ObjectTypeDB::bind_method(_MD("get_filter_cutoff","voice"),&SamplePlayer::get_filter_cutoff );
- ObjectTypeDB::bind_method(_MD("get_filter_resonance","voice"),&SamplePlayer::get_filter_resonance );
- ObjectTypeDB::bind_method(_MD("get_filter_gain","voice"),&SamplePlayer::get_filter_gain );
- ObjectTypeDB::bind_method(_MD("get_chorus","voice"),&SamplePlayer::get_chorus );
- ObjectTypeDB::bind_method(_MD("get_reverb_room","voice"),&SamplePlayer::get_reverb_room );
- ObjectTypeDB::bind_method(_MD("get_reverb","voice"),&SamplePlayer::get_reverb );
+ ObjectTypeDB::bind_method(_MD("set_mix_rate", "voice", "hz"), &SamplePlayer::set_mix_rate);
+ ObjectTypeDB::bind_method(_MD("set_pitch_scale", "voice", "ratio"), &SamplePlayer::set_pitch_scale);
+ ObjectTypeDB::bind_method(_MD("set_volume", "voice", "volume"), &SamplePlayer::set_volume);
+ ObjectTypeDB::bind_method(_MD("set_volume_db", "voice", "db"), &SamplePlayer::set_volume_db);
+ ObjectTypeDB::bind_method(_MD("set_pan", "voice", "pan", "depth", "height"), &SamplePlayer::set_pan, DEFVAL(0), DEFVAL(0));
+ ObjectTypeDB::bind_method(_MD("set_filter", "voice", "type", "cutoff_hz", "resonance", "gain"), &SamplePlayer::set_filter, DEFVAL(0));
+ ObjectTypeDB::bind_method(_MD("set_chorus", "voice", "send"), &SamplePlayer::set_chorus);
+ ObjectTypeDB::bind_method(_MD("set_reverb", "voice", "room_type", "send"), &SamplePlayer::set_reverb);
- ObjectTypeDB::bind_method(_MD("set_default_pitch_scale","ratio"),&SamplePlayer::set_default_pitch_scale );
- ObjectTypeDB::bind_method(_MD("set_default_volume","volume"),&SamplePlayer::set_default_volume );
- ObjectTypeDB::bind_method(_MD("set_default_volume_db","db"),&SamplePlayer::set_default_volume_db );
- ObjectTypeDB::bind_method(_MD("set_default_pan","pan","depth","height"),&SamplePlayer::set_default_pan,DEFVAL(0),DEFVAL(0) );
- ObjectTypeDB::bind_method(_MD("set_default_filter","type","cutoff_hz","resonance","gain"),&SamplePlayer::set_default_filter,DEFVAL(0) );
- ObjectTypeDB::bind_method(_MD("set_default_chorus","send"),&SamplePlayer::set_default_chorus );
- ObjectTypeDB::bind_method(_MD("set_default_reverb","room_type","send"),&SamplePlayer::set_default_reverb );
+ ObjectTypeDB::bind_method(_MD("get_mix_rate", "voice"), &SamplePlayer::get_mix_rate);
+ ObjectTypeDB::bind_method(_MD("get_pitch_scale", "voice"), &SamplePlayer::get_pitch_scale);
+ ObjectTypeDB::bind_method(_MD("get_volume", "voice"), &SamplePlayer::get_volume);
+ ObjectTypeDB::bind_method(_MD("get_volume_db", "voice"), &SamplePlayer::get_volume_db);
+ ObjectTypeDB::bind_method(_MD("get_pan", "voice"), &SamplePlayer::get_pan);
+ ObjectTypeDB::bind_method(_MD("get_pan_depth", "voice"), &SamplePlayer::get_pan_depth);
+ ObjectTypeDB::bind_method(_MD("get_pan_height", "voice"), &SamplePlayer::get_pan_height);
+ ObjectTypeDB::bind_method(_MD("get_filter_type", "voice"), &SamplePlayer::get_filter_type);
+ ObjectTypeDB::bind_method(_MD("get_filter_cutoff", "voice"), &SamplePlayer::get_filter_cutoff);
+ ObjectTypeDB::bind_method(_MD("get_filter_resonance", "voice"), &SamplePlayer::get_filter_resonance);
+ ObjectTypeDB::bind_method(_MD("get_filter_gain", "voice"), &SamplePlayer::get_filter_gain);
+ ObjectTypeDB::bind_method(_MD("get_chorus", "voice"), &SamplePlayer::get_chorus);
+ ObjectTypeDB::bind_method(_MD("get_reverb_room", "voice"), &SamplePlayer::get_reverb_room);
+ ObjectTypeDB::bind_method(_MD("get_reverb", "voice"), &SamplePlayer::get_reverb);
- ObjectTypeDB::bind_method(_MD("get_default_pitch_scale"),&SamplePlayer::get_default_pitch_scale );
- ObjectTypeDB::bind_method(_MD("get_default_volume"),&SamplePlayer::get_default_volume );
- ObjectTypeDB::bind_method(_MD("get_default_volume_db"),&SamplePlayer::get_default_volume_db );
- ObjectTypeDB::bind_method(_MD("get_default_pan"),&SamplePlayer::get_default_pan );
- ObjectTypeDB::bind_method(_MD("get_default_pan_depth"),&SamplePlayer::get_default_pan_depth );
- ObjectTypeDB::bind_method(_MD("get_default_pan_height"),&SamplePlayer::get_default_pan_height );
- ObjectTypeDB::bind_method(_MD("get_default_filter_type"),&SamplePlayer::get_default_filter_type );
- ObjectTypeDB::bind_method(_MD("get_default_filter_cutoff"),&SamplePlayer::get_default_filter_cutoff );
- ObjectTypeDB::bind_method(_MD("get_default_filter_resonance"),&SamplePlayer::get_default_filter_resonance );
- ObjectTypeDB::bind_method(_MD("get_default_filter_gain"),&SamplePlayer::get_default_filter_gain );
- ObjectTypeDB::bind_method(_MD("get_default_chorus"),&SamplePlayer::get_default_chorus );
- ObjectTypeDB::bind_method(_MD("get_default_reverb_room"),&SamplePlayer::get_default_reverb_room );
- ObjectTypeDB::bind_method(_MD("get_default_reverb"),&SamplePlayer::get_default_reverb );
+ ObjectTypeDB::bind_method(_MD("set_default_pitch_scale", "ratio"), &SamplePlayer::set_default_pitch_scale);
+ ObjectTypeDB::bind_method(_MD("set_default_volume", "volume"), &SamplePlayer::set_default_volume);
+ ObjectTypeDB::bind_method(_MD("set_default_volume_db", "db"), &SamplePlayer::set_default_volume_db);
+ ObjectTypeDB::bind_method(_MD("set_default_pan", "pan", "depth", "height"), &SamplePlayer::set_default_pan, DEFVAL(0), DEFVAL(0));
+ ObjectTypeDB::bind_method(_MD("set_default_filter", "type", "cutoff_hz", "resonance", "gain"), &SamplePlayer::set_default_filter, DEFVAL(0));
+ ObjectTypeDB::bind_method(_MD("set_default_chorus", "send"), &SamplePlayer::set_default_chorus);
+ ObjectTypeDB::bind_method(_MD("set_default_reverb", "room_type", "send"), &SamplePlayer::set_default_reverb);
- ObjectTypeDB::bind_method(_MD("is_active"),&SamplePlayer::is_active );
- ObjectTypeDB::bind_method(_MD("is_voice_active","voice"),&SamplePlayer::is_voice_active );
+ ObjectTypeDB::bind_method(_MD("get_default_pitch_scale"), &SamplePlayer::get_default_pitch_scale);
+ ObjectTypeDB::bind_method(_MD("get_default_volume"), &SamplePlayer::get_default_volume);
+ ObjectTypeDB::bind_method(_MD("get_default_volume_db"), &SamplePlayer::get_default_volume_db);
+ ObjectTypeDB::bind_method(_MD("get_default_pan"), &SamplePlayer::get_default_pan);
+ ObjectTypeDB::bind_method(_MD("get_default_pan_depth"), &SamplePlayer::get_default_pan_depth);
+ ObjectTypeDB::bind_method(_MD("get_default_pan_height"), &SamplePlayer::get_default_pan_height);
+ ObjectTypeDB::bind_method(_MD("get_default_filter_type"), &SamplePlayer::get_default_filter_type);
+ ObjectTypeDB::bind_method(_MD("get_default_filter_cutoff"), &SamplePlayer::get_default_filter_cutoff);
+ ObjectTypeDB::bind_method(_MD("get_default_filter_resonance"), &SamplePlayer::get_default_filter_resonance);
+ ObjectTypeDB::bind_method(_MD("get_default_filter_gain"), &SamplePlayer::get_default_filter_gain);
+ ObjectTypeDB::bind_method(_MD("get_default_chorus"), &SamplePlayer::get_default_chorus);
+ ObjectTypeDB::bind_method(_MD("get_default_reverb_room"), &SamplePlayer::get_default_reverb_room);
+ ObjectTypeDB::bind_method(_MD("get_default_reverb"), &SamplePlayer::get_default_reverb);
- BIND_CONSTANT( FILTER_NONE);
- BIND_CONSTANT( FILTER_LOWPASS);
- BIND_CONSTANT( FILTER_BANDPASS);
- BIND_CONSTANT( FILTER_HIPASS);
- BIND_CONSTANT( FILTER_NOTCH);
- BIND_CONSTANT( FILTER_PEAK);
- BIND_CONSTANT( FILTER_BANDLIMIT); ///< cutoff is LP resonace is HP
- BIND_CONSTANT( FILTER_LOW_SHELF);
- BIND_CONSTANT( FILTER_HIGH_SHELF);
+ ObjectTypeDB::bind_method(_MD("is_active"), &SamplePlayer::is_active);
+ ObjectTypeDB::bind_method(_MD("is_voice_active", "voice"), &SamplePlayer::is_voice_active);
- BIND_CONSTANT( REVERB_SMALL );
- BIND_CONSTANT( REVERB_MEDIUM );
- BIND_CONSTANT( REVERB_LARGE );
- BIND_CONSTANT( REVERB_HALL );
+ BIND_CONSTANT(FILTER_NONE);
+ BIND_CONSTANT(FILTER_LOWPASS);
+ BIND_CONSTANT(FILTER_BANDPASS);
+ BIND_CONSTANT(FILTER_HIPASS);
+ BIND_CONSTANT(FILTER_NOTCH);
+ BIND_CONSTANT(FILTER_PEAK);
+ BIND_CONSTANT(FILTER_BANDLIMIT); ///< cutoff is LP resonace is HP
+ BIND_CONSTANT(FILTER_LOW_SHELF);
+ BIND_CONSTANT(FILTER_HIGH_SHELF);
- BIND_CONSTANT( INVALID_VOICE_ID );
+ BIND_CONSTANT(REVERB_SMALL);
+ BIND_CONSTANT(REVERB_MEDIUM);
+ BIND_CONSTANT(REVERB_LARGE);
+ BIND_CONSTANT(REVERB_HALL);
+ BIND_CONSTANT(INVALID_VOICE_ID);
}
-
SamplePlayer::SamplePlayer() {
voices.resize(1);
- _default.pitch_scale=1;
- _default.volume_db=0;
- _default.pan=0;
- _default.depth=0;
- _default.height=0;
- _default.filter_type=FILTER_NONE;
- _default.filter_cutoff=5000;
- _default.filter_resonance=1;
- _default.filter_gain=1;
- _default.chorus_send=0;
- _default.reverb_room=REVERB_LARGE;
- _default.reverb_send=0;
- last_id=0;
- last_check=0;
-
-
+ _default.pitch_scale = 1;
+ _default.volume_db = 0;
+ _default.pan = 0;
+ _default.depth = 0;
+ _default.height = 0;
+ _default.filter_type = FILTER_NONE;
+ _default.filter_cutoff = 5000;
+ _default.filter_resonance = 1;
+ _default.filter_gain = 1;
+ _default.chorus_send = 0;
+ _default.reverb_room = REVERB_LARGE;
+ _default.reverb_send = 0;
+ last_id = 0;
+ last_check = 0;
}
SamplePlayer::~SamplePlayer() {
-
-
}