The createChannelMerger()
method of the AudioContext
interface creates a ChannelMergerNode
, which combines channels from multiple audio streams into a single audio stream.
Syntax
var audioCtx = new AudioContext(); var merger = audioCtx.createChannelMerger(2);
Parameters
- numberOfInputs
- The number of channels in the input audio streams, which the output stream will contain; the default is 6 if this parameter is not specified.
Returns
Example
The following example shows how you could separate a stereo track (say, a piece of music), and process the left and right channel differently. To use them, you need to use the second and third parameters of the AudioNode.connect(AudioNode)
method, which allow you to specify both the index of the channel to connect from and the index of the channel to connect to.
var ac = new AudioContext(); ac.decodeAudioData(someStereoBuffer, function(data) { var source = ac.createBufferSource(); source.buffer = data; var splitter = ac.createChannelSplitter(2); source.connect(splitter); var merger = ac.createChannelMerger(2); // Reduce the volume of the left channel only var gainNode = ac.createGain(); gainNode.gain.value = 0.5; splitter.connect(gainNode, 0); // Connect the splitter back to the second input of the merger: we // effectively swap the channels, here, reversing the stereo image. gainNode.connect(merger, 0, 1); splitter.connect(merger, 1, 0); var dest = ac.createMediaStreamDestination(); // Because we have used a ChannelMergerNode, we now have a stereo // MediaStream we can use to pipe the Web Audio graph to WebRTC, // MediaRecorder, etc. merger.connect(dest); });
Specifications
Specification | Status | Comment |
---|---|---|
Web Audio API The definition of 'createChannelMerger()' in that specification. |
Working Draft |
Browser compatibility
Feature | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari (WebKit) |
---|---|---|---|---|---|
Basic support | 10.0webkit | 25.0 (25.0) | No support | 15.0webkit 22 (unprefixed) |
6.0webkit |
Feature | Android | Firefox Mobile (Gecko) | Firefox OS | IE Mobile | Opera Mobile | Safari Mobile | Chrome for Android |
---|---|---|---|---|---|---|---|
Basic support | ? | 26.0 | 1.2 | ? | ? | ? | 33.0 |
See also
Document Tags and Contributors
Tags:
Contributors to this page:
fseydel,
rolfedh,
PushpitaPikuDey,
deanmarano,
teoli,
anirudh_venkatesh,
chrisdavidmills
Last updated by:
fseydel,