title | short-title | slug | l10n | ||
---|---|---|---|---|---|
MediaSource: addSourceBuffer() メソッド |
addSourceBuffer() |
Web/API/MediaSource/addSourceBuffer |
|
{{APIRef("Media Source Extensions")}}
addSourceBuffer()
は {{domxref("MediaSource")}} インターフェイスのメソッドで、指定された {{Glossary("MIME type","MIME タイプ")}}の新しい {{domxref("SourceBuffer")}} を作成し、MediaSource
の {{domxref("MediaSource.sourceBuffers", "sourceBuffers")}} リストに追加します。 新しい SourceBuffer
も返されます。
addSourceBuffer(mimeType)
mimeType
- : 文字列で、 {{domxref("MediaSource")}} に作成して追加する {{domxref("SourceBuffer")}} の MIME タイプを指定します。
作成され、メディアソースに追加された新しいソースバッファーを表す {{domxref("SourceBuffer")}} オブジェクト。
InvalidAccessError
{{domxref("DOMException")}}- :
mimeType
に指定された値は、有効な MIME タイプではなく空の文字列です。
- :
InvalidStateError
{{domxref("DOMException")}}- : {{domxref("MediaSource")}} の {{domxref("MediaSource.readyState", "readyState")}} は
"open"
でありません。
- : {{domxref("MediaSource")}} の {{domxref("MediaSource.readyState", "readyState")}} は
NotSupportedError
{{domxref("DOMException")}}- : 指定された
mimeType
は{{Glossary("user agent","ユーザーエージェント")}}でサポートされていないか、メディアソースの {{domxref("MediaSource.sourceBuffers", "sourceBuffers")}} リストに既に含まれている他の {{domxref("SourceBuffer")}} オブジェクトの MIME タイプと互換性がありません。
- : 指定された
QuotaExceededError
{{domxref("DOMException")}}- : ユーザーエージェントはこれ以上
SourceBuffer
オブジェクトを処理できないか、指定されたmimeType
を使用して新しいSourceBuffer
を作成すると、SourceBuffer の構成がサポートされなくなります。
- : ユーザーエージェントはこれ以上
次のスニペットは、Nick Desaulniers によって書かれた例からのものです(ライブで完全なデモを見るか、ソースをダウンロードしてさらに調査してください)。ここでは定義されていませんが、関数 getMediaSource()
は MediaSource
を返します。
const assetURL = "frag_bunny.mp4";
// Blink はコーデックに関して特定する必要がある
// ./mp4info frag_bunny.mp4 | grep Codec
const mimeCodec = 'video/mp4; codecs="avc1.42E01E, mp4a.40.2"';
const mediaSource = getMediaSource();
if ("MediaSource" in window && MediaSource.isTypeSupported(mimeCodec)) {
console.log(mediaSource.readyState); // closed
mediaSource.addEventListener("sourceopen", sourceOpen);
video.src = URL.createObjectURL(mediaSource);
} else {
console.error(
"サポートされていない MIME タイプまたはコーデック: ",
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);
});
}
{{Specifications}}
{{Compat}}
- {{domxref("SourceBuffer")}}
- {{domxref("SourceBufferList")}}