侯小啾 2022-06-12 13:25 采纳率: 75%
浏览 167
已结题

前端摄像头处理实时视频问题

问题遇到的现象和发生背景

请求帮忙讲解或者修改代码前端。我的需求是,想要在web前端用摄像头实时拍摄视频,然后不直接显示该视频画面。将每一帧画面传递到后端程序代码中,使用python opencv将图像处理好之后再传回来显示画面(对应img id="video" width="480" height="720" src="{{ url_for('home.video_viewer') }}"这一句)。

其中,我对前端代码中的video.addEventListener("DOMContentLoaded", function () 这一大段代码最不理解,可能也存在问题,请求各位佬讲解或修改一下!
这一段的作用python获取视频数据的代码相对应,对应python代码为:

if request.method == 'POST':
        imgData = base64.b64decode(request.form['imgdata'].replace('data:image/png;base64,', ''))

(即从form标签的imgdata中取到视频数据)(作为参考)

问题相关代码

前端代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        img {
            border: 1px solid #ccc;
            display: block;
            margin: 100px 0 20px 700px;
            float: left;
        }

    </style>
</head>
<body>
    <img id="video" width="480" height="720" src="{{ url_for('home.video_viewer') }}">
    <script type="text/javascript">
    window.addEventListener("DOMContentLoaded", function() {
        var video = document.getElementById("video");
        var videoObj = {"video" : true};
        var errBack = function(error) {
            console.log("Video capture error: ", error.code);
        };
        if (navigator.getUserMedia) {
            navigator.getUserMedia(videoObj, function(stream) {
                video.srcObject = stream;
            }, errBack);
        } else if (navigator.webkitGetUserMedia) {
            navigator.webkitGetUserMedia(videoObj, function(stream) {
                video.srcObject = window.webkitURL.createObjectURL(stream);
            }, errBack);
        } else if (navigator.mozGetUserMedia) {
            navigator.mozGetUserMedia(videoObj, function (stream) {
                video.srcObject = window.URL.createObjectURL(stream);
            }, errBack);
            }
        }, false);


    video.addEventListener("DOMContentLoaded", function () {
        var dataURL = canvas.toDataURL();
        var temp = document.createElement("form");
        temp.action = "http://127.0.0.1:5002";
        temp.method = "post";
        temp.style.display = "none";
        var opt = document.createElement("textarea");
        opt.name ="imgdata";
        opt.value = dataURL;
        temp.appendChild(opt);
        document.body.appendChild(temp);
        temp.submit();
    });

</script>
</body>
</html>
  • 写回答

2条回答 默认 最新

  • 溪风沐雪 2022-06-12 15:51
    关注

    总感觉你这逻辑是错误的,为什么不直接用后端采集视频然后处理完给前端显示呢

    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 6月14日
  • 修改了问题 6月12日
  • 修改了问题 6月12日
  • 创建了问题 6月12日

悬赏问题

  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥15 stable diffusion
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误