語法
js
endOfStream()
endOfStream(endOfStreamError)
引數
endOfStreamError可選-
當到達流的末尾時引發的錯誤的字串表示。可能的值為:
返回值
無(undefined)。
異常
InvalidStateErrorDOMException-
如果
MediaSource.readyState不等於open,或者MediaSource.sourceBuffers中的一個或多個SourceBuffer物件正在更新(即,它們的SourceBuffer.updating屬性為true),則丟擲此錯誤。
示例
以下程式碼段來自 Nick Desaulniers 編寫的示例(線上檢視完整演示,或下載原始碼以供進一步研究)。函式 getMediaSource()(此處未定義)返回一個 MediaSource。
js
const assetURL = "frag_bunny.mp4";
// Need to be specific for Blink regarding codecs
// ./mp4info frag_bunny.mp4 | grep Codec
const mimeCodec = 'video/mp4; codecs="avc1.42E01E, mp4a.40.2"';
let mediaSource;
if ("MediaSource" in window && MediaSource.isTypeSupported(mimeCodec)) {
mediaSource = getMediaSource();
console.log(mediaSource.readyState); // closed
video.src = URL.createObjectURL(mediaSource);
mediaSource.addEventListener("sourceopen", sourceOpen);
} else {
console.error("Unsupported MIME type or codec: ", mimeCodec);
}
function sourceOpen() {
console.log(this.readyState); // open
const sourceBuffer = mediaSource.addSourceBuffer(mimeCodec);
fetchAB(assetURL, (buf) => {
sourceBuffer.addEventListener("updateend", () => {
mediaSource.endOfStream();
video.play();
console.log(mediaSource.readyState); // ended
});
sourceBuffer.appendBuffer(buf);
});
}
規範
| 規範 |
|---|
| Media Source Extensions™ # dom-mediasource-endofstream |
瀏覽器相容性
載入中…