gpt4 book ai didi

websocket - WebRTC/WebSocket 录屏

转载 作者:行者123 更新时间:2023-12-04 23:17:45 25 4
gpt4 key购买 nike

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

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

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

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

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

    最佳答案

    以下是在 Firefox 中记录屏幕的方法( 更新:this fiddle 中尝试):

    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;
    <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>


    Warning: Sharing your browser window on the web involves security risk! Read about it here!



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

    mediaRecorder bits 也应该在 Chrome 中工作,但不幸的是,屏幕共享仍然没有完全标准化并且工作方式不同,需要在 Chrome 中进行扩展。

    关于websocket - WebRTC/WebSocket 录屏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35857134/

    25 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com