This feature is not Baseline because it does not work in some of the most widely-used browsers.
Note: This feature is only available in Dedicated Web Workers.
Warning: Browsers differ on which global context they expose this interface in (e.g., only window in some browsers and only dedicated worker in others), making them incompatible. Keep this in mind when comparing support.
The MediaStreamTrackProcessor interface of the Insertable Streams for MediaStreamTrack API consumes a video MediaStreamTrack object's source and generates a stream of VideoFrame objects.
MediaStreamTrackProcessor()Creates a new MediaStreamTrackProcessor object.
window.MediaStreamTrackProcessor() Experimental Non-standard
Creates a new MediaStreamTrackProcessor object on the main thread that can process both video and audio.
MediaStreamTrackProcessor.readableReturns a ReadableStream.
The following example is from the article Unbundling MediaStreamTrackProcessor and VideoTrackGenerator. It transfers a camera MediaStreamTrack to a worker for processing. The worker creates a pipeline that applies a sepia tone filter to the video frames and mirrors them. The pipeline culminates in a VideoTrackGenerator whose MediaStreamTrack is transferred back and played. The media now flows in real time through the transform off the main thread.
const stream = await navigator.mediaDevices.getUserMedia({ video: true });
const [track] = stream.getVideoTracks();
const worker = new Worker("worker.js");
worker.postMessage({ track }, [track]);
const { data } = await new Promise((r) => {
worker.onmessage = r;
});
video.srcObject = new MediaStream([data.track]);
worker.js:
onmessage = async ({ data: { track } }) => {
const vtg = new VideoTrackGenerator();
self.postMessage({ track: vtg.track }, [vtg.track]);
const { readable } = new MediaStreamTrackProcessor({ track });
await readable
.pipeThrough(new TransformStream({ transform }))
.pipeTo(vtg.writable);
};
| Specification |
|---|
| MediaStreamTrack Insertable Media Processing using Streams> # mediastreamtrackprocessor> |
| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Opera | Safari | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | WebView Android | WebView on iOS | |
MediaStreamTrackProcessor |
94Exposed onWindow instead of DedicatedWorker. |
94Exposed onWindow instead of DedicatedWorker. |
No | 80Exposed onWindow instead of DedicatedWorker. |
18 | 94Exposed onWindow instead of DedicatedWorker. |
No | 66Exposed onWindow instead of DedicatedWorker. |
18 | 17.0Exposed onWindow instead of DedicatedWorker. |
94Exposed onWindow instead of DedicatedWorker. |
18 |
MediaStreamTrackProcessor |
94Exposed onWindow instead of DedicatedWorker. |
94Exposed onWindow instead of DedicatedWorker. |
No | 80Exposed onWindow instead of DedicatedWorker. |
18 | 94Exposed onWindow instead of DedicatedWorker. |
No | 66Exposed onWindow instead of DedicatedWorker. |
18 | 17.0Exposed onWindow instead of DedicatedWorker. |
94Exposed onWindow instead of DedicatedWorker. |
18 |
readable |
94 | 94 | No | 80 | 18 | 94 | No | 66 | 18 | 17.0 | 94 | 18 |
VideoTrackGeneratorNote: This article was written before the API was restricted to workers and video. Beware its use of the non-standard version of MediaStreamTrackProcessor which blocks on the main thread.
© 2005–2025 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/MediaStreamTrackProcessor