osci-render/Source/CommonPluginProcessor.cpp

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());
}