阅读此页面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 的正确方法是什么?