当我将它们附加到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>
有可能做我想要的吗?此外,如果有人能够建议我如何称呼它,我将不胜感激 - 我将其称为“直播”,但我不确定。