/* -*- Mode: IDL; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this file, * You can obtain one at http://mozilla.org/MPL/2.0/. * * The origin of this IDL file is * https://w3c.github.io/webcodecs/#videoframe */ enum AlphaOption { "keep", "discard", }; // [Serializable, Transferable] are implemented without adding attributes here. [Exposed=(Window,DedicatedWorker), Func="mozilla::dom::VideoFrame::PrefEnabled"] interface VideoFrame { // The constructors should be shortened to: // ``` // constructor(CanvasImageSource image, optional VideoFrameInit init = {}); // constructor(AllowSharedBufferSource data, VideoFrameBufferInit init); // ``` // but a `No support for unions as distinguishing arguments yet` error occurs // when using the CanvasImageSource and AllowSharedBufferSource unions // (bug 1786410). [Throws] constructor(HTMLImageElement imageElement, optional VideoFrameInit init = {}); [Throws] constructor(SVGImageElement svgImageElement, optional VideoFrameInit init = {}); [Throws] constructor(HTMLCanvasElement canvasElement, optional VideoFrameInit init = {}); [Throws] constructor(HTMLVideoElement videoElement, optional VideoFrameInit init = {}); [Throws] constructor(OffscreenCanvas offscreenCanvas, optional VideoFrameInit init = {}); [Throws] constructor(ImageBitmap imageBitmap, optional VideoFrameInit init = {}); [Throws] constructor(VideoFrame videoFrame, optional VideoFrameInit init = {}); [Throws] constructor([AllowShared] ArrayBufferView bufferView, VideoFrameBufferInit init); [Throws] constructor([AllowShared] ArrayBuffer buffer, VideoFrameBufferInit init); readonly attribute VideoPixelFormat? format; readonly attribute unsigned long codedWidth; readonly attribute unsigned long codedHeight; readonly attribute DOMRectReadOnly? codedRect; readonly attribute DOMRectReadOnly? visibleRect; readonly attribute unsigned long displayWidth; readonly attribute unsigned long displayHeight; readonly attribute unsigned long long? duration; // microseconds readonly attribute long long timestamp; // microseconds readonly attribute VideoColorSpace colorSpace; [Throws] unsigned long allocationSize( optional VideoFrameCopyToOptions options = {}); [Throws] Promise> copyTo( AllowSharedBufferSource destination, optional VideoFrameCopyToOptions options = {}); [Throws] VideoFrame clone(); undefined close(); }; dictionary VideoFrameInit { unsigned long long duration; // microseconds long long timestamp; // microseconds AlphaOption alpha = "keep"; // Default matches image. May be used to efficiently crop. Will trigger // new computation of displayWidth and displayHeight using image’s pixel // aspect ratio unless an explicit displayWidth and displayHeight are given. DOMRectInit visibleRect; // Default matches image unless visibleRect is provided. [EnforceRange] unsigned long displayWidth; [EnforceRange] unsigned long displayHeight; }; dictionary VideoFrameBufferInit { required VideoPixelFormat format; required [EnforceRange] unsigned long codedWidth; required [EnforceRange] unsigned long codedHeight; required [EnforceRange] long long timestamp; // microseconds [EnforceRange] unsigned long long duration; // microseconds // Default layout is tightly-packed. sequence layout; // Default visible rect is coded size positioned at (0,0) DOMRectInit visibleRect; // Default display dimensions match visibleRect. [EnforceRange] unsigned long displayWidth; [EnforceRange] unsigned long displayHeight; VideoColorSpaceInit colorSpace; }; dictionary VideoFrameCopyToOptions { DOMRectInit rect; sequence layout; VideoPixelFormat format; PredefinedColorSpace colorSpace; }; dictionary PlaneLayout { // TODO: https://github.com/w3c/webcodecs/pull/488 required [EnforceRange] unsigned long offset; required [EnforceRange] unsigned long stride; }; enum VideoPixelFormat { // 4:2:0 Y, U, V "I420", "I420P10", "I420P12", // 4:2:0 Y, U, V, A "I420A", "I420AP10", "I420AP12", // 4:2:2 Y, U, V "I422", "I422P10", "I422P12", // 4:2:2 Y, U, V, A "I422A", "I422AP10", "I422AP12", // 4:4:4 Y, U, V "I444", "I444P10", "I444P12", // 4:4:4 Y, U, V, A "I444A", "I444AP10", "I444AP12", // 4:2:0 Y, UV "NV12", // 4:4:4 RGBA "RGBA", // 4:4:4 RGBX (opaque) "RGBX", // 4:4:4 BGRA "BGRA", // 4:4:4 BGRX (opaque) "BGRX", };