Mediabunny is a JavaScript library for reading, writing, and converting media files (like MP4, WebM, MP3), directly in the browser. It aims to be a complete toolkit for high-performance media operations on the web. It's written from scratch in pure TypeScript, has zero dependencies, is very performant, and is extremely tree-shakable, meaning you only include what you use. You can think of it a bit like FFmpeg, but built from the ground up for the web.
Documentation | Examples | Sponsoring | License | Discord
Sponsor Mediabunny's development
Core features include:
- Wide format support: Read and write MP4, WebM, WAVE, MP3, Ogg, and more
- Built-in encoding & decoding: Supports 25+ video, audio, and subtitle codecs, hardware-accelerated using the WebCodecs API
- High precision: Fine-grained, microsecond-accurate reading and writing operations
- Conversion API: Easy-to-use API with features such as transmuxing, transcoding, resizing, rotation, resampling, trimming, and more
- Streaming I/O: Handle reading & writing files of any size with memory-efficient streaming
- Tree-shakable: Only bundle what you use (as small as 5 kB gzipped)
- Zero dependencies: Implemented in highly performant TypeScript
- Cross-platform: Works in browsers and Node.js
npm install mediabunny
Requires any JavaScript environment that can run ECMAScript 2021 or later. Mediabunny is expected to be run in modern browsers. For types, TypeScript 5.7 or later is required.
import { Input, ALL_FORMATS, BlobSource } from 'mediabunny';
const input = new Input({
source: new BlobSource(file), // Reading from disk
formats: ALL_FORMATS,
});
const duration = await input.computeDuration(); // in seconds
const videoTrack = await input.getPrimaryVideoTrack();
const audioTrack = await input.getPrimaryAudioTrack();
const { displayWidth, displayHeight, rotation } = videoTrack;
const { sampleRate, numberOfChannels } = audioTrack;
import { Output, Mp4OutputFormat, BufferTarget, CanvasSource, QUALITY_HIGH } from 'mediabunny';
const output = new Output({
format: new Mp4OutputFormat(),
target: new BufferTarget(), // Writing to memory
});
// Add a video track backed by a canvas element
const videoSource = new CanvasSource(canvas, {
codec: 'avc',
bitrate: QUALITY_HIGH,
});
output.addVideoTrack(videoSource);
await output.start();
// Add frames...
await output.finalize();
const buffer = output.target.buffer; // Final MP4 file
import { Input, Output, Conversion, ALL_FORMATS, BlobSource, WebMOutputFormat } from 'mediabunny';
const input = new Input({
source: new BlobSource(file),
formats: ALL_FORMATS,
});
const output = new Output({
format: new WebMOutputFormat(), // Convert to WebM
target: new BufferTarget(),
});
const conversion = await Conversion.init({ input, output });
await conversion.execute();
Visit the Docs for comprehensive guides, examples and API documentation.
Mediabunny is an open-source project released under the MPL-2.0 and is therefore free to use for any purpose, including closed-source commercial use. A permissive license is essential for a foundational library like this to truly thrive. That said, this project requires an immense amount of work and care to maintain and expand. This is made possible by the generous financial backing of the sponsors of this project.
If you have derived considerable value from this project, please consider sponsoring it or providing a one-time donation. Thank you! 🩷
This project is licensed under the Mozilla Public License 2.0. This is a very permissive weak copyleft license, not much different from the MIT License, allowing you to:
- Use Mediabunny for any purpose, commercial or non-commercial, without royalties
- Use Mediabunny in open- and closed-source projects
- Freely distribute projects built with Mediabunny
- Inspect and modify Mediabunny's source code
However, you have the following obligation:
- If you modify Mediabunny's licensed source code (e.g. in a fork) and then distribute it, you must publicly publish your modifications under the Mozilla Public License 2.0.
This ensures that library usage remains permissive for everybody, while any improvements to Mediabunny remain in the open, benefiting everyone.
You are not allowed to:
- Remove the license and copyright headers from any Mediabunny source file
- Claim the "Mediabunny" trademark
And finally, Mediabunny - like any other library - comes with no warranty of any kind and is not liable for any direct or indirect damages.
This is not legal advice. Refer to the full text of the Mozilla Public License 2.0 for the binding license agreement.
Mediabunny is implemented from scratch in pure TypeScript with zero dependencies. At its core, the library is a collection of multiplexers and demultiplexers (one for every container format), which are then connected together via abstractions around the WebCodecs API. The logic is heavily pipelined and lazy, keeping performance high and memory usage low. If this stuff interests you, refer to the Technical overview for more.
For development, clone this repository and install it using a modern version of Node.js and npm. The build system uses TypeScript, esbuild, API Extractor, Vite, and VitePress.
npm install # Install dependencies
npm run watch # Build bundles on watch mode
npm run build # Production build with type definitions
npm run check # Type checking
npm run lint # ESLint
npm run docs:dev # Start docs development server
npm run dev # Start examples development server
npm run docs:build # Build docs and examples