WebRTC/WebSocket 屏幕录制

Dan*_*any 5 video-capture websocket html5-video webrtc

在我的用例中,我想记录屏幕活动并将其发送到服务器 [not live]。为此,我查看了一些博客/示例演示。但我找不到与此相关的任何内容。我可以找到很多实时流音频/视频,但找不到屏幕录制。

我有以下与此相关的问题,

  • 对于这个用例,哪一个是高效的 WebRTC/Websockets?
  • 浏览器支持 WebRTC/Websockets 吗?
  • 有没有其他方法可以实现这个用例?

我对 WebRTC/Websockets 还很陌生,如果我没有发布足够的信息,请发表评论。我会加。

有人可以帮我吗?与此用例相关的任何参考 URL/任何相关信息都会非常有帮助。

jib*_*jib 5

以下是在 Firefox 中录制屏幕的方法(更新:这个小提琴中尝试):

var constraints = { video: { mediaSource: "screen", width: 320, height: 200 } };

var start = ms => navigator.mediaDevices.getUserMedia(constraints)
  .then(stream => record(stream, ms)
    .then(recording => {
      stop(stream);
      video.src = link.href = URL.createObjectURL(new Blob(recording));
      link.download = "recording.blob";
      link.innerHTML = "Download blob";
      log("Playing "+ recording[0].type +" recording:");
    })
    .catch(log).then(() => stop(stream)))
  .catch(log);

var record = (stream, ms) => {
  var rec = new MediaRecorder(stream), data = [];
  rec.ondataavailable = e => data.push(e.data);
  rec.start();
  log(rec.state + " for "+ (ms / 1000) +" seconds...");
  var stopped = new Promise((r, e) => (rec.onstop = r, rec.onerror = e));
  return Promise.all([stopped, wait(ms).then(() => rec.stop())])
    .then(() => data);
};

var stop = stream => stream.getTracks().forEach(track => track.stop());
var wait = ms => new Promise(resolve => setTimeout(resolve, ms));
var log = msg => div.innerHTML += "<br>" + msg;
Run Code Online (Sandbox Code Playgroud)
<button onclick="start(5000)">Record screen!</button>
<div id="div"></div><br>
<video id="video" height="120" width="160" autoplay></video>
<a id="link"></a>
Run Code Online (Sandbox Code Playgroud)

警告:在网络上共享您的浏览器窗口涉及安全风险!在这里阅读!

获得 blob 后,您可以使用常规 Web 套接字(未显示)上传它。

mediaRecorder位应在Chrome浏览器为好,但遗憾的是屏幕共享还没有完全规范,工作方式不同,需要在Chrome的扩展。