ManagedMediaSource: startstreaming event
Limited availability
This feature is not Baseline because it does not work in some of the most widely-used browsers.
Note: This feature is available in Dedicated Web Workers.
The startstreaming event of the ManagedMediaSource interface is fired when the streaming property changes from false to true. This indicates that the user agent needs more data to ensure uninterrupted playback, and the application should begin fetching and appending media segments.
Syntax
Use the event name in methods like addEventListener(), or set an event handler property.
js
addEventListener("startstreaming", (event) => {});
onstartstreaming = (event) => {};
Event type
A generic Event.
Examples
>Fetching data in response to startstreaming
This example creates a ManagedMediaSource, attaches it to a <video> element, and uses the startstreaming event to begin fetching and appending media data.
js
const videoUrl =
"https://mdn.github.io/shared-assets/videos/flower-fragmented.mp4";
const mediaType = 'video/mp4; codecs="avc1.64001F, mp4a.40.2"';
if (ManagedMediaSource.isTypeSupported(mediaType)) {
const video = document.createElement("video");
const source = new ManagedMediaSource();
video.controls = true;
video.disableRemotePlayback = true;
video.src = URL.createObjectURL(source);
document.body.appendChild(video);
source.addEventListener("sourceopen", () => {
const sourceBuffer = source.addSourceBuffer(mediaType);
source.addEventListener("startstreaming", async () => {
console.log("startstreaming — fetching media data");
const response = await fetch(videoUrl);
const data = await response.arrayBuffer();
sourceBuffer.appendBuffer(data);
});
});
}
Specifications
| Specification |
|---|
| Media Source Extensions™> # dfn-startstreaming> |