@remotion/renderer
Version:
Render Remotion videos using Node.js or Bun
95 lines (94 loc) • 3.86 kB
TypeScript
import type { AudioOrVideoAsset, VideoConfig } from 'remotion/no-react';
import type { RenderMediaOnDownload } from './assets/download-and-map-assets-to-file';
import type { BrowserExecutable } from './browser-executable';
import type { BrowserLog } from './browser-log';
import type { HeadlessBrowser } from './browser/Browser';
import type { FrameRange } from './frame-range';
import type { VideoImageFormat } from './image-format';
import type { CancelSignal } from './make-cancel-signal';
import type { ChromiumOptions } from './open-browser';
import type { ToOptions } from './options/option';
import type { optionsMap } from './options/options-map';
import type { RemotionServer } from './prepare-server';
import type { EmittedArtifact } from './serialize-artifact';
import type { OnStartData, RenderFramesOutput } from './types';
export type OnArtifact = (asset: EmittedArtifact) => void;
type InternalRenderFramesOptions = {
onStart: null | ((data: OnStartData) => void);
onFrameUpdate: null | ((framesRendered: number, frameIndex: number, timeToRenderInMilliseconds: number) => void);
outputDir: string | null;
envVariables: Record<string, string>;
imageFormat: VideoImageFormat;
jpegQuality: number;
frameRange: FrameRange | null;
everyNthFrame: number;
puppeteerInstance: HeadlessBrowser | undefined;
browserExecutable: BrowserExecutable | null;
onBrowserLog: null | ((log: BrowserLog) => void);
onFrameBuffer: null | ((buffer: Buffer, frame: number) => void);
onDownload: RenderMediaOnDownload | null;
chromiumOptions: ChromiumOptions;
scale: number;
port: number | null;
cancelSignal: CancelSignal | undefined;
composition: Omit<VideoConfig, 'props' | 'defaultProps'>;
indent: boolean;
server: RemotionServer | undefined;
muted: boolean;
concurrency: number | string | null;
webpackBundleOrServeUrl: string;
serializedInputPropsWithCustomSchema: string;
serializedResolvedPropsWithCustomSchema: string;
parallelEncodingEnabled: boolean;
compositionStart: number;
onArtifact: OnArtifact | null;
} & ToOptions<typeof optionsMap.renderFrames>;
type ArtifactWithoutContent = {
frame: number;
filename: string;
};
export type FrameAndAssets = {
frame: number;
audioAndVideoAssets: AudioOrVideoAsset[];
artifactAssets: ArtifactWithoutContent[];
};
export type RenderFramesOptions = {
onStart: (data: OnStartData) => void;
onFrameUpdate: (framesRendered: number, frameIndex: number, timeToRenderInMilliseconds: number) => void;
outputDir: string | null;
inputProps: Record<string, unknown>;
envVariables?: Record<string, string>;
imageFormat?: VideoImageFormat;
/**
* @deprecated Renamed to "jpegQuality"
*/
quality?: never;
frameRange?: FrameRange | null;
everyNthFrame?: number;
/**
* @deprecated Use "logLevel": "verbose" instead
*/
dumpBrowserLogs?: boolean;
/**
* @deprecated Use "logLevel" instead
*/
verbose?: boolean;
puppeteerInstance?: HeadlessBrowser;
browserExecutable?: BrowserExecutable;
onBrowserLog?: (log: BrowserLog) => void;
onFrameBuffer?: (buffer: Buffer, frame: number) => void;
onDownload?: RenderMediaOnDownload;
timeoutInMilliseconds?: number;
chromiumOptions?: ChromiumOptions;
scale?: number;
port?: number | null;
cancelSignal?: CancelSignal;
composition: VideoConfig;
muted?: boolean;
concurrency?: number | string | null;
onArtifact?: OnArtifact | null;
serveUrl: string;
} & Partial<ToOptions<typeof optionsMap.renderFrames>>;
export declare const internalRenderFrames: (args_0: InternalRenderFramesOptions) => Promise<RenderFramesOutput>;
export declare const renderFrames: (options: RenderFramesOptions) => Promise<RenderFramesOutput>;
export {};