Skip to main content

Class: FFmpeg

Provides APIs to interact with ffmpeg web worker.

Example

const ffmpeg = new FFmpeg();

Constructors

constructor

new FFmpeg()

Properties

#logEventCallbacks

Private #logEventCallbacks: LogEventCallback[] = []

Defined in

classes.ts:37


#progressEventCallbacks

Private #progressEventCallbacks: ProgressEventCallback[] = []

Defined in

classes.ts:38


#rejects

Private #rejects: Callbacks = {}

Defined in

classes.ts:35


#resolves

Private #resolves: Callbacks = {}

#resolves and #rejects tracks Promise resolves and rejects to be called when we receive message from web worker.

Defined in

classes.ts:34


#worker

Private #worker: null | Worker = null

Defined in

classes.ts:29


loaded

loaded: boolean = false

Defined in

classes.ts:40

FFmpeg Methods

exec

exec(args, timeout?): Promise<number>

Execute ffmpeg command.

Remarks

To avoid common I/O issues, ["-nostdin", "-y"] are prepended to the args by default.

Example

const ffmpeg = new FFmpeg();
await ffmpeg.load();
await ffmpeg.writeFile("video.avi", ...);
// ffmpeg -i video.avi video.mp4
await ffmpeg.exec(["-i", "video.avi", "video.mp4"]);
const data = ffmpeg.readFile("video.mp4");

Parameters

NameTypeDefault valueDescription
argsstring[]undefinedffmpeg command line args
timeoutnumber-1milliseconds to wait before stopping the command execution. Default Value -1

Returns

Promise<number>

0 if no error, != 0 if timeout (1) or error.

Defined in

classes.ts:197


load

load(config?): Promise<boolean>

Loads ffmpeg-core inside web worker. It is required to call this method first as it initializes WebAssembly and other essential variables.

Parameters

NameType
configFFMessageLoadConfig

Returns

Promise<boolean>

true if ffmpeg core is loaded for the first time.

Defined in

classes.ts:164


off

off(event, callback): void

Unlisten to log or prgress events from ffmpeg.exec().

Parameters

NameType
event"log"
callbackLogEventCallback

Returns

void

Defined in

classes.ts:144

off(event, callback): void

Parameters

NameType
event"progress"
callbackProgressEventCallback

Returns

void

Defined in

classes.ts:145


on

on(event, callback): void

Listen to log or prgress events from ffmpeg.exec().

Example

ffmpeg.on("log", ({ type, message }) => {
// ...
})

Example

ffmpeg.on("progress", ({ progress, time }) => {
// ...
})

Remarks

  • log includes output to stdout and stderr.
  • The progress events are accurate only when the length of input and output video/audio file are the same.

Parameters

NameType
event"log"
callbackLogEventCallback

Returns

void

Defined in

classes.ts:126

on(event, callback): void

Parameters

NameType
event"progress"
callbackProgressEventCallback

Returns

void

Defined in

classes.ts:127


terminate

terminate(): void

Terminate all ongoing API calls and terminate web worker. FFmpeg.load() must be called again before calling any other APIs.

Returns

void

Defined in

classes.ts:218


File System Methods

createDir

createDir(path): Promise<boolean>

Create a directory.

Parameters

NameType
pathstring

Returns

Promise<boolean>

Defined in

classes.ts:316


deleteDir

deleteDir(path): Promise<boolean>

Delete an empty directory.

Parameters

NameType
pathstring

Returns

Promise<boolean>

Defined in

classes.ts:338


deleteFile

deleteFile(path): Promise<boolean>

Delete a file.

Parameters

NameType
pathstring

Returns

Promise<boolean>

Defined in

classes.ts:294


listDir

listDir(path): Promise<FSNode[]>

List directory contents.

Parameters

NameType
pathstring

Returns

Promise<FSNode[]>

Defined in

classes.ts:327


readFile

readFile(path, encoding?): Promise<FileData>

Read data from ffmpeg.wasm.

Example

const ffmpeg = new FFmpeg();
await ffmpeg.load();
const data = await ffmpeg.readFile("video.mp4");

Parameters

NameTypeDefault valueDescription
pathstringundefined-
encodingstring"binary"File content encoding, supports two encodings: - utf8: read file as text file, return data in string type. - binary: read file as binary file, return data in Uint8Array type. Default Value binary

Returns

Promise<FileData>

Defined in

classes.ts:273


rename

rename(oldPath, newPath): Promise<boolean>

Rename a file or directory.

Parameters

NameType
oldPathstring
newPathstring

Returns

Promise<boolean>

Defined in

classes.ts:305


writeFile

writeFile(path, data): Promise<boolean>

Write data to ffmpeg.wasm.

Example

const ffmpeg = new FFmpeg();
await ffmpeg.load();
await ffmpeg.writeFile("video.avi", await fetchFile("../video.avi"));
await ffmpeg.writeFile("text.txt", "hello world");

Parameters

NameType
pathstring
dataFileData

Returns

Promise<boolean>

Defined in

classes.ts:247


Other Methods

#registerHandlers

Private #registerHandlers(): void

register worker message event handlers.

Returns

void

Defined in

classes.ts:45


#send

Private #send(__namedParameters, trans?): Promise<CallbackData>

Generic function to send messages to web worker.

Parameters

NameTypeDefault value
__namedParametersMessageundefined
transTransferable[][]

Returns

Promise<CallbackData>

Defined in

classes.ts:86