如何实时流式传输具有django帧的opencv框架?

Leo*_*eow 8 python django opencv real-time-data django-views

我正在尝试使用raspberry pi从USB摄像头捕获图像并使用Django框架流式传输我尝试使用StreamingHttpResponse从Opencv2流式传输帧.但是,它只显示1帧而不替换图像.

如何实时替换图像?

这是我的代码.

from django.shortcuts import render
from django.http import HttpResponse,StreamingHttpResponse
import cv2
import time

class VideoCamera(object):
    def __init__(self):
        self.video = cv2.VideoCapture(0)
    def __del__(self):
        self.video.release()

    def get_frame(self):
        ret,image = self.video.read()
        ret,jpeg = cv2.imencode('.jpg',image)
        return jpeg.tobytes()

def gen(camera):
    while True:
        frame = camera.get_frame()
        yield(frame)
        time.sleep(1)

def index(request):
    # response = HttpResponse(gen(VideoCamera())
    return StreamingHttpResponse(gen(VideoCamera()),content_type="image/jpeg")
Run Code Online (Sandbox Code Playgroud)

Leo*_*eow 5

@Ritwick 我所做的是将genindex函数更改为以下

def gen(camera):
    while True:
        frame = camera.get_frame()
        yield(b'--frame\r\n'
        b'Content-Type: image/jpeg\r\n\r\n' + frame + b'\r\n\r\n')

@gzip.gzip_page
def index(request): 
    try:
        return StreamingHttpResponse(gen(VideoCamera()),content_type="multipart/x-mixed-replace;boundary=frame")
    except HttpResponseServerError as e:
        print("aborted")
Run Code Online (Sandbox Code Playgroud)

我使用 python 生成器生成每个相机帧,并使用 StreamingHttpResponse 替换边界标记为multipart/x-mixed-replace

在 django 中有一个 gzip 装饰器功能。

from django.views.decorators import gzip</pre>
Run Code Online (Sandbox Code Playgroud)

提高串流速度。我使用了 django gzip 装饰器方法来 gzip 框架。