0

0

如何在Flask和YOLOv5开发的HTML网页上成功打开摄像头并显示检测框?

霞舞

霞舞

发布时间:2025-03-15 10:08:11

|

968人浏览过

|

来源于php中文网

原创

如何在flask和yolov5开发的html网页上成功打开摄像头并显示检测框?

使用Flask和YOLOv5在网页上实现摄像头实时目标检测

本文探讨如何在Flask框架和YOLOv5模型的基础上,构建一个HTML网页,实现摄像头实时视频流的获取和目标检测结果的显示。 过程中,可能会遇到摄像头无法打开或检测框无法显示等问题,本文将提供相应的解决方案。

前端代码详解

前端HTML页面包含<video></video>标签用于显示摄像头视频流,以及<img src="https://img.php.cn/upload/article/001/246/273/174200449476734.jpg" alt="如何在Flask和YOLOv5开发的HTML网页上成功打开摄像头并显示检测框?"><script> function start() { navigator.mediaDevices.getUserMedia({ video: true }) .then(function(stream) { const video = document.querySelector('video'); video.srcObject = stream; const canvas = document.createElement('canvas'); const ctx = canvas.getContext('2d'); setInterval(function() { const videoWidth = video.videoWidth; const videoHeight = video.videoHeight; canvas.width = videoWidth; canvas.height = videoHeight; ctx.drawImage(video, 0, 0, videoWidth, videoHeight); const imageData = canvas.toDataURL('image/png', 1); // 压缩图片 // 发送数据到后端 $.ajax({ type: 'POST', url: '/image_data', data: { id: $("#uid").val(), image_data: imageData }, success: function(response) { console.log(response); $("#res").attr("src", "/img_feed?id=" + $("#uid").val()); // 更新结果图像 } }); }, 1000 / 30); // 每秒30帧 }) .catch(function(error) { console.error(error); }); } </script><h4>后端代码详解</h4> <p>后端使用Flask框架,定义两个主要路由:</p><div class="aritcle_card flexRow"> <div class="artcardd flexRow"> <a class="aritcle_card_img" href="/ai/984" title="Frase"><img src="https://img.php.cn/upload/ai_manual/000/000/000/175680021196501.png" alt="Frase" onerror="this.onerror='';this.src='/static/lhimages/moren/morentu.png'" ></a> <div class="aritcle_card_info flexColumn"> <a href="/ai/984" title="Frase">Frase</a> <p>Frase是一款出色的长篇 AI 写作工具,快速创建seo优化的内容。</p> </div> <a href="/ai/984" title="Frase" class="aritcle_card_btn flexRow flexcenter"><b></b><span>下载</span> </a> </div> </div> <ol> <li> <code>/image_data: 接收前端发送的图像数据,将其保存到服务器临时文件。

  • /img_feed: 处理图像,使用YOLOv5进行目标检测,并将检测结果图像返回给前端。
  • import cv2
    import time
    import io
    import base64
    from flask import Flask, request, Response, render_template
    from PIL import Image
    
    app = Flask(__name__)
    
    #  ... (YOLOv5 模型加载代码,假设名为 'd') ...
    
    def gen(path):
        cap = cv2.VideoCapture(path)
        while cap.isOpened():
            try:
                start_time = time.time()
                success, frame = cap.read()
                if success:
                    im, label, c = d.detect(frame) # 调用YOLOv5检测函数
                    ret, jpeg = cv2.imencode('.png', im)
                    if ret:
                        frame = jpeg.tobytes()
                        elapsed_time = time.time() - start_time
                        print(f"Frame processing time: {elapsed_time:.3f} seconds")
                        yield (b'--frame\r\n'
                               b'Content-Type: image/png\r\n\r\n' + frame + b'\r\n\r\n')
                    else:
                        break
                else:
                    break
            except Exception as e:
                print(e)
                continue
        cap.release()
    
    @app.route('/img_feed')
    def img_feed():
        f = request.args.get("id")
        return Response(gen(f'upload/temp{f}.png'), mimetype='multipart/x-mixed-replace; boundary=frame')
    
    @app.route('/image_data', methods=["POST"])
    def image_data():
        image_data = request.form.get('image_data')
        id = request.form.get('id')
        image_data = io.BytesIO(base64.b64decode(image_data.split(',')[1]))
        img = Image.open(image_data)
        img.save(f'upload/temp{id}.png')
        return "ok"
    
    if __name__ == '__main__':
        app.run(debug=True)

    问题排查与解决方案

    1. 摄像头权限: 确保浏览器允许网页访问摄像头。
    2. cv2.VideoCapture 参数: cv2.VideoCapture(0) 通常用于访问默认摄像头。 如果使用其他摄像头,需要更改参数。 对于视频文件,需要提供正确的文件路径。
    3. YOLOv5 模型路径: 确保YOLOv5模型正确加载,并且路径设置正确。
    4. 错误信息: 仔细检查控制台的错误信息,例如网络错误、模型加载错误等。
    5. 文件路径: 使用绝对路径来避免文件路径问题。
    6. 后端接口调用: 确认前端代码正确调用 /img_feed 接口来获取检测结果。

    通过仔细检查代码、配置和错误信息,并参考以上解决方案,可以有效解决摄像头无法打开或检测框无法显示的问题,从而成功构建一个基于Flask和YOLOv5的网页实时目标检测应用。 记得安装必要的库:opencv-python, flask, Pillow, torch (以及YOLOv5相关的依赖)。

    相关文章

    HTML速学教程(入门课程)
    HTML速学教程(入门课程)

    HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

    下载

    本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    WorkBuddy
    WorkBuddy

    腾讯云推出的AI原生桌面智能体工作台

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    Python Flask框架
    Python Flask框架

    本专题专注于 Python 轻量级 Web 框架 Flask 的学习与实战,内容涵盖路由与视图、模板渲染、表单处理、数据库集成、用户认证以及RESTful API 开发。通过博客系统、任务管理工具与微服务接口等项目实战,帮助学员掌握 Flask 在快速构建小型到中型 Web 应用中的核心技能。

    106

    2025.08.25

    Python Flask Web框架与API开发
    Python Flask Web框架与API开发

    本专题系统介绍 Python Flask Web框架的基础与进阶应用,包括Flask路由、请求与响应、模板渲染、表单处理、安全性加固、数据库集成(SQLAlchemy)、以及使用Flask构建 RESTful API 服务。通过多个实战项目,帮助学习者掌握使用 Flask 开发高效、可扩展的 Web 应用与 API。

    81

    2025.12.15

    ajax教程
    ajax教程

    php中文网为大家带来ajax教程合集,Ajax是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,Ajax可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。php中文网还为大家带来ajax的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

    166

    2023.06.14

    ajax中文乱码解决方法
    ajax中文乱码解决方法

    ajax中文乱码解决方法有设置请求头部的字符编码、在服务器端设置响应头部的字符编码和使用encodeURIComponent对中文进行编码。本专题为大家提供ajax中文乱码相关的文章、下载、课程内容,供大家免费下载体验。

    170

    2023.08.31

    ajax传递中文乱码怎么办
    ajax传递中文乱码怎么办

    ajax传递中文乱码的解决办法:1、设置统一的编码方式;2、服务器端编码;3、客户端解码;4、设置HTTP响应头;5、使用JSON格式。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

    125

    2023.11.15

    ajax网站有哪些
    ajax网站有哪些

    使用ajax的网站有谷歌、维基百科、脸书、纽约时报、亚马逊、stackoverflow、twitter、hacker news、shopify和basecamp等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

    261

    2024.09.24

    scripterror怎么解决
    scripterror怎么解决

    scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

    533

    2023.10.18

    500error怎么解决
    500error怎么解决

    500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

    385

    2023.10.25

    Python WebSocket实时通信与异步服务开发实践
    Python WebSocket实时通信与异步服务开发实践

    本专题聚焦 Python 在实时通信场景中的开发实践,系统讲解 WebSocket 协议原理、长连接管理、消息推送机制以及异步服务架构设计。内容包括客户端与服务端通信实现、连接稳定性优化、消息队列集成及高并发处理策略。通过完整案例,帮助开发者构建高效稳定的实时通信系统,适用于聊天应用、实时数据推送等场景。

    7

    2026.03.18

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    最新Python教程 从入门到精通
    最新Python教程 从入门到精通

    共4课时 | 22.5万人学习

    Django 教程
    Django 教程

    共28课时 | 5.1万人学习

    SciPy 教程
    SciPy 教程

    共10课时 | 2万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号