Sonorous.js is a JavaScript audio library that streamlines working with web audio, enabling easy audio integration into web apps and games. As an abstraction over the WebAudio APIs, Sonorous.js offers fine-grained control for those who need it, while handling any cross-browser issues for you.
See the repo's examples/ directory for the source code.
To get started, run npm install --save sonorous.
To use Sonorous.js, require it or import it into your file.
ES6
import Sonorous from 'sonorous';
CommonJS
const Sonorous = require('sonorous');
Sonorous is a manager that handles the addition and removal of sonors. A sonor can be thought of as a wrapper over one audio file. Each sonor has its own functionality, like play(), pause(), volume, etc. You can also set global properties (masterVolume, muteAll, etc) on all sonors via the Sonorous instance.
Example:
let mySonor = Sonorous.addSonor('./test_audio/test_sound_1.mp3');
mySonor.play(); // begins to play test_sound_1.mp3
mySonor.volume = 0.5; // sets the volume of the sonor to 0.5
Sonorous.muteAll = true; // mutes all sonors
mySonor.stop(); // stops the playback of test_sound_1.mp3
Please see the API section for more details.
Sonorous is a singleton, and will manage all the Sonor objects.
Array of all the Sonor objects added to this manager.
ctx : AudioContext (read only)
Returns the current audio context used by Sonorous.
This is a read/write property and is connected to the masterGain node, that will set the volume for all Sonor objects. Valid values are between 0 and 1.
This is a read/write property that will mute/unmute all Sonor objects.
returns true if WebAudio is supported, false if not.
creates a Sonor object and returns it, if successful.
| Param | Type | Description | 
|---|---|---|
| src | string,string[],SonorSrc,SonorSrc[] | The media this sound is associated with. If you pass in an array of various formats, it will take the first one that works with the current browser. If your source url does not have an extension, you can specify that manually using the SonorSrc object defined below. | 
| options | object | Optional configuration object. See options below. | 
Configuration Options for addSonor():
| Option | Type | Default | Description | 
|---|---|---|---|
| id | string | randomly generated | A unique ID. One will be created for this object if you do not pass one in. | 
| preload | boolean | true | Will attempt to load url automatically if true. If false, the calling code must call load()explicitly. | 
| volume | number | 1.0 | The initial volume of the sound. | 
| loop | boolean | false | Determine if the audio should loop forever. | 
| autoplay | boolean | false | Determine if the audio should play immediately on load. | 
| muted | boolean | false | Mute once loaded. | 
| poolSize | number | 1 | The total number of audio segments available to play. Increasing this number allows you to start concurrently playing the same sound multiple times, before the initial playthrough has finished. | 
| optimizeFor | string | 'time' | Can either be 'time'or'memory'. This determines if the decoded buffer will be cached or not. By default, it will be. If memory is a concern, then set this to 'memory' and expect a small delay while we decode the buffer before playback can begin. | 
| Property | Type | Description | 
|---|---|---|
| url | string | The source url for the audio, without an extension. | 
| format | string | The manually specified format for this audio source. | 
Example:
let mySonor = Sonorous.addSonor('./test_audio/test_sound_1.mp3', {
    id: 'myFirstSonor', 
    preload: false,
    volume: 0.5,
    poolSize: 3 });
let testSoundSonor = Sonorous.addSonor(
    {
        url: './test_audio/test_sound_2',
        format: 'mp3'
    }, 
    { id: 'test_sound_2'});
