docs/src/api/class-screencast.md
Interface for capturing screencast frames from a page.
Starts the screencast. When [option: Screencast.start.path] is provided, it saves video recording to the specified file.
When [option: Screencast.start.onFrame] is provided, delivers JPEG-encoded frames to the callback. Both can be used together.
Usage
// Record video
await page.screencast.start({ path: 'video.webm', size: { width: 1280, height: 800 } });
// ... perform actions ...
await page.screencast.stop();
// Capture frames
await page.screencast.start({
onFrame: ({ data }) => console.log(`frame size: ${data.length}`),
size: { width: 800, height: 600 },
});
// ... perform actions ...
await page.screencast.stop();
onFrame <[function]([Object=ScreencastFrame]): [Promise]>
data <[Buffer]> JPEG-encoded frame data.Callback that receives JPEG-encoded frame data.
path <[path]>Path where the video should be saved when the screencast is stopped. When provided, video recording is started.
quality <[int]>The quality of the image, between 0-100.
size ?<[Object=ScreencastSize]>
width <[int]> Max frame width in pixels.height <[int]> Max frame height in pixels.Specifies the dimensions of screencast frames. The actual frame is scaled to preserve the page's aspect ratio and may be smaller than these bounds. If a screencast is already active (e.g. started by tracing or video recording), the existing configuration takes precedence and the frame size may exceed these bounds or this option may be ignored. If not specified the size will be equal to page viewport scaled down to fit into 800×800.
Stops the screencast and video recording if active. If a video was being recorded, saves it to the path specified in [method: Screencast.start].
Adds an overlay with the given HTML content. The overlay is displayed on top of the page until removed. Returns a disposable that removes the overlay when disposed.
html <[string]>HTML content for the overlay.
duration <[float]>Duration in milliseconds after which the overlay is automatically removed. Overlay stays until dismissed if not provided.
Shows a chapter overlay with a title and optional description, centered on the page with a blurred backdrop. Useful for narrating video recordings. The overlay is removed after the specified duration, or 2000ms.
title <[string]>Title text displayed prominently in the overlay.
description <[string]>Optional description text displayed below the title.
duration <[float]>Duration in milliseconds after which the overlay is automatically removed. Defaults to 2000.
Enables visual annotations on interacted elements. Returns a disposable that stops showing actions when disposed.
duration ?<[float]>How long each annotation is displayed in milliseconds. Defaults to 500.
position ?<[AnnotatePosition]<"top-left"|"top"|"top-right"|"bottom-left"|"bottom"|"bottom-right">>Position of the action title overlay. Defaults to "top-right".
fontSize ?<[int]>Font size of the action title in pixels. Defaults to 24.
Shows overlays.
Removes action decorations.
Hides overlays without removing them.