Попробуйте транслировать видео нескольким клиентам, используя cheroot flask и opencv - PullRequest
0 голосов
/ 23 июня 2019

Я пытаюсь создать потоковую передачу видео с моего Raspberry Pi на несколько клиентов. Flask не поддерживает сервер WSGI, поэтому я использую cheroot.wsgi сервер. Я создал сервер ddns, используя noip для трансляции видео потока через Интернет. До сих пор мне удается обслуживать видео только одному клиенту, даже если я использую сервер wsgi.

Вот видео фидер

from flask import Flask, render_template, Response
from camera import VideoCamera
import RPi.GPIO as gpio


gpio.setmode(gpio.BCM)  
gpio.setup(21, gpio.OUT)


app = Flask(__name__)

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')


@app.route('/')
def index():
    return render_template('index.html')



@app.route('/video_feed')
def video_feed():
    return Response(gen(VideoCamera()),mimetype='multipart/x-mixed-replace; boundary=frame')

@app.route('/background_process_test')
def background_process_test():
    gpio.output(21, gpio.HIGH)

    print ("Hello")
    return ("nothing")

@app.route('/background_process_test2')
def background_process_test2():
    gpio.output(21, gpio.LOW)

    print ("Hello")
    return ("nothing")

if __name__ == '__main__':
    app.run()

вот сервер wsgi, использующий cheroot

попробовать: из cheroot.wsgi импортируйте сервер как WSGIServer, PathInfoDispatcher кроме ImportError: печать ( "OK") из cherrypy.wsgiserver импортируйте CherryPyWSGIServer как WSGIServer, WSGIPathInfoDispatcher как PathInfoDispatcher

from main import app
d = PathInfoDispatcher({'/': app})
server = WSGIServer(('0.0.0.0', 5000), d)
if __name__ == '__main__':
    try:
        server.start()
    except KeyboardInterrupt:
        server.stop()

Модуль opencv, который захватывает кадры камеры

import cv2

class VideoCamera(object):
    def __init__(self):
        # Using OpenCV to capture from device 0. If you have trouble capturing
        # from a webcam, comment the line below out and use a video file
        # instead.
        self.video = cv2.VideoCapture(0)
        self.video.set(cv2.CAP_PROP_FRAME_WIDTH, 160)
        self.video.set(cv2.CAP_PROP_FRAME_HEIGHT, 200)
        # If you decide to use video.mp4, you must have this file in the folder
        # as the main.py.
        # self.video = cv2.VideoCapture('video.mp4')

    def __del__(self):
        self.video.release()

    def get_frame(self):
        success, image = self.video.read()
        # We are using Motion JPEG, but OpenCV defaults to capture raw images,
        # so we must encode it into JPEG in order to correctly display the
        # video stream.
        ret, jpeg = cv2.imencode('.jpg', image)
        return jpeg.tobytes()

наконец, веб-страница, которая обслуживает видео канал

<!doctype html>

<html>
<head>
<!--    <link rel="shortcut icon" href="1.ico" type="image/x-icon" />-->

    <title>jindeath</title>



</head>
<body>



hello
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script type=text/javascript>
        $(function() {
          $('a#test').bind('click', function() {
            $.getJSON('/background_process_test',
                function(data) {
              //do nothing
            });
            return false;
          });
        });
                $(function() {
          $('a#test2').bind('click', function() {
            $.getJSON('/background_process_test2',
                function(data) {
              //do nothing
            });
            return false;
          });
        });
</script>

<div class='container'>
    <h3>Test</h3>
        <form>
            <img id="bg" src="{{ url_for('video_feed') }}">
            <a href=# id=test><button class='btn btn-default'>Test</button></a>
            <a href=# id=test2><button class='btn btn-default'>Test</button></a>

        </form>
</body>
</html>

Более того, когда к странице подключается более одного устройства, мой rpi использует 100% своего процессора. любые предложения

...