图片保持空白,烧瓶和多部分/x混合替换

问题描述 投票:0回答:1

我有一个 Flask Web 应用程序,可以读取我的相机,并应该将其显示在我的 Web 浏览器中。但我没有显示它,而是得到了一个空白图像,如下所示:

py 文件

import cv2
import numpy
from flask import Flask, render_template, Response, stream_with_context, Request

video = cv2.VideoCapture(0)
app = Flask(__name__)

def video_stream():
    while(True):
        ret, frame = video.read()
        if not ret:
            break
        else:
            ret, buffer = cv2.imencode('.jpeg',frame)
            frame = buffer.tobytes()
            yield (b'--frame\r\n' b'Content-type: image/jpeg\r\n\r\n' + frame + b'\r\n')

@app.route('/siteTest')

def siteTest():
    return render_template('siteTest.html')

@app.route('/video_feed')

def video_feed():
    return Response(video_stream(), mimetype= 'multipart/x-mixed-replace; boundary = frame')

app.run(host ='0.0.0.0', port= '5000', debug=False)

(由于明显原因更改了IP)

html 文件

<html>
 <head>
    <meta name = "viewport" content = "width = device-width, initial-scale=1">
    <style>
        img{ display: block;
            margin-left: auto;
            margin-right: auto;
        }
        h1 {text-align: center;}
    </style>
 </head>
 <body>
    <img id="bg" src = "{{ url_for('video_feed') }}" style="width: 88%;">
 </body>
</html>

如有任何帮助,我们将不胜感激

我尝试更改响应,但效果与更改 video_stream() 一样不起作用,但我认为我做错了什么。

python flask multipart-mixed-replace
1个回答
1
投票
  1. 从边界 = 框架中删除空格
  2. 重启服务器

代码:

def video_feed():
    return Response(video_stream(), mimetype= 'multipart/x-mixed-replace; boundary=frame')
© www.soinside.com 2019 - 2024. All rights reserved.