Я пишу плагин сверточной реверберации и хочу добавить ползунок предварительной задержки. У меня есть сигнал «Сухой» и «Влажный» в двух отдельных буферах для воспроизведения, как показано в коде ниже:
// copy the original signal into a "dry signal" buffer that we'll use later
AudioSampleBuffer dryBuffer(buffer.getNumChannels(), buffer.getNumSamples());
// now apply convolution to the buffer
for (int i = 0; i < buffer.getNumChannels(); ++i)
{
float* writePointer = buffer.getWritePointer (i % getNumOutputChannels());
const float* readPointer = buffer.getReadPointer (i % getNumInputChannels());
dryBuffer.copyFrom(
i, // destChannel
0, //destStartSample
buffer, // sourceBuffer
i, // sourceChannel
0, // sourceStartSample,
buffer.getNumSamples()
);
convolvers.getUnchecked(i % convolvers.size())->process (readPointer, writePointer, buffer.getNumSamples());
//WET MIX
buffer.applyGain(i, // channel
0, // startSample
buffer.getNumSamples(),
wetLevel->getValue() // gain
);
//DRY MIX
dryBuffer.applyGain(i,
0,
dryBuffer.getNumSamples(),
dryLevel->getValue()
);
buffer.addFrom(
i, // destChannel
0, // destStartSample
dryBuffer, // sourceBuffer
i, // sourceChannel
0, // soucreStartSample,
buffer.getNumSamples(),
1.0 // gain
);
}
dryBuffer — это сухой AudioSampleBuffer, а буфер — это обработанный сигнал с примененной сверткой. Как я могу отложить воспроизведение влажного буфера?