docs.rodeo

MDN Web Docs mirror

ScriptProcessorNode

{{APIRef("Web Audio API")}} {{Deprecated_Header}} 

The ScriptProcessorNode interface allows the generation, processing, or analyzing of audio using JavaScript.

{{InheritanceDiagram}} 

[!NOTE] This feature was replaced by AudioWorklets and the {{domxref("AudioWorkletNode")}}  interface.

The ScriptProcessorNode interface is an {{domxref("AudioNode")}}  audio-processing module that is linked to two buffers, one containing the input audio data, one containing the processed output audio data. An event, implementing the {{domxref("AudioProcessingEvent")}}  interface, is sent to the object each time the input buffer contains new data, and the event handler terminates when it has filled the output buffer with data.

The ScriptProcessorNode stores the input in a buffer, send the audioprocess event. The EventHandler takes the input buffer and fill the output buffer which is sent to the output by the ScriptProcessorNode.

The size of the input and output buffer are defined at the creation time, when the {{domxref("BaseAudioContext.createScriptProcessor")}}  method is called (both are defined by {{domxref("BaseAudioContext.createScriptProcessor")}} 's bufferSize parameter). The buffer size must be a power of 2 between 256 and 16384, that is 256, 512, 1024, 2048, 4096, 8192 or 16384. Small numbers lower the latency, but large number may be necessary to avoid audio breakup and glitches.

If the buffer size is not defined, which is recommended, the browser will pick one that its heuristic deems appropriate.

Number of inputs 1
Number of outputs 1
Channel count mode "max"
Channel count 2 (not used in the default count mode)
Channel interpretation "speakers"

Instance properties

Inherits properties from its parent, {{domxref("AudioNode")}} .

Instance methods

No specific methods; inherits methods from its parent, {{domxref("AudioNode")}} .

Events

Listen to these events using addEventListener() or by assigning an event listener to the oneventname property of this interface:

Examples

See BaseAudioContext.createScriptProcessor() for example code.

Specifications

Since the August 29, 2014 Web Audio API specification publication, this feature has been deprecated. It is no longer on track to become a standard.

It was replaced by AudioWorklets and the {{domxref("AudioWorkletNode")}}  interface.

Browser compatibility

{{Compat}} 

See also

In this article

View on MDN