VideoFrame: copyTo() method
Limited availability
This feature is not Baseline because it does not work in some of the most widely-used browsers.
Note: This feature is available in Dedicated Web Workers.
The copyTo()
method of the VideoFrame
interface copies the contents of the VideoFrame
to an ArrayBuffer
.
Syntax
copyTo(destination)
copyTo(destination, options)
Parameters
destination
-
An
ArrayBuffer
, aTypedArray
, or aDataView
to copy to. options
Optional-
An object containing the following:
rect
Optional-
The rectangle of pixels to copy from the
VideoFrame
. If unspecified, thevisibleRect
will be used. This is in the format of a dictionary object containing:x
: The x-coordinate.y
: The y-coordinate.width
: The width of the frame.height
: The height of the frame.
layout
Optional-
A list containing the following values for each plane in the
VideoFrame
: format
Optional-
A pixel format for the pixel data in the
destination
. Can be set to"RGBA"
,"RGBX"
,"BGRA"
,"BGRX"
. If unspecified, theformat
will be used. colorSpace
Optional-
Specifies the color space of the pixel data in the
destination
. Can be set to"srgb"
for the sRGB color space or"display-p3"
for the display-p3 color space. Only applicable for RGB pixel formats. If unspecified,"srgb
will be used.
Return value
A Promise
that resolves to the layout of the copy when the copy has completed.
Examples
The following example copies the entire contents of videoFrame
.
let buffer = new Uint8Array(videoFrame.allocationSize());
let layout = await videoFrame.copyTo(buffer);
The following example converts a portion of the videoFrame
to RGB format.
const videoRect = {
x: 100,
y: 100,
width: 80,
height: 60,
};
const options = {
rect: videoRect,
format: "RGBX",
colorSpace: "display-p3",
};
const size = videoFrame.allocationSize(options);
const buffer = new ArrayBuffer(size);
const layout = await videoFrame.copyTo(buffer, options);
Specifications
Specification |
---|
WebCodecs # dom-videoframe-copyto |