使用媒体源扩展符合DOMException:无法加载,因为找不到支持的源

问题描述 投票:0回答:1

我用ffmpeg变换mp4到m3u8;它保持相同的编解码器值。当我使用fetch获取ts缓冲区并将其附加到MSE实例时。如此糟糕。它不起作用。

一些代码在这里:

function sourceOpen(e) {
    URL.revokeObjectURL(video.src);
    // var mime = 'video/mp4; codecs="avc1.42c015, mp4a.40.5"';avc1.42001e"
    var mime = 'video/mp4; codecs="avc1.42E01E, mp4a.40.2"';
    var mediaSource = e.target;
    sourceBuffer = mediaSource.addSourceBuffer(mime);
    var videoUrl = './video/' + playManifest.segments[index]['uri'];
    log('.js-log-m3u8', 'Fetch Segment ~' + videoUrl);
    fetch(videoUrl, {
        // headers: { range: 'bytes=0-5671398' }
    })
        .then(function (response) {
            return response.arrayBuffer();
        })
        .then(function (arrayBuffer) {
            sourceBuffer.appendBuffer(arrayBuffer);
            sourceBuffer.addEventListener('updateend', updateEnd);
        });
}

Entire Code

在线测试页面:http://events.jackpu.com/media-source/

html5 video media-source mse
1个回答
0
投票

您正在将mime类型设置为video / mp4,但尝试将传输流段附加到源缓冲区。结果,附加失败并且没有数据被缓冲。

一旦获取了所有段,就调用play,而不检查是否有任何数据被缓冲,并且Promise拒绝。

假设您的用户代理能够执行此操作,则需要使用正确的mime类型创建SourceBuffer。

© www.soinside.com 2019 - 2024. All rights reserved.