Skip to content

Another rubberband-wasm story but with ready-to-use AudioWorklet and WebWorker

License

Notifications You must be signed in to change notification settings

delude88/rubberband-web

Repository files navigation

rubberband-web

A wasm-powered audio worklet using the Rubber Band library to provide pitch shifting for the Web Audio API.

Example

Checkout the example page here.

Usage

Add this package to your project using your favorite package manager:

npm install rubberband-web
# or
yarn add rubberband-web
# or
pnpm add rubberband-web

If you are using a framework using assets management (next.js, Angular, etc.), start by copying or linking this package's public/rubberband-processor.js into your public asset folder. In many cases you can also reference directly to the node_modules/rubberband-web/public/rubberband-processor.js.

Then use the helper function createRubberBandNode to create a worklet instance:

import { createRubberBandRealtimeNode } from 'rubberband-web';

const audioCtx = new AudioContext();
const sourceNode = new AudioBufferSourceNode(audioCtx); // or any source

const rubberBandNode = await createRubberBandRealtimeNode(
          audioCtx,
          '<public path to your rubberband-processor.js copy>'
        );

// Now you can do something like:
sourceNode.connect(rubberBandNode);
rubberBandNode.connect(audioCtx.destination);

// You can change the following parameters live at any time:
rubberBandNode.setPitch(1.2);
rubberBandNode.setTempo(0.6);
rubberBandNode.setHighQuality(true);

About

Another rubberband-wasm story but with ready-to-use AudioWorklet and WebWorker

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published