This is the main object you use to interact with the waveform data. It provides access to the waveform data points and allows you to resample the data to display the waveform at zoom levels or fit to a given width.
It also allows you to create waveform data from audio content using the Web Audio API.
Creates and returns a WaveformData
instance from the given
data, which may be in binary (.dat) format in an
ArrayBuffer
,
or a JavaScript object. Refer to the
data format documentation
for details.
Name | Type |
---|---|
data |
ArrayBuffer |
To create a WaveformData
object from binary waveform data
(.dat format):
fetch('http://example.com/waveforms/track.dat')
.then(response => response.arrayBuffer())
.then(buffer => WaveformData.create(buffer))
.then(waveform => {
console.log(`Waveform has ${waveform.channels} channels`);
console.log(`Waveform has length ${waveform.length} points`);
});
To create a WaveformData
object from JSON format waveform
data:
fetch('http://example.com/waveforms/track.json')
.then(response => response.json())
.then(json => WaveformData.create(json))
.then(waveform => {
console.log(`Waveform has ${waveform.channels} channels`);
console.log(`Waveform has length ${waveform.length} points`);
});
Note that previous (v1.x) versions of waveform-data.js would accept JSON strings as input, but this is not supported from v2.0 onwards.
Creates a WaveformData
object from audio using the Web
Audio API.
Name | Type |
---|---|
options |
Object (see below) |
callback |
Function |
Name | Type |
---|---|
audio_context |
AudioContext |
array_buffer |
ArrayBuffer |
audio_buffer |
AudioBuffer |
scale |
Number (integer, default: 512) |
amplitude_scale |
Number (default: 1.0) |
split_channels |
Boolean (default: false) |
To create a WaveformData
object from audio content in an
ArrayBuffer
:
const audioContext = new AudioContext();
fetch('https://example.com/audio/track.ogg')
.then(response => response.arrayBuffer())
.then(buffer => {
const options = {
audio_context: audioContext,
array_buffer: buffer,
scale: 512
};
WaveformData.createFromAudio(options, (err, waveform) => {
if (err) {
console.error(err);
return;
}
console.log(`Waveform has ${waveform.channels} channels`);
console.log(`Waveform has length ${waveform.length} points`);
});
});
To create a WaveformData
object from an
AudioBuffer
:
const audioContext = new AudioContext();
const sampleRate = audioContext.sampleRate;
const audioBuffer = audioContext.createBuffer(2, sampleRate * 4, sampleRate);
// TODO: Fill audioBuffer with audio content (4 seconds)
const options = {
audio_buffer: audioBuffer
};
WaveformData.createFromAudio(options, (err, waveform) => {
if (err) {
console.error(err);
return;
}
console.log(`Waveform has ${waveform.channels} channels`);
console.log(`Waveform has length ${waveform.length} points`);
});
To create a WaveformData
object with multi-channel waveform
data:
const audioContext = new AudioContext();
fetch('https://example.com/audio/track.ogg')
.then(response => response.arrayBuffer())
.then(buffer => {
const options = {
audio_context: audioContext,
array_buffer: buffer,
scale: 512,
split_channels: true
};
WaveformData.createFromAudio(options, (err, waveform) => {
if (err) {
console.error(err);
return;
}
console.log(`Waveform has ${waveform.channels} channels`);
console.log(`Waveform has length ${waveform.length} points`);
});
});
Returns the sample rate of the original audio, in Hz.
const waveform = WaveformData.create(buffer);
console.log(waveform.sample_rate); // -> 44100
Returns the number of audio samples per pixel of the waveform data. This gives an indication of the zoom level (higher numbers mean lower resolution, i.e., more zoomed out).
const waveform = WaveformData.create(buffer);
console.log(waveform.scale); // -> 512
Returns the amount of time (in seconds) represented by a single pixel.
const waveform = WaveformData.create(buffer);
console.log(waveform.seconds_per_pixel); // -> 0.010666666666666666
Returns the number of pixels per second.
const waveform = WaveformData.create(buffer);
console.log(waveform.pixels_per_second); // -> 93.75
Returns the length of the waveform data, in pixels.
const waveform = WaveformData.create(buffer);
console.log(waveform.length); // -> 1000
Returns the approximate duration of the audio file, in seconds.
The duration is approximate because it is calculated based on the waveform length, number of samples per pixel, and audio sample rate.
const waveform = WaveformData.create(buffer);
console.log(waveform.duration); // -> 10.32
Returns the pixel index for a given time.
Name | Type |
---|---|
time |
Number (seconds) |
const waveform = WaveformData.create(buffer);
console.log(waveform.at_time(0.116)); // -> 10
Returns the time in seconds for a given pixel index.
Name | Type |
---|---|
index |
Number (integer) |
const waveform = WaveformData.create(buffer);
console.log(waveform.time(10)); // 0.116
Returns the number of waveform channels.
Note: by default, audiowaveform
combines all audio channels into a single channel waveform. Use the
--split-channels
command-line option if you want multi-channel waveforms.
const waveform = WaveformData.create(buffer);
console.log(waveform.channels); // 1
Returns a WaveformDataChannel
object that provides
access to the waveform data for the given channel index.
Name | Type |
---|---|
index |
Number (integer) |
const waveform = WaveformData.create(buffer);
for (let i = 0; i < waveform.channels; i++) {
const channel = waveform.channel(i);
}
Creates and returns a new WaveformData
object with resampled
data. Use this method to create waveform data at different zoom levels.
Name | Type |
---|---|
options | Object (see below) |
Name | Type |
---|---|
width |
Number (integer) |
scale |
Number (integer) |
To resample the waveform to fit to a specific width:
const waveform = WaveformData.create(buffer);
const resampledWaveform = waveform.resample({ width: 500 });
console.log(resampledWaveform.length); // -> 500
To resample the waveform to a specific zoom level, in samples per pixel:
const waveform = WaveformData.create(buffer);
const scale = waveform.scale; // -> 512
const resampledWaveform = waveform.resample({ scale: scale * 2 });
console.log(resampledWaveform.scale); // -> 1024
Note that you cannot resample to a lower number of samples per pixel than the original waveform.
const waveform = WaveformData.create(buffer);
const scale = waveform.scale; // -> 512
const resampledWaveform = waveform.resample({ scale: scale / 2 }); // throws an Error
You can resample a subset of the waveform, which is useful for performing fast animations involving a resampling per animation frame.
const waveform = WaveformData.create(buffer);
const resampledWaveform = waveform.resample({ width: 500, from: 0, to: 500 });
Concatenates the receiver with one or more other waveforms, returning a new
WaveformData
object.
The waveforms must be compatible objects (for instance, joining mono to stereo
waveforms is not supported).
Name | Type |
---|---|
...waveforms | One or more WaveformData instances |
To combine three waveforms into one long one:
const wave1 = WaveformData.create(buffer1);
const wave2 = WaveformData.create(buffer2);
const wave3 = WaveformData.create(buffer3);
const combinedResult = wave1.concat(wave2, wave3);
console.log(wave1.length); // -> 500
console.log(wave2.length); // -> 300
console.log(wave3.length); // -> 100
console.log(combinedResult.length); // -> 900
Returns the waveform minimum at the given index position.
Name | Type |
---|---|
index |
Number (integer) |
const waveform = WaveformData.create(buffer);
const channel = waveform.channel(0);
for (let i = 0; i < waveform.length; i++) {
const time = waveform.time(i);
const min = channel.min_sample(i);
const max = channel.max_sample(i);
console.log(time, min, max);
}
Returns the waveform maximum at the given index position.
Name | Type |
---|---|
index |
Number (integer) |
const waveform = WaveformData.create(buffer);
const channel = waveform.channel(0);
for (let i = 0; i < waveform.length; i++) {
const time = waveform.time(i);
const min = channel.min_sample(i);
const max = channel.max_sample(i);
console.log(time, min, max);
}
Returns all the waveform minimum values within the current offset, as an array.
const waveform = WaveformData.create(buffer);
const channel = waveform.channel(0);
console.log(waveform.length); // -> 3
const min = channel.min_array(); // -> [-7, -5, -10]
for (let i = 0; i < waveform.length; i++) {
console.log(min[i]);
}
Returns all the waveform maximum values within the current offset, as an array.
const waveform = WaveformData.create(buffer);
const channel = waveform.channel(0);
console.log(waveform.length); // -> 3
const max = channel.max_array(); // -> [7, 5, 10]
for (let i = 0; i < waveform.length; i++) {
console.log(max[i]);
}