removes a Sonor object from the manager. This will unload and destroy the sound, and immediately stop all processes related to this sound.
removes any existing sonor objects and resets the audio context.
destroys all Sonor objects
return a Sonor object
Example:
Sonorous.addSonor('./test_audio/test_sound_1.mp3', { id: 'mySonorId'});
let mySonor = Sonorous.get('mySonorId');
return true if Sonorous has a Sonor matching the passed in id
will trigger when the audio is unlocked (via user interaction with the page). Some browsers do not allow playback of audio before a user has interacted with the page in some way. This event will trigger once the audio is free to play.
This module contains most of the functionality for controlling a sound, including adjusting volume, playing, pausing, etc. If the AudioContext has not been unlocked (via a user gesture, etc), all actions will go into a queue. These actions will be immediately executed as soon as the AudioContext is unlocked and the buffer has been loaded.
A read-only property that returns the unique ID for this sound object. The id is optionally provided during initialization (see Sonorous's addSonor() for more information). If no ID is provided during initialization, a randomly generated alphanumeric string will be assigned as the id. Sonorous can retrieve Sonor objects by id, using the Sonorous.get(id) function.
Returns the url for the source audio of this object.
Returns true if the sonor was set to preload during initialization.
Reflects the loaded state of the sonor. Can either be 'loading', 'loaded', or 'unloaded'.
Example:
let mySonor = Sonorous.addSonor('./test_audio/test_sound_1.mp3', { preload: false });
console.log(mySonor.state); // prints out 'unloaded'
mySonor.load();
console.log(mySonor.state); // prints out 'loading'
Returns the duration of the sonor. Note that this value will only be available when a sonor is loaded. If the sonor is unloaded, this will return 0.
Returns true if the sound is currently playing, false if not.
Returns how far into playback the sound is. If poolSize > 1, the first active audio segment will be used to return this value.
A read/write public property that controls the number of total audio segments in the pool. Increase the size of the pool if you would like to start playing the same sound concurrently. Defaults to 1.
Once the pool size has increased, the setters/getters will behave as follows: Any setter will be applied to all active segments. Any getter will use the first active audio segment to return the information requested. (An "active segment" is one that has been pulled from the pool already, and is currently in use.)
Example:
let mySonor = Sonorous.addSonor('./test_audio/test_sound_1.mp3');
mySonor.poolSize = 2;
mySonor.play();
setTimeout(() => { mySonor.play(); }, 1000);  // will result in the same audio being played twice, with the second playback 1s behind the first one.
A read/write public property that controls the playback rate of this sound. If poolSize > 1, the first active audio segment will be used to return this value.
A read/write public property that controls if the sound will loop or not. When setting this property, it will apply to all active segments.
A read/write public property that controls the volume of this sound. When setting this property, it will apply to all active segments.
A read/write public property that controls if the sound is muted or not. When setting this property, it will apply to all active segments.
will play the audio source. If the sonor has not been loaded, it will load the sonor and play once loaded. If the pool of audio segments is greater than 1, then we pull segments from the pool as needed. An "active segment" is one that has been pulled from the pool already, and is currently in use. The logic for play is as follows:
if there are no active segments:
    retrieve one from the pool and play it.
if there are active segments:
    if none are currently playing:
        play all active segments
    else:
        retrieve/play a segment from the pool
if there are no available segments in the pool:
    do nothing and report an error
will pause all active audio segments, but not return them to the pool.
will stop all active audio segments and return them to the pool.
will fade the audio from the current volume to the targetVolume, for the fade duration provided. If a startTime is provided and is greater than the audioContext's current time, the fade will start at that point. Otherwise, it will start immediately. The fade duration should be in terms of seconds.
will move playback to the time passed in (in seconds).
will load the buffer and prepare an audio segment for playback.
will remove the buffer and return all active audio segments to the pool.
The Sonor object is an event emitter (on/off/once). See the list of available events below.
Will trigger when the sound is loaded
| Param | Type | Description | 
|---|---|---|
| sonorObj | Sonor | The instance of Sonor that was operated on | 
Will trigger when play begins
| Param | Type | Description | 
|---|---|---|
| sonorObj | Sonor | The instance of Sonor that was operated on | 
Will trigger when the sound pauses
| Param | Type | Description | 
|---|---|---|
| sonorObj | Sonor | The instance of Sonor that was operated on | 
Will trigger when the sound stops playing
| Param | Type | Description | 
|---|---|---|
| sonorObj | Sonor | The instance of Sonor that was operated on | 
Will trigger when the sound reaches the end of its duration
| Param | Type | Description | 
|---|---|---|
| sonorObj | Sonor | The instance of Sonor that was operated on | 
Will trigger when the currentTime has been changed manually
| Param | Type | Description | 
|---|---|---|
| sonorObj | Sonor | The instance of Sonor that was operated on | 
| seekPosition | Number | Timecode that the Sonor seeked to | 
Will trigger when the sound volume changes (via volume or mute)
| Param | Type | Description | 
|---|---|---|
| sonorObj | Sonor | The instance of Sonor that was operated on | 
| newVolume | Number | The new volume that the Sonor was set to | 
Will trigger when the playback rate changes
| Param | Type | Description | 
|---|---|---|
| sonorObj | Sonor | The instance of Sonor that was operated on | 
| newPlaybackRate | Number | The new playback rate that the Sonor was set to | 
Will trigger when the fade ends
| Param | Type | Description | 
|---|---|---|
| sonorObj | Sonor | The instance of Sonor that was operated on | 
Will trigger if any error occurs during a Sonor operation
| Param | Type | Description | 
|---|---|---|
| sonorObj | Sonor | The instance of Sonor that was operated on | 
| error | String | Error message | 
Once you have the repo locally, run yarn install to install dependencies.
- npm run buildwill build unminified versions of Sonorous.
- npm run build:productionwill build minified and gzipped versions of Sonorous.
- npm run start-devwill build unminified Sonorous and open a simple html page with audio controls. You can manually test most of the Sonorous functionality through there.
- npm run testwill run all unit tests. (Unit tests are written using Jest)
We actively welcome pull requests and proposed changes to the code base. Please follow these steps when contributing.
- Please fork and branch from develop, and follow the Developing Locally guide to get buildable.
- Comment your code extensively, and update the README when expected.
- Add unit tests where applicable.
- All existing testing suites must pass and no linter errors should occur.
Sonorous is supported wherever WebAudio is. Click here for a full list.



