Secure context: This feature is available only in secure contexts (HTTPS), in some or all supporting browsers.
The configure() method of the VideoDecoder interface enqueues a control message to configure the video decoder for decoding chunks.
Secure context: This feature is available only in secure contexts (HTTPS), in some or all supporting browsers.
The configure() method of the VideoDecoder interface enqueues a control message to configure the video decoder for decoding chunks.
js
configure(config)
configAn object containing the following members:
codecA string containing a valid codec string. See "codecs" parameter for details on codec string construction.
description Optional
An ArrayBuffer, a TypedArray, or a DataView containing a sequence of codec specific bytes, commonly known as extradata.
codedWidth Optional
An integer representing the width of the VideoFrame in pixels, including any non-visible padding, before any ratio adjustments.
codedHeight Optional
An integer representing the height of the VideoFrame in pixels, including any non-visible padding, before any ratio adjustments.
displayAspectWidth Optional
An integer representing the horizontal dimension of the VideoFrame in pixels when displayed.
displayAspectHeight Optional
An integer representing the vertical dimension of the VideoFrame in pixels when displayed.
colorSpaceAn object representing a VideoColorSpace, containing the following members:
primariesA string representing the color gamut of the video sample. One of:
"bt709""bt470bg""smpte170m"transferA string representing transfer characteristics. One of:
"bt709""smpte170m""iec61966-2-1"matrixA string representing a matrix coefficient. One of:
"rgb""bt709""bt470bg""smpte170m"hardwareAccelerationA hint as to the hardware acceleration method to use. One of:
"no-preference""prefer-hardware""prefer-software"optimizeForLatencyA boolean. If true this is a hint that the selected decoder should be optimized to minimize the number of EncodedVideoChunk objects that have to be decoded before a VideoFrame is output.
Note: The registrations in the WebCodecs Codec Registry link to a specification detailing whether and how to populate the optional description member.
None (undefined).
TypeErrorThrown if the provided config is invalid.
InvalidStateError DOMException
Thrown if the state is "closed".
NotSupportedError DOMException
Thrown if the provided config is valid but the user agent cannot provide a codec that can decode this profile.
The following example creates a new VideoDecoder and configures it with the "vp8" codec, a codedWidth of 640 pixels and a codedHeight of 480 pixels.
js
const init = { output: handleFrame, error: (e) => { console.log(e.message); }, }; const config = { codec: "vp8", codedWidth: 640, codedHeight: 480, }; let decoder = new VideoDecoder(init); decoder.configure(config);
| Specification | 
|---|
| WebCodecs  # dom-videodecoder-configure  | 
| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Internet Explorer | Opera | Safari | WebView Android | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | |
configure | 
94 | 94 | No | No | 80 | 16.4 | 94 | 94 | No | 66 | 16.4 | 17.0 | 
    © 2005–2023 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
    https://developer.mozilla.org/en-US/docs/Web/API/VideoDecoder/configure