adds a lot of stuff, working band pass filter (lofi mode), and output gain

This commit is contained in:
2025-07-07 12:07:12 -04:00
parent b2db3ef579
commit bf9bf80d69
2 changed files with 48 additions and 11 deletions

View File

@ -30,6 +30,7 @@ ReverbAudioProcessor::ReverbAudioProcessor()
addParameter(freezeMode = new juce::AudioParameterFloat(juce::ParameterID("freezeMode", 5), "Freeze", 0.0, 1.0, 0.0)); addParameter(freezeMode = new juce::AudioParameterFloat(juce::ParameterID("freezeMode", 5), "Freeze", 0.0, 1.0, 0.0));
addParameter(lofi = new juce::AudioParameterBool(juce::ParameterID("lofi", 6), "Tone or lofi", false)); addParameter(lofi = new juce::AudioParameterBool(juce::ParameterID("lofi", 6), "Tone or lofi", false));
addParameter(tone_val = new juce::AudioParameterFloat(juce::ParameterID("tone_val", 7), "Tone", 0.0, 1.0, 0.5)); addParameter(tone_val = new juce::AudioParameterFloat(juce::ParameterID("tone_val", 7), "Tone", 0.0, 1.0, 0.5));
addParameter(out = new juce::AudioParameterFloat(juce::ParameterID("out", 8), "Output", 0.0, 2.0, 1.0));
verb.setSampleRate(sample_rate); verb.setSampleRate(sample_rate);
} }
@ -94,6 +95,10 @@ void ReverbAudioProcessor::prepareToPlay (double sampleRate, int samplesPerBlock
// Use this method as the place to do any pre-playback // Use this method as the place to do any pre-playback
// initialisation that you need.. // initialisation that you need..
verb.reset(); verb.reset();
filter_l = new juce::IIRFilter();
filter_r = new juce::IIRFilter();
} }
void ReverbAudioProcessor::releaseResources() void ReverbAudioProcessor::releaseResources()
@ -152,20 +157,47 @@ void ReverbAudioProcessor::processBlock (juce::AudioBuffer<float>& buffer, juce:
// Alternatively, you can process the samples with the channels // Alternatively, you can process the samples with the channels
// interleaved by keeping the same state. // interleaved by keeping the same state.
/*
for (int channel = 0; channel < totalNumInputChannels; ++channel)
{
auto* channelData = buffer.getWritePointer (channel);
// ..do something to the data...
} auto* channel_one = buffer.getWritePointer(0);
*/ auto* channel_two = buffer.getWritePointer(1);
auto num_samples = buffer.getNumSamples();
update_verb(); update_verb();
verb.processStereo(buffer.getWritePointer(0), buffer.getWritePointer(1), verb.processStereo(channel_one, channel_two,
buffer.getNumSamples()); num_samples);
setup_filter();
filter_l->processSamples(channel_one, num_samples);
filter_r->processSamples(channel_two, num_samples);
for (auto i = 0; i < num_samples; i++) {
*buffer.getWritePointer(0, i) = (*buffer.getReadPointer(0, i)) * out->get();
*buffer.getWritePointer(1, i) = (*buffer.getReadPointer(1, i)) * out->get();
}
}
void ReverbAudioProcessor::setup_filter()
{
juce::IIRCoefficients coef = juce::IIRCoefficients();
if (lofi) {
filter_l->setCoefficients(coef.makeBandPass(sample_rate, tone_val->get() * 24000));
filter_r->setCoefficients(coef.makeBandPass(sample_rate, tone_val->get() * 24000));
} else {
if (tone_val->get() == 0.5) {
filter_l->makeInactive();
filter_r->makeInactive();
} else {
filter_l->makeInactive();
filter_r->makeInactive();
}
}
} }
//============================================================================== //==============================================================================
@ -203,6 +235,7 @@ void ReverbAudioProcessor::getStateInformation (juce::MemoryBlock& destData)
stream.writeFloat(*freezeMode); stream.writeFloat(*freezeMode);
stream.writeBool(*lofi); stream.writeBool(*lofi);
stream.writeFloat(*tone_val); stream.writeFloat(*tone_val);
stream.writeFloat(*out);
} }
void ReverbAudioProcessor::setStateInformation (const void* data, int sizeInBytes) void ReverbAudioProcessor::setStateInformation (const void* data, int sizeInBytes)
@ -215,6 +248,7 @@ void ReverbAudioProcessor::setStateInformation (const void* data, int sizeInByte
freezeMode->setValueNotifyingHost(stream.readFloat()); freezeMode->setValueNotifyingHost(stream.readFloat());
lofi->setValueNotifyingHost(stream.readBool()); lofi->setValueNotifyingHost(stream.readBool());
tone_val->setValueNotifyingHost(stream.readFloat()); tone_val->setValueNotifyingHost(stream.readFloat());
out->setValueNotifyingHost(stream.readFloat());
} }
//============================================================================== //==============================================================================

View File

@ -54,7 +54,7 @@ public:
void setStateInformation (const void* data, int sizeInBytes) override; void setStateInformation (const void* data, int sizeInBytes) override;
void update_verb(); void update_verb();
void setup_filter();
private: private:
@ -68,10 +68,13 @@ private:
juce::AudioParameterBool* lofi; juce::AudioParameterBool* lofi;
juce::AudioParameterFloat* tone_val; juce::AudioParameterFloat* tone_val;
juce::AudioParameterFloat* out;
juce::Reverb verb; juce::Reverb verb;
juce::Reverb::Parameters params; juce::Reverb::Parameters params;
juce::IIRFilter filter; juce::IIRFilter* filter_l;
juce::IIRFilter* filter_r;
//============================================================================== //==============================================================================
JUCE_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR (ReverbAudioProcessor) JUCE_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR (ReverbAudioProcessor)
}; };