- 7 stereo output buses: Main, Kick, Snare, HiHat, Toms, Cymbals, Perc - Each pad pre-assigned to appropriate bus (configurable via outputBus) - Pads route to assigned bus if active, fallback to Main if not - Master FX (limiter) applied to Main bus only - isBusesLayoutSupported: Main must be stereo, aux can be stereo or disabled - All buses enabled by default for REAPER multi-output detection - VU meter: switched from RMS to peak measurement (getMagnitude) - VU meter: sqrt scaling for better visibility on transient material - VU meter: removed distracting dB scale markers - VU meter: fast attack / medium release smoothing - README updated with multi-output routing section Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
79 sor
2.7 KiB
C++
79 sor
2.7 KiB
C++
#pragma once
|
|
#include <JuceHeader.h>
|
|
#include "DrumPad.h"
|
|
|
|
class InstaDrumsProcessor : public juce::AudioProcessor
|
|
{
|
|
public:
|
|
static constexpr int defaultNumPads = 12;
|
|
static constexpr int maxPads = 64;
|
|
|
|
InstaDrumsProcessor();
|
|
~InstaDrumsProcessor() override;
|
|
|
|
void prepareToPlay (double sampleRate, int samplesPerBlock) override;
|
|
void releaseResources() override;
|
|
void processBlock (juce::AudioBuffer<float>&, juce::MidiBuffer&) override;
|
|
|
|
juce::AudioProcessorEditor* createEditor() override;
|
|
bool hasEditor() const override { return true; }
|
|
|
|
const juce::String getName() const override { return JucePlugin_Name; }
|
|
bool acceptsMidi() const override { return true; }
|
|
bool producesMidi() const override { return true; }
|
|
bool isBusesLayoutSupported (const BusesLayout& layouts) const override;
|
|
double getTailLengthSeconds() const override { return 0.0; }
|
|
|
|
// Output bus names
|
|
static constexpr int numOutputBuses = 7;
|
|
static const char* const outputBusNames[numOutputBuses];
|
|
|
|
int getNumPrograms() override { return 1; }
|
|
int getCurrentProgram() override { return 0; }
|
|
void setCurrentProgram (int) override {}
|
|
const juce::String getProgramName (int) override { return {}; }
|
|
void changeProgramName (int, const juce::String&) override {}
|
|
|
|
void getStateInformation (juce::MemoryBlock& destData) override;
|
|
void setStateInformation (const void* data, int sizeInBytes) override;
|
|
|
|
// Pad management
|
|
int getNumPads() const { return numActivePads; }
|
|
DrumPad& getPad (int index) { return pads[index]; }
|
|
void addPads (int count = 4);
|
|
void loadSample (int padIndex, const juce::File& file);
|
|
|
|
juce::AudioFormatManager& getFormatManager() { return formatManager; }
|
|
|
|
DrumPad* findPadForNote (int midiNote);
|
|
|
|
// Kit management
|
|
void loadKitFromFolder (const juce::File& folder);
|
|
void saveKitPreset (const juce::File& file);
|
|
void loadKitPreset (const juce::File& file);
|
|
|
|
// Master FX parameters (read by editor from FxPanel/MasterPanel)
|
|
std::atomic<float> masterVolume { 1.0f };
|
|
std::atomic<float> masterPan { 0.0f };
|
|
std::atomic<float> masterTune { 0.0f };
|
|
|
|
// Master bus
|
|
std::atomic<bool> outputLimiterEnabled { true };
|
|
|
|
// VU meter levels (written by audio thread, read by GUI)
|
|
std::atomic<float> vuLevelL { 0.0f };
|
|
std::atomic<float> vuLevelR { 0.0f };
|
|
|
|
private:
|
|
std::array<DrumPad, maxPads> pads;
|
|
int numActivePads = defaultNumPads;
|
|
juce::AudioFormatManager formatManager;
|
|
|
|
double currentSampleRate = 44100.0;
|
|
|
|
void initializeDefaults();
|
|
void applyMasterFx (juce::AudioBuffer<float>& buffer);
|
|
|
|
JUCE_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR (InstaDrumsProcessor)
|
|
};
|