ConstantSourceNode interface—part of the Web Audio API—represents an audio source (based upon
AudioScheduledSourceNode) whose output is single unchanging value. This makes it useful for cases in which you need a constant value coming in from an audio source. In addition, it can be used like a constructible
AudioParam by automating the value of its
offset or by connecting another node to it; see Controlling multiple parameters with ConstantSourceNode.
ConstantSourceNode has no inputs and exactly one monaural (one-channel) output. The output's value is always the same as the value of the
|Number of inputs||
|Number of outputs||
In the article Controlling multiple parameters with ConstantSourceNode, a
ConstantSourceNode is created to allow one slider control to change the gain on two
GainNodes. The three nodes are set up like this:
gainNode2 = context.createGain(); gainNode3 = context.createGain(); gainNode2.gain.value = gainNode3.gain.value = 0.5; volumeSliderControl.value = gainNode2.gain.value; constantNode = context.createConstantSource(); constantNode.connect(gainNode2.gain); constantNode.connect(gainNode3.gain); constantNode.start(); gainNode2.connect(context.destination); gainNode3.connect(context.destination);
This code starts by creating the gain nodes and setting them and the volume control that will adjust their value all to 0.5. Then the
ConstantSourceNode is created by calling
AudioContext.createConstantSource(), and the gain parameters of each of the two gain nodes are connected to the
ConstantSourceNode. After starting the constant source by calling its
start() method. Finally, the two gain nodes are connected to the audio destination (typically speakers or headphones).
Now, whenever the value of
constantNode.offset changes, the gain on both
gainNode3 will change to have that same value.
To see this example in action, as well as to read the rest of the code from which these snippets were derived, see Controlling multiple parameters with ConstantSourceNode.
|Web Audio API |
BCD tables only load in the browser