3

阅读此页面https://developer.mozilla.org/en-US/docs/Web/API/MediaRecorder.start后,我​​编写了自己的代码:

var mediaConstraint = { video: true, audio: true };
navigator.getUserMedia(mediaConstraint, function(stream) {
    var vendorURL = window.URL || window.webkitURL;
    _video = document.querySelector('#recordingCamera');
    _video.src = vendorURL.createObjectURL(stream);
    _video.play();

    var mediaRecorder = new MediaRecorder(stream);
    mediaRecorder.start(3000);
    mediaRecorder.ondataavailable = function(e) {
        var replay = document.querySelector('#replay');
        replay.src = window.URL.createObjectURL(e.data);
        replay.play();
    }
}, function(error){

});

我希望在#recordingCamera 元素显示我相机的内容后 3 秒后,我将在 #replay 元素中看到内容重播。
但是#replay 元素只播放 3 秒。之后,#recordingCamera 元素仍然显示摄像机内容,但 #replay 元素没有其他内容。
检查控制台时,我发现了以下消息:

Media resource blob:http://localhost:8081/634f6237-17a9-475d-89bb-2c6ca0b48eb6 could not be decoded.
Media resource blob:http://localhost:8081/d0b95463-f9bc-4b0f-bd0d-40ae3152181f could not be decoded.
Media resource blob:http://localhost:8081/535ab990-0ee2-4ec0-adac-2d5d6917f6f3 could not be decoded.

ondataavailable仍然触发,但数据发生了问题。

我的问题

  • 这是Firefox的错误吗?
  • 如果不是,那么使用带有 start 指定的时间片参数的 MediaRecorder 的正确方法是什么?
4

2 回答 2

2

好的,我找到了解决方案,即MediaSource API

var mediaSource = new MediaSource();
var replay = document.querySelector('#replay');
replay.src = window.URL.createObjectURL(mediaSource);
mediaSource.addEventListener('sourceopen', function(e) {
    console.log('sourceopen')
    sourceBuffer = mediaSource.addSourceBuffer('video/webm; codecs="vorbis,vp8"');
});

var mediaConstraint = { video: true, audio: true };
navigator.getUserMedia(mediaConstraint, function(stream) {
    var mediaRecorder = new MediaRecorder(stream);
    mediaRecorder.start(3000);
    mediaRecorder.ondataavailable = function(e) {
        var fileReader = new FileReader();
        fileReader.onload = function() {
            sourceBuffer.appendBuffer(fileReader.result);
        };
        fileReader.readAsArrayBuffer(e.data);
    }
}, function(error){});

请注意,在 Firefox 中,您需要将 enable-media-source 标志设置为 true。

于 2015-01-07T14:25:25.477 回答
0

这似乎是 Firefox 中的一个错误。如果您mediaRecorder.start以较小的时间片间隔调用,则 blob 将在不使用 MediaSource 的情况下正常播放。请注意,MediaSource 直到 Firefox 42 才普遍可用,因此您不能依赖它可用。

mediaRecorder.start(1000);

于 2016-01-20T21:38:43.023 回答