148 |
|
|
149 |
void PitchEGUnit::Trigger() { |
void PitchEGUnit::Trigger() { |
150 |
::sfz::Region* const pRegion = pVoice->pRegion; |
::sfz::Region* const pRegion = pVoice->pRegion; |
151 |
depth = pRegion->pitcheg_depth; |
depth = pRegion->pitcheg_depth + GetInfluence(pRegion->pitcheg_depth_oncc); |
152 |
|
|
153 |
// the length of the decay and release curves are dependent on the velocity |
// the length of the decay and release curves are dependent on the velocity |
154 |
const double velrelease = 1 / pVoice->GetVelocityRelease(pVoice->MIDIVelocity); |
const double velrelease = 1 / pVoice->GetVelocityRelease(pVoice->MIDIVelocity); |
155 |
|
|
156 |
// set the delay trigger |
// set the delay trigger |
157 |
uiDelayTrigger = (pRegion->pitcheg_delay + pRegion->pitcheg_vel2delay * velrelease) * GetSampleRate(); |
float delay = pRegion->pitcheg_delay + pRegion->pitcheg_vel2delay * velrelease; |
158 |
|
delay += GetInfluence(pRegion->pitcheg_delay_oncc); |
159 |
|
uiDelayTrigger = std::max(0.0f, delay) * GetSampleRate(); |
160 |
|
|
161 |
|
float start = (pRegion->pitcheg_start + GetInfluence(pRegion->pitcheg_start_oncc)) * 10; |
162 |
|
|
163 |
|
float attack = pRegion->pitcheg_attack + pRegion->pitcheg_vel2attack * velrelease; |
164 |
|
attack = std::max(0.0f, attack + GetInfluence(pRegion->pitcheg_attack_oncc)); |
165 |
|
|
166 |
|
float hold = pRegion->pitcheg_hold + pRegion->pitcheg_vel2hold * velrelease; |
167 |
|
hold = std::max(0.0f, hold + GetInfluence(pRegion->pitcheg_hold_oncc)); |
168 |
|
|
169 |
EG.trigger(uint(pRegion->pitcheg_start * 10), |
float decay = pRegion->pitcheg_decay + pRegion->pitcheg_vel2decay * velrelease; |
170 |
std::max(0.0, pRegion->pitcheg_attack + pRegion->pitcheg_vel2attack * velrelease), |
decay = std::max(0.0f, decay + GetInfluence(pRegion->pitcheg_decay_oncc)); |
171 |
std::max(0.0, pRegion->pitcheg_hold + pRegion->pitcheg_vel2hold * velrelease), |
|
172 |
std::max(0.0, pRegion->pitcheg_decay + pRegion->pitcheg_vel2decay * velrelease), |
float sustain = pRegion->pitcheg_sustain + pRegion->pitcheg_vel2sustain * velrelease; |
173 |
uint(std::min(std::max(0.0, 10 * (pRegion->pitcheg_sustain + pRegion->pitcheg_vel2sustain * velrelease)), 1000.0)), |
sustain = 10 * (sustain + GetInfluence(pRegion->pitcheg_sustain_oncc)); |
174 |
std::max(0.0, pRegion->pitcheg_release + pRegion->pitcheg_vel2release * velrelease), |
|
175 |
GetSampleRate()); |
float release = pRegion->pitcheg_release + pRegion->pitcheg_vel2release * velrelease; |
176 |
|
release = std::max(0.0f, release + GetInfluence(pRegion->pitcheg_release_oncc)); |
177 |
|
|
178 |
|
EG.trigger ( |
179 |
|
uint(std::min(std::max(0.0f, start), 1000.0f)), attack, hold, decay, |
180 |
|
uint(std::min(std::max(0.0f, sustain), 1000.0f)), release, GetSampleRate() |
181 |
|
); |
182 |
} |
} |
183 |
|
|
184 |
|
|
185 |
void FilEGUnit::Trigger() { |
void FilEGUnit::Trigger() { |
186 |
::sfz::Region* const pRegion = pVoice->pRegion; |
::sfz::Region* const pRegion = pVoice->pRegion; |
187 |
depth = pRegion->fileg_depth; |
depth = pRegion->fileg_depth + GetInfluence(pRegion->fileg_depth_oncc); |
188 |
|
|
189 |
// the length of the decay and release curves are dependent on the velocity |
// the length of the decay and release curves are dependent on the velocity |
190 |
const double velrelease = 1 / pVoice->GetVelocityRelease(pVoice->MIDIVelocity); |
const double velrelease = 1 / pVoice->GetVelocityRelease(pVoice->MIDIVelocity); |
191 |
|
|
192 |
// set the delay trigger |
// set the delay trigger |
193 |
uiDelayTrigger = (pRegion->fileg_delay + pRegion->fileg_vel2delay * velrelease) * GetSampleRate(); |
float delay = pRegion->fileg_delay + pRegion->fileg_vel2delay * velrelease; |
194 |
|
delay += GetInfluence(pRegion->fileg_delay_oncc); |
195 |
|
uiDelayTrigger = std::max(0.0f, delay) * GetSampleRate(); |
196 |
|
|
197 |
|
float start = (pRegion->fileg_start + GetInfluence(pRegion->fileg_start_oncc)) * 10; |
198 |
|
|
199 |
|
float attack = pRegion->fileg_attack + pRegion->fileg_vel2attack * velrelease; |
200 |
|
attack = std::max(0.0f, attack + GetInfluence(pRegion->fileg_attack_oncc)); |
201 |
|
|
202 |
|
float hold = pRegion->fileg_hold + pRegion->fileg_vel2hold * velrelease; |
203 |
|
hold = std::max(0.0f, hold + GetInfluence(pRegion->fileg_hold_oncc)); |
204 |
|
|
205 |
EG.trigger(uint(pRegion->fileg_start * 10), |
float decay = pRegion->fileg_decay + pRegion->fileg_vel2decay * velrelease; |
206 |
std::max(0.0, pRegion->fileg_attack + pRegion->fileg_vel2attack * velrelease), |
decay = std::max(0.0f, decay + GetInfluence(pRegion->fileg_decay_oncc)); |
207 |
std::max(0.0, pRegion->fileg_hold + pRegion->fileg_vel2hold * velrelease), |
|
208 |
std::max(0.0, pRegion->fileg_decay + pRegion->fileg_vel2decay * velrelease), |
float sustain = pRegion->fileg_sustain + pRegion->fileg_vel2sustain * velrelease; |
209 |
uint(std::min(std::max(0.0, 10 * (pRegion->fileg_sustain + pRegion->fileg_vel2sustain * velrelease)), 1000.0)), |
sustain = 10 * (sustain + GetInfluence(pRegion->fileg_sustain_oncc)); |
210 |
std::max(0.0, pRegion->fileg_release + pRegion->fileg_vel2release * velrelease), |
|
211 |
GetSampleRate()); |
float release = pRegion->fileg_release + pRegion->fileg_vel2release * velrelease; |
212 |
|
release = std::max(0.0f, release + GetInfluence(pRegion->fileg_release_oncc)); |
213 |
|
|
214 |
|
EG.trigger ( |
215 |
|
uint(std::min(std::max(0.0f, start), 1000.0f)), attack, hold, decay, |
216 |
|
uint(std::min(std::max(0.0f, sustain), 1000.0f)), release, GetSampleRate() |
217 |
|
); |
218 |
} |
} |
219 |
|
|
220 |
|
|
293 |
} |
} |
294 |
|
|
295 |
void LFOUnit::ValueChanged(CCSignalUnit* pUnit) { |
void LFOUnit::ValueChanged(CCSignalUnit* pUnit) { |
296 |
|
if (pLFO == NULL) return; |
297 |
pLFO->SetFrequency(std::max(0.0f, suFreqOnCC.GetLevel() + pLfoInfo->freq), GetSampleRate()); |
pLFO->SetFrequency(std::max(0.0f, suFreqOnCC.GetLevel() + pLfoInfo->freq), GetSampleRate()); |
298 |
} |
} |
299 |
|
|
343 |
} |
} |
344 |
|
|
345 |
void AmpLFOUnit::Trigger() { |
void AmpLFOUnit::Trigger() { |
346 |
|
bActive = true; |
347 |
::sfz::Region* const pRegion = pVoice->pRegion; |
::sfz::Region* const pRegion = pVoice->pRegion; |
348 |
pLfoInfo->delay = pRegion->amplfo_delay + GetInfluence(pRegion->amplfo_delay_oncc); |
pLfoInfo->delay = pRegion->amplfo_delay + GetInfluence(pRegion->amplfo_delay_oncc); |
349 |
pLfoInfo->freq = pRegion->amplfo_freq; |
pLfoInfo->freq = pRegion->amplfo_freq; |
350 |
pLfoInfo->fade = pRegion->amplfo_fade + GetInfluence(pRegion->amplfo_fade_oncc); |
pLfoInfo->fade = pRegion->amplfo_fade + GetInfluence(pRegion->amplfo_fade_oncc); |
351 |
pLfoInfo->volume = pRegion->amplfo_depth; |
pLfoInfo->volume = pRegion->amplfo_depth; |
352 |
|
|
353 |
|
if (pLfoInfo->freq <= 0) { |
354 |
|
if (!pRegion->amplfo_freqcc.empty()) pLfoInfo->freq = 0; |
355 |
|
else bActive = false; |
356 |
|
} |
357 |
|
|
358 |
LFOv1Unit::Trigger(); |
LFOv1Unit::Trigger(); |
359 |
} |
} |
360 |
|
|
361 |
void PitchLFOUnit::Trigger() { |
void PitchLFOUnit::Trigger() { |
362 |
|
bActive = true; |
363 |
::sfz::Region* const pRegion = pVoice->pRegion; |
::sfz::Region* const pRegion = pVoice->pRegion; |
364 |
pLfoInfo->delay = pRegion->pitchlfo_delay + GetInfluence(pRegion->pitchlfo_delay_oncc); |
pLfoInfo->delay = pRegion->pitchlfo_delay + GetInfluence(pRegion->pitchlfo_delay_oncc); |
365 |
pLfoInfo->freq = pRegion->pitchlfo_freq; |
pLfoInfo->freq = pRegion->pitchlfo_freq; |
366 |
pLfoInfo->fade = pRegion->pitchlfo_fade + GetInfluence(pRegion->pitchlfo_fade_oncc); |
pLfoInfo->fade = pRegion->pitchlfo_fade + GetInfluence(pRegion->pitchlfo_fade_oncc); |
367 |
pLfoInfo->pitch = pRegion->pitchlfo_depth; |
pLfoInfo->pitch = pRegion->pitchlfo_depth; |
368 |
|
|
369 |
|
if (pLfoInfo->freq <= 0) { |
370 |
|
if (!pRegion->pitchlfo_freqcc.empty()) pLfoInfo->freq = 0; |
371 |
|
else bActive = false; |
372 |
|
} |
373 |
|
|
374 |
LFOv1Unit::Trigger(); |
LFOv1Unit::Trigger(); |
375 |
} |
} |
376 |
|
|
377 |
void FilLFOUnit::Trigger() { |
void FilLFOUnit::Trigger() { |
378 |
|
bActive = true; |
379 |
::sfz::Region* const pRegion = pVoice->pRegion; |
::sfz::Region* const pRegion = pVoice->pRegion; |
380 |
pLfoInfo->delay = pRegion->fillfo_delay + GetInfluence(pRegion->fillfo_delay_oncc); |
pLfoInfo->delay = pRegion->fillfo_delay + GetInfluence(pRegion->fillfo_delay_oncc); |
381 |
pLfoInfo->freq = pRegion->fillfo_freq; |
pLfoInfo->freq = pRegion->fillfo_freq; |
382 |
pLfoInfo->fade = pRegion->fillfo_fade + GetInfluence(pRegion->fillfo_fade_oncc); |
pLfoInfo->fade = pRegion->fillfo_fade + GetInfluence(pRegion->fillfo_fade_oncc); |
383 |
pLfoInfo->cutoff = pRegion->fillfo_depth; |
pLfoInfo->cutoff = pRegion->fillfo_depth; |
384 |
|
|
385 |
|
if (pLfoInfo->freq <= 0) { |
386 |
|
if (!pRegion->fillfo_freqcc.empty()) pLfoInfo->freq = 0; |
387 |
|
else bActive = false; |
388 |
|
} |
389 |
|
|
390 |
LFOv1Unit::Trigger(); |
LFOv1Unit::Trigger(); |
391 |
} |
} |
392 |
|
|
879 |
|
|
880 |
// LFO |
// LFO |
881 |
for (int i = 0; i < pRegion->lfos.size(); i++) { |
for (int i = 0; i < pRegion->lfos.size(); i++) { |
882 |
if (pRegion->lfos[i].freq == -1) continue; // Not initialized |
if (pRegion->lfos[i].freq <= 0) { |
883 |
|
if (pRegion->lfos[i].freq_oncc.empty()) continue; // Not initialized |
884 |
|
else pRegion->lfos[i].freq = 0; |
885 |
|
} |
886 |
|
|
887 |
if(LFOs.size() < LFOs.capacity()) { |
if(LFOs.size() < LFOs.capacity()) { |
888 |
LFOv2Unit lfo(this); |
LFOv2Unit lfo(this); |