V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
NouveauNom
V2EX  ›  问与答

js 大佬进,如何使用视频流来重写 navigator.mediaDevices.getUserMedia

  •  
  •   NouveauNom · 2023-06-13 18:27:38 +08:00 · 476 次点击
    这是一个创建于 521 天前的主题,其中的信息可能已经有所发展或是发生改变。
    想实现的功能,写一个扩展,将 navigator.mediaDevices.getUserMedia 获取摄像头,改为视频流输入,网上找到代码
    await page.evaluate(() => {
    const video = document.createElement("video");

    video.setAttribute('id', 'video-mock');
    video.setAttribute("src", 'https://woolyss.com/f/spring-vp9-vorbis.webm');
    video.setAttribute("crossorigin", "anonymous");
    video.setAttribute("controls", "");

    video.oncanplay = () => {
    const stream = video.captureStream();

    navigator.mediaDevices.getUserMedia = () => Promise.resolve(stream);
    };

    document.querySelector("body").appendChild(video);
    });

    但是没有成功
    3 条回复    2023-06-14 16:40:35 +08:00
    jifengg
        1
    jifengg  
       2023-06-14 08:58:27 +08:00
    不清楚具体原理,不过,你的 navigator.mediaDevices.getUserMedia 覆写 是在 video canplay 之后,是否这期间其他 js 代码已经调用 navigator.mediaDevices.getUserMedia 了呢?
    NouveauNom
        2
    NouveauNom  
    OP
       2023-06-14 10:25:24 +08:00
    @jifengg 把代码改为
    <!DOCTYPE html>
    <html>
    <head>
    <title>摄像头实时预览</title>
    <style>
    #video-preview {
    width: 100%;
    height: auto;
    }
    </style>
    </head>
    <body>
    <video id="video-preview" autoplay></video>

    <video id="video-preview2" autoplay></video>


    <div id="container"></div>
    <button onclick="click2()"> click2</button>
    <script>
    // 获取视频流
    let video;
    async function playVideo(url) {

    video = document.createElement("video");
    video.setAttribute('id', 'video-mock');
    video.setAttribute("src", url);
    // video.setAttribute("crossorigin", "anonymous");
    // video.setAttribute("controls", "");

    video.oncanplay = async () => {

    };

    video.onplay = async () => {
    const stream = video.captureStream();
    navigator.mediaDevices.getUserMedia = () => Promise.resolve(stream);



    };

    videoCreated = true;
    }



    // 在页面中创建一个按钮,并绑定点击事件
    const playButton = document.createElement('button');
    playButton.textContent = '点击播放视频';
    playButton.addEventListener('click', startVideoPlayback);

    // 将按钮添加到页面中的某个元素上
    const container = document.getElementById('container');
    container.appendChild(playButton);
    playVideo("test.mp4");
    // 用户点击按钮后调用此函数
    function startVideoPlayback() {
    video.play();

    }

    function click2()
    {
    // 获取视频流
    navigator.mediaDevices.getUserMedia({ video: true })
    .then(function(stream2) {
    var videoElement = document.getElementById('video-preview2');
    videoElement.srcObject = stream2;
    })
    .catch(function(error) {
    console.error('访问摄像头失败:', error);
    });
    }
    </script>
    </body>
    </html>


    似乎 Chrome ,只是似乎可用,safari 直接报错了
    NouveauNom
        3
    NouveauNom  
    OP
       2023-06-14 16:40:35 +08:00
    已经实现此功能,此贴结束。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2058 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 16:19 · PVG 00:19 · LAX 08:19 · JFK 11:19
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.