parseMedia()
Part of the @remotion/media-parser
package.
available from v4.0.190
Unstable API: This package is experimental. We might change the API at any time, until we remove this notice.
Examples
Parsing a hosted videotsx
import {parseMedia } from '@remotion/media-parser';constresult = awaitparseMedia ({src : 'https://example.com/my-video.mp4',fields : {durationInSeconds : true,dimensions : true,},});console .log (result .durationInSeconds ); // 10console .log (result .dimensions ); // {width: 1920, height: 1080}
Parsing a hosted videotsx
import {parseMedia } from '@remotion/media-parser';constresult = awaitparseMedia ({src : 'https://example.com/my-video.mp4',fields : {durationInSeconds : true,dimensions : true,},});console .log (result .durationInSeconds ); // 10console .log (result .dimensions ); // {width: 1920, height: 1080}
Parsing a local filetsx
import {parseMedia } from '@remotion/media-parser';import {nodeReader } from '@remotion/media-parser/node';constresult = awaitparseMedia ({src : '/Users/jonnyburger/Downloads/my-video.mp4',fields : {durationInSeconds : true,dimensions : true,},reader :nodeReader ,});
Parsing a local filetsx
import {parseMedia } from '@remotion/media-parser';import {nodeReader } from '@remotion/media-parser/node';constresult = awaitparseMedia ({src : '/Users/jonnyburger/Downloads/my-video.mp4',fields : {durationInSeconds : true,dimensions : true,},reader :nodeReader ,});
API
Unstable API: This package is experimental. We might change the API at any time, until we remove this notice.
src
Either a local file path, or a URL, or a File
or Blob
object.
If you pass a local file path, you must also pass nodeReader
as the reader
argument.
If you pass a File
object, you must also pass webFileReader
as the reader
argument.
fields?
An object specifying which fields you'd like to receive.
If you like to receive the field, pass true
as the value.
Possible fields are:
dimensions
{width: number, height: number}
The dimensions of the video.
Any rotation is already applied - the dimensions are like a media player would show them.
Use unrotatedDimensions
to get the dimensions before rotation.
durationInSeconds
number | null
The duration of the video in seconds.
Only returns a non-null value if the duration is stored in the metadata.
slowDurationInSeconds
number
The duration of the video in seconds, but it is guaranteed to return a value.
If needed, the entire video file is read to determine the duration.
name
string
The name of the file.
container
"mp4" | "webm" | "avi" | null
The container of the file.
size
number | null
The size of the input in bytes.
mimeType
string | null
The MIME type of the file that was returned when the file was fetched.
Only available if using the fetchReader
or webFileReader
.
structure
The internal structure of the video. Unstable, internal data structure, refer to the TypeScript types to see what's inside.
fps
number | null
The frame rate of the video.
Only returns a non-null value if the frame rate is stored in the metadata.
slowFps
number
The frame rate of the video, but it is guaranteed to return a value.
If needed, the entire video file is read to determine the frame rate.
videoCodec
The video codec of the file.
If multiple video tracks are present, this will be the first video track.
One of "h264"
, "h265"
, "vp8"
, "vp9"
, "av1"
, "prores"
or null
(in case of an unknown codec).
audioCodec
The audio codec of the file.
If multiple audio tracks are present, this will be the first audio track.
One of 'aac'
, 'mp3'
, 'aiff'
, 'opus'
, 'pcm'
, 'unknown'
(audio is there but not recognized) or null
(in case of no audio detected).
metadata
Metadata fields such as ID3 tags or EXIF data.
See metadata for more information.
location
The location of the video was shot. Either null
if not available or:
latitude
: The latitude of the locationlongitude
: The longitude of the locationaltitude
: The altitude of the location (can benull
)horizontalAccuracy
: The horizontal accuracy of the location (can benull
)
tracks
Returns an object of two two arrays videoTracks
and audioTracks
.
The data structure of them is not yet stable.
keyframes
Return type: MediaParserKeyframe[] | null
An array of keyframes. Each keyframe has the following structure:
presentationTimeInSeconds
: The time in seconds when the keyframe should be presenteddecodingTimeInSeconds
: The time in seconds when the keyframe should be decodedpositionInBytes
: The position in bytes where the keyframe is located in the filesizeInBytes
: The size of the keyframe in bytestrackId
: The ID of the track the frame belongs to
Only being returned if the keyframe information are stored in the metadata, otherwise null
.
slowKeyframes
Return type: MediaParserKeyframe[]
An array of keyframes, same as keyframes
, but it is guaranteed to return a value.
Will read the entire video file to determine the keyframes.
slowNumberOfFrames
number
The number of video frames in the media.
Will read the entire video file to determine the number of frames.
unrotatedDimensions
{width: number, height: number}
The dimensions of the video before rotation.
isHdr
boolean
Whether the video is in HDR (High dynamic range).
rotation
number
The rotation of the video in degrees (e.g. -90
for a 90° counter-clockwise rotation).
reader?
A reader interface.
Default value: fetchReader
, which uses fetch()
to read the video.
If you pass nodeReader
, you must also pass a local file path as the src
argument.
If you pass webFileReader
, you must also pass a File
as the src
argument.
onVideoTrack?
A callback that is called when a video track is detected.
It receives an object with track
and container
(API not yet stable).
You must return either null
or a callback that is called for each sample that corresponds to the video track.
The sample
has the type VideoSample
and while not all fields are stable, it has all the mandatory fields for the EncodedVideoChunk
constructor.
Reading video framestsx
import {parseMedia ,OnVideoTrack } from '@remotion/media-parser';constonVideoTrack :OnVideoTrack = ({track }) => {console .log (track );return (sample ) => {console .log (newEncodedVideoChunk (sample ));};};
Reading video framestsx
import {parseMedia ,OnVideoTrack } from '@remotion/media-parser';constonVideoTrack :OnVideoTrack = ({track }) => {console .log (track );return (sample ) => {console .log (newEncodedVideoChunk (sample ));};};
onAudioTrack?
A callback that is called when an audio track is detected.
It receives an object with track
and container
(API not yet stable).
You must return either null
or a callback that is called for each sample that corresponds to the audio track.
The sample
has the type AudioSample
and while not all fields are stable, it has all the mandatory fields for the EncodedAudioChunk
constructor.
Reading audio framestsx
import {parseMedia ,OnAudioTrack } from '@remotion/media-parser';constonAudioTrack :OnAudioTrack = ({track }) => {console .log (track );return (sample ) => {console .log (newEncodedAudioChunk (sample ));};};
Reading audio framestsx
import {parseMedia ,OnAudioTrack } from '@remotion/media-parser';constonAudioTrack :OnAudioTrack = ({track }) => {console .log (track );return (sample ) => {console .log (newEncodedAudioChunk (sample ));};};
onParseProgress?
A callback that is called from time to time when bytes have been read from the media.
It includes the following data:
tsx
import {ParseMediaProgress } from '@remotion/media-parser';
tsx
import {ParseMediaProgress } from '@remotion/media-parser';
You may make this an async function, and while it is not resolved, the parsing process will be paused.
This is useful if you want to add a small delay inbetween progress steps to keep the UI interactive.
logLevel?
One of "error"
, "warn"
, "info"
, "debug"
, "trace"
.
Default value: "info"
, which logs only important information.
signal?
An AbortSignal
instance.
If the signal is aborted, the parser will stop reading the media and stop the decoding process and throw an error.
Callbacks
Each field also has a callback that allows you to retrieve the value as soon as it is obtained without waiting for the function to resolve.
You do not have to add the field to the fields
object if you use the callback.
However, just like with fields
, adding a callback for a slow field may require reading more of the file.
Using a callbacktsx
import {parseMedia } from '@remotion/media-parser';constresult = awaitparseMedia ({src : 'https://example.com/my-video.mp4',onDurationInSeconds : (durationInSeconds ) => {console .log (durationInSeconds );},onDimensions : (dimensions ) => {console .log (dimensions );},});
Using a callbacktsx
import {parseMedia } from '@remotion/media-parser';constresult = awaitparseMedia ({src : 'https://example.com/my-video.mp4',onDurationInSeconds : (durationInSeconds ) => {console .log (durationInSeconds );},onDimensions : (dimensions ) => {console .log (dimensions );},});