Skip to content

navana-tech/web-amr

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

web-amr

AMR audio codec is an audio compression format optimized for speech coding. Since AMR is not a supported web audio format, this library provides an implementation of AMR for use in the web.

Note: Currently this library only supports narrowband AMR.

Installation

# Using npm
npm install web-amr

# Using yarn
yarn add web-amr

# Using pnpm
pnpm add web-amr

Usage

import { AMRPlayer } from "web-amr";

const player = AMRPlayer(buffer); // pass file as ArrayBuffer

If the buffer failed to be decoded, player.error will be set. You can check for player.error?.message before proceeding.

The returned player instance implements a subset of the HTMLMediaElement API. Hence, you can use it as a drop-in for a real HTML5 audio player. It might be that this subset of APIs is all that you need from both; in that case, it's safe to do this:

import type { Player } from "web-amr";

// assume we have isAMR, audioElement, file,
// and a function "read" that returns ArrayBuffer

if (!isAMR) audioElement.src = file;
else audioElement.remove();

const player: Player = isAMR ? AMRPlayer(read(file)) : audioElement;

// use player normally

player.play();

Available methods

addEventListener

Appends an event listener for events. The callback argument sets the callback that will be invoked when the event is dispatched.

removeEventListener

Removes the event listener in target's event listener list with the same type and callback.

play: (): Promise<void>

Loads and starts playback of the AMR audio.

pause: (): Promise<void>

Pauses the current playback.

fastSeek: (seconds: number): Promise<void>

Sets the current playback position, in seconds.

Props

duration: number

Returns the duration in seconds of the current media resource. A NaN value is returned if duration is not available.

currentTime: number

Gets or sets the current playback position, in seconds.

readonly paused: boolean

Gets a flag that specifies whether playback is paused.

readonly ended: boolean

Gets information about whether the playback has ended or not.

readonly error: MediaError | null

Returns an object representing the current error state of the audio.

Contributing

Use pnpm as your package manager while installing dependencies. Make sure pnpm build runs without an error before raising a PR.

Acknowledgement

This project uses an emscripten build of OpenCORE-AMR from yxl.

Releases

No releases published

Packages

No packages published