This is the sample code from a presentation on the basics of the Web Audio API. It was presented for the Nashville Music Programmers Meetup Group 2-27-2017.
-
High-level JavaScript API for processing audio in web apps.
-
Everything you need is right in your web browser!
-
The foundation of the Web Audio API is AudioContext();
-
Everything is created inside the AudioContext();
-
Inside the AudioContext, you create AudioNodes and connect them together, finally connecting them all to their destination, the speakers.
Think of each AudioNode as different guitar pedals (reverb, delay, flanger, etc), and the arrows as the guitar cords connecting each pedal to the next.
There can be as many or as few AudioNodes as you want.
Every AudioNode can connect to any other node as demonstrated in previous slides.
BUT, one of the awesome features of the Web Audio API is that any audioNode can connect to any other node’s Params.
Example?
You can connect the output of an oscillator Node (set to a low frequency) to a GainNode’s “gain” param to control volume of another sound source...as in a Tremolo effect.
Use an XMLHttpRequest (XHR) for getting sound files.
Audio file data is binary, so you assign the XHR’s ‘responseType’ to an ‘arraybuffer’.
An ArrayBuffer is a generic container for binary data. The buffer allows you to replay sounds repeatedly without needing to reload them.
Decode asynchronously using the AudioContext.decodeAudioData() method using JavaScript Promises.
Nick Chemsak
2-27-2017
GITHUB
github.com/nchemsak/WebAudioPresentation
github.com/nchemsak/eWaveStudio