/*************************************************************************/ /* cp_instrument.cpp */ /*************************************************************************/ /* This file is part of: */ /* GODOT ENGINE */ /* http://www.godotengine.org */ /*************************************************************************/ /* Copyright (c) 2007-2017 Juan Linietsky, Ariel Manzur. */ /* */ /* Permission is hereby granted, free of charge, to any person obtaining */ /* a copy of this software and associated documentation files (the */ /* "Software"), to deal in the Software without restriction, including */ /* without limitation the rights to use, copy, modify, merge, publish, */ /* distribute, sublicense, and/or sell copies of the Software, and to */ /* permit persons to whom the Software is furnished to do so, subject to */ /* the following conditions: */ /* */ /* The above copyright notice and this permission notice shall be */ /* included in all copies or substantial portions of the Software. */ /* */ /* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */ /* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */ /* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/ /* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */ /* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */ /* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */ /* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ /*************************************************************************/ #include "cp_instrument.h" #include "cp_note.h" #include "cp_song.h" const char *CPInstrument::get_name() { return name; } void CPInstrument::set_name(const char *p_name) { if (p_name == NULL) { name[0] = 0; return; } bool done = false; for (int i = 0; i < MAX_NAME_LEN; i++) { name[i] = done ? 0 : p_name[i]; if (!done && p_name[i] == 0) done = true; } name[MAX_NAME_LEN - 1] = 0; /* just in case */ } void CPInstrument::set_sample_number(uint8_t p_note, uint8_t p_sample_id) { CP_ERR_COND(p_note >= CPNote::NOTES); CP_ERR_COND(p_sample_id > CPSong::MAX_SAMPLES && p_sample_id != CPNote::EMPTY); data.sample_number[p_note] = p_sample_id; } uint8_t CPInstrument::get_sample_number(uint8_t p_note) { CP_ERR_COND_V(p_note >= CPNote::NOTES, 0); return data.sample_number[p_note]; } void CPInstrument::set_note_number(uint8_t p_note, uint8_t p_note_id) { CP_ERR_COND(p_note >= CPNote::NOTES); CP_ERR_COND(p_note_id >= CPNote::NOTES && p_note_id != CPNote::EMPTY); data.note_number[p_note] = p_note_id; } uint8_t CPInstrument::get_note_number(uint8_t p_note) { CP_ERR_COND_V(p_note >= CPNote::NOTES, 0); return data.note_number[p_note]; } void CPInstrument::set_NNA_type(NNA_Type p_NNA_type) { data.NNA_type = p_NNA_type; } CPInstrument::NNA_Type CPInstrument::get_NNA_type() { return data.NNA_type; } void CPInstrument::set_DC_type(DC_Type p_DC_type) { data.DC_type = p_DC_type; } CPInstrument::DC_Type CPInstrument::get_DC_type() { return data.DC_type; } void CPInstrument::set_DC_action(DC_Action p_DC_action) { data.DC_action = p_DC_action; } CPInstrument::DC_Action CPInstrument::get_DC_action() { return data.DC_action; } /* Volume */ void CPInstrument::set_volume_global_amount(uint8_t p_amount) { CP_ERR_COND(p_amount > MAX_VOLUME); data.volume.global_amount = p_amount; } uint8_t CPInstrument::get_volume_global_amount() { return data.volume.global_amount; } void CPInstrument::set_volume_fadeout(uint16_t p_amount) { CP_ERR_COND(p_amount > MAX_FADEOUT); data.volume.fadeout = p_amount; } uint16_t CPInstrument::get_volume_fadeout() { return data.volume.fadeout; } void CPInstrument::set_volume_random_variation(uint8_t p_amount) { CP_ERR_COND(p_amount > MAX_VOLUME_RANDOM); data.volume.random_variation = p_amount; } uint8_t CPInstrument::get_volume_random_variation() { return data.volume.random_variation; } /* Panning */ void CPInstrument::set_pan_default_amount(uint8_t p_amount) { CP_ERR_COND(p_amount > MAX_PAN); data.pan.default_amount = p_amount; } uint8_t CPInstrument::get_pan_default_amount() { return data.pan.default_amount; } void CPInstrument::set_pan_default_enabled(bool p_enabled) { data.pan.use_default = p_enabled; } bool CPInstrument::is_pan_default_enabled() { return data.pan.use_default; } void CPInstrument::set_pan_pitch_separation(int8_t p_amount) { CP_ERR_COND(p_amount < -32); CP_ERR_COND(p_amount > 32); data.pan.pitch_separation = p_amount; } int8_t CPInstrument::get_pan_pitch_separation() { return data.pan.pitch_separation; } void CPInstrument::set_pan_pitch_center(uint8_t p_amount) { CP_ERR_COND(p_amount >= CPNote::NOTES); data.pan.pitch_center = p_amount; } uint8_t CPInstrument::get_pan_pitch_center() { return data.pan.pitch_center; } void CPInstrument::set_pan_random_variation(uint8_t p_amount) { CP_ERR_COND(p_amount > MAX_PAN_RANDOM); data.pan.random_variation = p_amount; } uint8_t CPInstrument::get_pan_random_variation() { return data.pan.random_variation; } /* Pitch / Filter */ void CPInstrument::set_pitch_use_as_filter(bool p_enabled) { data.pitch.use_as_filter = p_enabled; } bool CPInstrument::is_pitch_use_as_filter() { return data.pitch.use_as_filter; } void CPInstrument::set_filter_use_default_cutoff(bool p_enabled) { data.pitch.use_default_cutoff = p_enabled; } bool CPInstrument::filter_use_default_cutoff() { return data.pitch.use_default_cutoff; } void CPInstrument::set_filter_default_cutoff(uint8_t p_amount) { CP_ERR_COND(p_amount > MAX_FILTER_CUTOFF); data.pitch.default_cutoff = p_amount; } uint8_t CPInstrument::get_filter_default_cutoff() { return data.pitch.default_cutoff; } void CPInstrument::set_filter_use_default_resonance(bool p_enabled) { data.pitch.use_default_resonance = p_enabled; } bool CPInstrument::filter_use_default_resonance() { return data.pitch.use_default_resonance; } void CPInstrument::set_filter_default_resonance(uint8_t p_amount) { CP_ERR_COND(p_amount > MAX_FILTER_RESONANCE); data.pitch.default_resonance = p_amount; } uint8_t CPInstrument::get_filter_default_resonance() { return data.pitch.default_resonance; } /* Envelopes */ CPEnvelope *CPInstrument::get_volume_envelope() { return &data.volume.envelope; } CPEnvelope *CPInstrument::get_pan_envelope() { return &data.pan.envelope; } CPEnvelope *CPInstrument::get_pitch_filter_envelope() { return &data.pitch.envelope; } void CPInstrument::reset() { name[0] = 0; data.NNA_type = NNA_NOTE_CUT; data.DC_action = DCA_NOTE_CUT; data.DC_type = DCT_DISABLED; for (int i = 0; i < CPNote::NOTES; i++) { data.sample_number[i] = CPNote::EMPTY; data.note_number[i] = i; } data.volume.envelope.reset(); data.volume.envelope.set_max(64); data.volume.envelope.set_min(0); data.volume.envelope.add_position(0, 64, false); data.volume.envelope.add_position(30, 64, false); data.volume.global_amount = MAX_VOLUME; data.volume.fadeout = 0; data.volume.random_variation = 0; data.pan.envelope.reset(); data.pan.envelope.set_max(32); data.pan.envelope.set_min(-32); data.pan.envelope.add_position(0, 0, false); data.pan.envelope.add_position(30, 0, false); data.pan.default_amount = 32; data.pan.pitch_center = 48; data.pan.pitch_separation = 0; data.pan.use_default = false; data.pan.random_variation = 0; data.pitch.envelope.reset(); data.pitch.envelope.set_max(32); data.pitch.envelope.set_min(-32); data.pitch.envelope.add_position(0, 0, false); data.pitch.envelope.add_position(30, 0, false); data.pitch.use_as_filter = false; data.pitch.use_default_cutoff = false; data.pitch.use_default_resonance = false; data.pitch.default_cutoff = 0; data.pitch.default_resonance = 0; } bool CPInstrument::is_empty() { bool has_sample = false; for (int i = 0; i < CPNote::NOTES; i++) { if (data.sample_number[i] != CPNote::EMPTY) { has_sample = true; break; } } return !has_sample; } CPInstrument::CPInstrument() { reset(); }