kopia lustrzana https://github.com/jameshball/osci-render
228 wiersze
6.6 KiB
C++
228 wiersze
6.6 KiB
C++
/*
|
|
==============================================================================
|
|
|
|
This file contains the basic framework code for a JUCE plugin processor.
|
|
|
|
==============================================================================
|
|
*/
|
|
|
|
#include "CommonPluginProcessor.h"
|
|
#include "CommonPluginEditor.h"
|
|
#include "audio/EffectParameter.h"
|
|
#include "components/AudioPlayerComponent.h"
|
|
|
|
//==============================================================================
|
|
CommonAudioProcessor::CommonAudioProcessor(const BusesProperties& busesProperties)
|
|
#ifndef JucePlugin_PreferredChannelConfigurations
|
|
: AudioProcessor(busesProperties)
|
|
#endif
|
|
{
|
|
// locking isn't necessary here because we are in the constructor
|
|
|
|
for (auto effect : visualiserParameters.effects) {
|
|
permanentEffects.push_back(effect);
|
|
effects.push_back(effect);
|
|
}
|
|
|
|
for (auto effect : visualiserParameters.audioEffects) {
|
|
effects.push_back(effect);
|
|
}
|
|
|
|
for (auto parameter : visualiserParameters.booleans) {
|
|
booleanParameters.push_back(parameter);
|
|
}
|
|
|
|
for (auto parameter : visualiserParameters.integers) {
|
|
intParameters.push_back(parameter);
|
|
}
|
|
|
|
permanentEffects.push_back(volumeEffect);
|
|
permanentEffects.push_back(thresholdEffect);
|
|
effects.push_back(volumeEffect);
|
|
effects.push_back(thresholdEffect);
|
|
|
|
wavParser.setLooping(false);
|
|
}
|
|
|
|
void CommonAudioProcessor::addAllParameters() {
|
|
for (auto effect : effects) {
|
|
for (auto effectParameter : effect->parameters) {
|
|
auto parameters = effectParameter->getParameters();
|
|
for (auto parameter : parameters) {
|
|
addParameter(parameter);
|
|
}
|
|
}
|
|
}
|
|
|
|
for (auto parameter : booleanParameters) {
|
|
addParameter(parameter);
|
|
}
|
|
|
|
for (auto parameter : floatParameters) {
|
|
addParameter(parameter);
|
|
}
|
|
|
|
for (auto parameter : intParameters) {
|
|
addParameter(parameter);
|
|
}
|
|
}
|
|
|
|
CommonAudioProcessor::~CommonAudioProcessor() {}
|
|
|
|
const juce::String CommonAudioProcessor::getName() const {
|
|
return JucePlugin_Name;
|
|
}
|
|
|
|
bool CommonAudioProcessor::acceptsMidi() const {
|
|
#if JucePlugin_WantsMidiInput
|
|
return true;
|
|
#else
|
|
return false;
|
|
#endif
|
|
}
|
|
|
|
bool CommonAudioProcessor::producesMidi() const {
|
|
#if JucePlugin_ProducesMidiOutput
|
|
return true;
|
|
#else
|
|
return false;
|
|
#endif
|
|
}
|
|
|
|
bool CommonAudioProcessor::isMidiEffect() const {
|
|
#if JucePlugin_IsMidiEffect
|
|
return true;
|
|
#else
|
|
return false;
|
|
#endif
|
|
}
|
|
|
|
double CommonAudioProcessor::getTailLengthSeconds() const {
|
|
return 0.0;
|
|
}
|
|
|
|
int CommonAudioProcessor::getNumPrograms() {
|
|
return 1; // NB: some hosts don't cope very well if you tell them there are 0 programs,
|
|
// so this should be at least 1, even if you're not really implementing programs.
|
|
}
|
|
|
|
int CommonAudioProcessor::getCurrentProgram() {
|
|
return 0;
|
|
}
|
|
|
|
void CommonAudioProcessor::setCurrentProgram(int index) {
|
|
}
|
|
|
|
const juce::String CommonAudioProcessor::getProgramName(int index) {
|
|
return {};
|
|
}
|
|
|
|
void CommonAudioProcessor::changeProgramName(int index, const juce::String& newName) {}
|
|
|
|
void CommonAudioProcessor::prepareToPlay(double sampleRate, int samplesPerBlock) {
|
|
currentSampleRate = sampleRate;
|
|
|
|
for (auto& effect : effects) {
|
|
effect->updateSampleRate(currentSampleRate);
|
|
}
|
|
|
|
threadManager.prepare(sampleRate, samplesPerBlock);
|
|
}
|
|
|
|
void CommonAudioProcessor::releaseResources() {
|
|
// When playback stops, you can use this as an opportunity to free up any
|
|
// spare memory, etc.
|
|
}
|
|
|
|
bool CommonAudioProcessor::isBusesLayoutSupported(const BusesLayout& layouts) const {
|
|
return true;
|
|
}
|
|
|
|
// effectsLock should be held when calling this
|
|
std::shared_ptr<Effect> CommonAudioProcessor::getEffect(juce::String id) {
|
|
for (auto& effect : effects) {
|
|
if (effect->getId() == id) {
|
|
return effect;
|
|
}
|
|
}
|
|
return nullptr;
|
|
}
|
|
|
|
// effectsLock should be held when calling this
|
|
BooleanParameter* CommonAudioProcessor::getBooleanParameter(juce::String id) {
|
|
for (auto& parameter : booleanParameters) {
|
|
if (parameter->paramID == id) {
|
|
return parameter;
|
|
}
|
|
}
|
|
return nullptr;
|
|
}
|
|
|
|
// effectsLock should be held when calling this
|
|
FloatParameter* CommonAudioProcessor::getFloatParameter(juce::String id) {
|
|
for (auto& parameter : floatParameters) {
|
|
if (parameter->paramID == id) {
|
|
return parameter;
|
|
}
|
|
}
|
|
return nullptr;
|
|
}
|
|
|
|
// effectsLock should be held when calling this
|
|
IntParameter* CommonAudioProcessor::getIntParameter(juce::String id) {
|
|
for (auto& parameter : intParameters) {
|
|
if (parameter->paramID == id) {
|
|
return parameter;
|
|
}
|
|
}
|
|
return nullptr;
|
|
}
|
|
|
|
//==============================================================================
|
|
bool CommonAudioProcessor::hasEditor() const {
|
|
return true; // (change this to false if you choose to not supply an editor)
|
|
}
|
|
|
|
double CommonAudioProcessor::getSampleRate() {
|
|
return currentSampleRate;
|
|
}
|
|
|
|
void CommonAudioProcessor::loadAudioFile(const juce::File& file) {
|
|
auto stream = std::make_unique<juce::FileInputStream>(file);
|
|
if (stream->openedOk()) {
|
|
loadAudioFile(std::move(stream));
|
|
}
|
|
}
|
|
|
|
void CommonAudioProcessor::loadAudioFile(std::unique_ptr<juce::InputStream> stream) {
|
|
if (stream != nullptr) {
|
|
juce::SpinLock::ScopedLockType lock(wavParserLock);
|
|
wavParser.parse(std::move(stream));
|
|
|
|
juce::SpinLock::ScopedLockType lock2(audioPlayerListenersLock);
|
|
for (auto listener : audioPlayerListeners) {
|
|
listener->parserChanged();
|
|
}
|
|
}
|
|
}
|
|
|
|
void CommonAudioProcessor::stopAudioFile() {
|
|
juce::SpinLock::ScopedLockType lock(wavParserLock);
|
|
wavParser.close();
|
|
|
|
juce::SpinLock::ScopedLockType lock2(audioPlayerListenersLock);
|
|
for (auto listener : audioPlayerListeners) {
|
|
listener->parserChanged();
|
|
}
|
|
}
|
|
|
|
void CommonAudioProcessor::addAudioPlayerListener(AudioPlayerListener* listener) {
|
|
juce::SpinLock::ScopedLockType lock(audioPlayerListenersLock);
|
|
audioPlayerListeners.push_back(listener);
|
|
}
|
|
|
|
void CommonAudioProcessor::removeAudioPlayerListener(AudioPlayerListener* listener) {
|
|
juce::SpinLock::ScopedLockType lock(audioPlayerListenersLock);
|
|
audioPlayerListeners.erase(std::remove(audioPlayerListeners.begin(), audioPlayerListeners.end(), listener), audioPlayerListeners.end());
|
|
}
|