MPEG DASH:尽快(和多次)播放片段,并将其附加到SourceBuffer

时间:2017-03-06 14:06:25

标签: javascript html5 mpeg-dash media-source mp4box

当我将它们附加到SourceBuffer时,是否有可能让HTML5视频标签尽快播放片段?所以,例如,如果我追加fragment2 - 我希望它立即播放fragment2,即使没有fragment1,如果我再次追加fragment2 - 我会再次播放fragment2。

我已经尝试将MediaSource传递给没有fragment1的初始段+ fragment2,但我发现它不是立即播放它而是用它填充相应的时间线部分。因此,如果我寻找相应的位置 - 它将开始播放它,但如果我不这样做 - 它将不会(除非我也传递fragment1,ofk)。更不用说即使我再次将fragment2附加到SourceBuffer,它也不会自动再次播放,直到我寻找。

这是我用来制作MP4 / DASH流的方法:

$ MP4Box -dash 30000 -dash-profile on-demand -segment-name output-seg output.mp4
$ cat output-seginit.mp4 output-seg2.m4s >test.mp4

以下是相应的HTML5 / JavaScript代码:

<audio id="player" controls></audio>

<script>
var player = document.querySelector("#player");
var mediaSource = new MediaSource();
player.src = URL.createObjectURL(mediaSource);
mediaSource.addEventListener('sourceopen', function() {
   console.log('sourceopen');
   var sourceBuffer = mediaSource.addSourceBuffer('video/mp4; codecs="mp4a.40.2"'); // My video only contains audio stream

    var xhr = new XMLHttpRequest()
    xhr.responseType = "arraybuffer";
    xhr.onload = function(event) {
      console.log("appendBuffer");
      sourceBuffer.appendBuffer(event.target.response);
    }
    xhr.open('GET', 'test.mp4');
    xhr.send(null);
});
</script>

有可能做我想要的吗?此外,如果有人能够建议我如何称呼它,我将不胜感激 - 我将其称为“直播”,但我不确定。

0 个答案:

没有答案