VideoFrame
        
        
          
                Baseline
                
                  2024
                
                 *
              
        
        Newly available
        
          
                
              
                
              
                
              
        
        
      
      Since September 2024, this feature works across the latest devices and browser versions. This feature might not work in older devices or browsers.
* Some parts of this feature may have varying levels of support.
Note: This feature is available in Dedicated Web Workers.
The VideoFrame interface of the Web Codecs API represents a frame of a video.
VideoFrame is a transferable object.
Description
A VideoFrame object can be created or accessed in a number of ways. The MediaStreamTrackProcessor breaks a media track into individual VideoFrame objects.
A VideoFrame is an image source and has a constructor that accepts any other canvas source (
an SVGImageElement,
an HTMLVideoElement,
an HTMLCanvasElement,
an ImageBitmap,
an OffscreenCanvas,
or another VideoFrame).
This means that a frame can be created from an image or video element.
A second constructor enables the creation of a VideoFrame from its binary pixel representation in an ArrayBuffer, a TypedArray, or a DataView.
Created frames may then turned into a media track, for example with the MediaStreamTrackGenerator interface that creates a media track from a stream of frames.
Constructor
- VideoFrame()
- 
Creates a new VideoFrameobject.
Instance properties
- VideoFrame.formatRead only
- 
Returns the pixel format of the VideoFrame.
- VideoFrame.codedWidthRead only
- 
Returns the width of the VideoFramein pixels, potentially including non-visible padding, and prior to considering potential ratio adjustments.
- VideoFrame.codedHeightRead only
- 
Returns the height of the VideoFramein pixels, potentially including non-visible padding, and prior to considering potential ratio adjustments.
- VideoFrame.codedRectRead only
- 
Returns a DOMRectReadOnlywith the width and height matchingcodedWidthandcodedHeight.
- VideoFrame.visibleRectRead only
- 
Returns a DOMRectReadOnlydescribing the visible rectangle of pixels for thisVideoFrame.
- VideoFrame.displayWidthRead only
- 
Returns the width of the VideoFramewhen displayed after applying aspect ratio adjustments.
- VideoFrame.displayHeightRead only
- 
Returns the height of the VideoFramewhen displayed after applying aspect ratio adjustments.
- VideoFrame.durationRead only
- 
Returns an integer indicating the duration of the video in microseconds. 
- VideoFrame.timestampRead only
- 
Returns an integer indicating the timestamp of the video in microseconds. 
- VideoFrame.colorSpaceRead only
- 
Returns a VideoColorSpaceobject.
- VideoFrame.flipRead only Experimental
- 
Returns whether the VideoFrameis horizontally mirrored.
- VideoFrame.rotationRead only Experimental
- 
Returns the rotation (0, 90, 180, or 270) in degrees clockwise applied to the VideoFrame. Arbitrary numbers (including negatives) are rounded to the next quarter turn.
Instance methods
- VideoFrame.allocationSize()
- 
Returns the number of bytes required to hold the VideoFrameas filtered by options passed into the method.
- VideoFrame.copyTo()
- 
Copies the contents of the VideoFrameto anArrayBuffer.
- VideoFrame.clone()
- 
Creates a new VideoFrameobject with reference to the same media resource as the original.
- VideoFrame.close()
- 
Clears all states and releases the reference to the media resource. 
Examples
In the following example frames are returned from a MediaStreamTrackProcessor, then encoded. See the full example and read more about it in the article Video processing with WebCodecs.
let frame_counter = 0;
const track = stream.getVideoTracks()[0];
const media_processor = new MediaStreamTrackProcessor(track);
const reader = media_processor.readable.getReader();
while (true) {
  const result = await reader.read();
  if (result.done) break;
  let frame = result.value;
  if (encoder.encodeQueueSize > 2) {
    // Too many frames in flight, encoder is overwhelmed
    // let's drop this frame.
    frame.close();
  } else {
    frame_counter++;
    const insert_keyframe = frame_counter % 150 === 0;
    encoder.encode(frame, { keyFrame: insert_keyframe });
    frame.close();
  }
}
Specifications
| Specification | 
|---|
| WebCodecs> # videoframe-interface> | 
Browser compatibility
Loading…