wavesurfer.js

Navigable waveform built on Web Audio and Canvas

README

npm version
npm Join the chat at https://gitter.im/katspaugh/wavesurfer.js GitPOAP Badge

Interactive navigable audio visualization using Web Audio and Canvas.
Screenshot


Browser support

wavesurfer.js works only in modern browsers supporting Web Audio.

It will fallback to Audio Element without graphics in other browsers (IE 11 and lower).

FAQ

Can the audio start playing before the waveform is drawn?

Yes, if you use the backend: 'MediaElement' option. See here: https://wavesurfer-js.org/example/audio-element/. The audio will start playing as you press play. A thin line will be displayed until the whole audio file is downloaded and decoded to draw the waveform.

Can drawing be done as file loads?

No. Web Audio needs the whole file to decode it in the browser. You can however load pre-decoded waveform data to draw the waveform immediately. See here: https://wavesurfer-js.org/example/audio-element/ (the "Pre-recoded Peaks" section).

API in examples


Choose a container:
  1. ``` html
  2. <div id="waveform"></div>
  3. ```
Create an instance, passing the container selector and options:

  1. ``` js
  2. var wavesurfer = WaveSurfer.create({
  3.     container: '#waveform',
  4.     waveColor: 'violet',
  5.     progressColor: 'purple'
  6. });
  7. ```

Subscribe to some events:

  1. ``` js
  2. wavesurfer.on('ready', function () {
  3.     wavesurfer.play();
  4. });
  5. ```

Load an audio file from a URL:

  1. ``` js
  2. wavesurfer.load('example/media/demo.wav');
  3. ```

Documentation


See the documentation on all available methods, options and events on the homepage.

Upgrade


See the upgrade document if you're upgrading from a previous version of wavesurfer.js.

Using with a module bundler


Install Wavesurfer:
  1. ``` sh
  2. npm install wavesurfer.js --save
  3. # or
  4. yarn add wavesurfer.js
  5. ```

Use it with a module system like this:
  1. ``` js
  2. // import
  3. import WaveSurfer from 'wavesurfer.js';

  4. // commonjs/requirejs
  5. var WaveSurfer = require('wavesurfer.js');

  6. // amd
  7. define(['WaveSurfer'], function(WaveSurfer) {
  8.   // ... code
  9. });

  10. ```

Related projects


For a list of  projects using wavesurfer.js, check out

Development

Build Status Coverage Status
Size

Install development dependencies:

  1. ```
  2. npm install
  3. ```
Development tasks automatically rebuild certain parts of the library when files are changed (start – wavesurfer, start:plugins – plugins). Start a dev task and go to localhost:8080/example/ to test the current build.

Start development server for core library:

  1. ```
  2. npm run start
  3. ```

Start development server for plugins:

  1. ```
  2. npm run start:plugins
  3. ```

Build all the files. (generated files are placed in the dist directory.)

  1. ```
  2. npm run build
  3. ```

Running tests only:

  1. ```
  2. npm run test
  3. ```

Build documentation with esdoc (generated files are placed in the doc directory.)
  1. ```
  2. npm run doc
  3. ```

If you want to use the VS Code - Debugger for Chrome, there is already a launch.json with a properly configuredsourceMapPathOverrides for you.

Editing documentation

The homepage and documentation files are maintained in the [gh-pages branch](https://github.com/katspaugh/wavesurfer.js/tree/gh-pages). Contributions to the documentation are especially welcome.

Updating the NPM package

When preparing a new release, update the version in the package.json and have it merged to master. The new version of the package will be published to NPM automatically via GitHub Actions.

Credits


The main maintainer: [Thijs Triemstra](https://github.com/thijstriemstra)


License

License

This work is licensed under a