This source file includes following definitions.
- process
- initialize
- uninitialize
- tailTime
- latencyTime
#include "config.h"
#if ENABLE(WEB_AUDIO)
#include "modules/webaudio/DynamicsCompressorNode.h"
#include "platform/audio/DynamicsCompressor.h"
#include "modules/webaudio/AudioContext.h"
#include "modules/webaudio/AudioNodeInput.h"
#include "modules/webaudio/AudioNodeOutput.h"
static const unsigned defaultNumberOfOutputChannels = 2;
namespace WebCore {
DynamicsCompressorNode::DynamicsCompressorNode(AudioContext* context, float sampleRate)
: AudioNode(context, sampleRate)
{
ScriptWrappable::init(this);
addInput(adoptPtr(new AudioNodeInput(this)));
addOutput(adoptPtr(new AudioNodeOutput(this, defaultNumberOfOutputChannels)));
setNodeType(NodeTypeDynamicsCompressor);
m_threshold = AudioParam::create(context, "threshold", -24, -100, 0);
m_knee = AudioParam::create(context, "knee", 30, 0, 40);
m_ratio = AudioParam::create(context, "ratio", 12, 1, 20);
m_reduction = AudioParam::create(context, "reduction", 0, -20, 0);
m_attack = AudioParam::create(context, "attack", 0.003, 0, 1);
m_release = AudioParam::create(context, "release", 0.250, 0, 1);
initialize();
}
DynamicsCompressorNode::~DynamicsCompressorNode()
{
uninitialize();
}
void DynamicsCompressorNode::process(size_t framesToProcess)
{
AudioBus* outputBus = output(0)->bus();
ASSERT(outputBus);
float threshold = m_threshold->value();
float knee = m_knee->value();
float ratio = m_ratio->value();
float attack = m_attack->value();
float release = m_release->value();
m_dynamicsCompressor->setParameterValue(DynamicsCompressor::ParamThreshold, threshold);
m_dynamicsCompressor->setParameterValue(DynamicsCompressor::ParamKnee, knee);
m_dynamicsCompressor->setParameterValue(DynamicsCompressor::ParamRatio, ratio);
m_dynamicsCompressor->setParameterValue(DynamicsCompressor::ParamAttack, attack);
m_dynamicsCompressor->setParameterValue(DynamicsCompressor::ParamRelease, release);
m_dynamicsCompressor->process(input(0)->bus(), outputBus, framesToProcess);
float reduction = m_dynamicsCompressor->parameterValue(DynamicsCompressor::ParamReduction);
m_reduction->setValue(reduction);
}
void DynamicsCompressorNode::initialize()
{
if (isInitialized())
return;
AudioNode::initialize();
m_dynamicsCompressor = adoptPtr(new DynamicsCompressor(sampleRate(), defaultNumberOfOutputChannels));
}
void DynamicsCompressorNode::uninitialize()
{
if (!isInitialized())
return;
m_dynamicsCompressor.clear();
AudioNode::uninitialize();
}
double DynamicsCompressorNode::tailTime() const
{
return m_dynamicsCompressor->tailTime();
}
double DynamicsCompressorNode::latencyTime() const
{
return m_dynamicsCompressor->latencyTime();
}
}
#endif