/audio-context-router

🎧 Simple multi-channel audio playback, routing, and manipulation with Web Audio.

Primary LanguageJavaScriptOtherNOASSERTION

audio-context-router

Simple multi-channel audio playback, routing, and manipulation with Web Audio.

Features

  • Easy playback of remote and local MediaStream objects
  • Designed to allow for multiple tracks per user-group
  • Simple channel-specific gain controls
  • Supports easy insertion of additonal AudioNode objects

Getting Started

Note: This hasn't been published yet

import Audio from 'audio-context-router';

Setting the configuration:

Audio.setConfiguration({
  input: {
    channels: 2
  },
  output: {
    channels: 2
  }
});

Note: In most cases this doesn't need to be called because Chromium only supports stereo (2-channel) inputs and outputs, however hacks can be used to introduce multi-channel support (Learn more).

Starting audio playback (connecting the graph):

const audio = Audio.addInstance('james', 'guitar');
const stream = new MediaStream();

// Set stream via any source
audio.setStream(stream);

// Playback audio
audio.play();

Simple Playback Note: If a remote stream is being supplied (eg. via WebRTC), you'll likely need to use the useAudioElement option when calling addInstance. This is because Chromium has issues with remote streams and the Web Audio API (Learn More).

Stopping audio playback:

const audio = Audio.getInstance('james', 'guitar');

// Disconnect gains from merger to stop audio
audio.stop();

Simple Stop Playback

Disconnecting audio graph instance:

const audio = Audio.getInstance('james', 'guitar');

// Disconnect and clear audio graph instance
audio.disconnect();

Adding & manipulating multiple tracks within a group:

const vocals = Audio.addInstance('james', 'vocals');
const synth = Audio.addInstance('james', 'synth');

vocals.setStream(vocalsStream);
synth.setStream(synthStream);

vocals.play();
synth.play();

vocals.setGain(0.7);
synth.setGain(1.2);

Audio Group diagram

Modifying audio gain (volume):

const audio = Audio.getInstance('james', 'guitar');

// Set gain of all channels to 50%
audio.setGain(0.5);

// Set gain of right channel
audio.setGain(0.5, 2);

Audio gain diagram

Muting audio by channel:

const audio = Audio.getInstance('james', 'guitar');

// Mute R channel
audio.mute(2);

// Later... Unmute R channel
audio.unmute(2);

Getting an AudioNode:

const graph = Audio.getInstance('james', 'guitar');

const audioNode = graph.getNode('splitter');

Note: By default, all graphs contain source, splitter, merger, and [gain] nodes however this method can also be used to retrieve custom nodes.

Adding custom AudioNode into the graph:

const graph = Audio.getInstance('james', 'guitar');
const context = Audio.getContext();

const source = graph.getNode('source');
const analyser = context.createAnalyser();

// ... draw stuff using analyser data

source.connect(analyser);

Analyzer Node

Isolate single channel from MediaStream object:

const stereoStream = new MediaStream();
const monoStream = Audio.getChannelStream(stereoStream, 2);

// ... Do something with new mono stream

Documentation

API

// AudioRouter
setConfiguration(config)
addInstance(groupId, trackId, useAudioElement): AudioGraph
getInstanceGroup(groupId): [AudioGraph]
getInstance(groupId, trackId): AudioGraph
getContext(): AudioContext
getChannelStream(stream, channel): MediaStream

// AudioGraph
getInputChannels(): [number]
getOutputChannels(): [number]
getNode(key, channel): AudioNode
setNode(key, node, channel): AudioNode
setStream(stream)
setGain(value, channel)
play(channel)
stop(channel)
mute(channel)
unmute(channel)
disconnect()

License

audio-context-router (c) by Jaden Dessureault

audio-context-router is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.