web-dev-qa-db-ja.com

Flask OpenCV画像を使用したビデオストリーム

OpenCV画像のストリームを表示するためにFlaskを使用しようとしています。ROSとZedステレオカメラを使用しています。

問題は、flaskサーバーが壊れた画像アイコンのみを表示することです。問題はcv2.imwrite( 't.jpg'、img)であるため、gen()メソッドにあると推測しています。メソッドは間違った方法ですOpenCVの経験はほとんどありません。

Flaskサーバーが受け取る画像データはInputArrayです。これを変換し、Flask=サーバーで画像を表示する方法が必要です。

私はPython 2.7およびrospy(ROS)を使用しています。

何かアドバイス?

更新:

ZEDカムにアクセスするROSノードのコード:

    #!/usr/bin/env python

# ROS imports
import rospy
from sensor_msgs.msg import Image

# Utils
import numpy as np
import cv2
from cv_bridge import CvBridge, CvBridgeError
import stream


def callback(data):
    """
    param data: data from zed/rgb/image_rect_color topic
    """
    # convert from ROS sensor_msgs/Image to cv2
    bridge = CvBridge()
    try:
        cv_img = bridge.imgmsg_to_cv2(data, desired_encoding='passthrough')
        stream.img = cv_img
    except CvBridgeError as e:
        print(e)
    # show image stream
    # cv2.imshow('zed', cv_img)
    # cv2.waitKey(3)


def zed_sub():
    # initialize ROS node 'zed_sub'
    rospy.init_node('zed_sub')
    # subscribe to the ROS topic 'zed/rgb/image_rect_color'
    rospy.Subscriber('zed/rgb/image_rect_color', Image, callback)
    # keep python from exiting until this node is stopped
    try:
        rospy.spin()
    except KeyboardInterrupt:
        cv2.destroyAllWindows()


if __name__ == '__main__':
    zed_sub()

Flaskサーバーのコード:

#!/usr/bin/env python

from flask import Flask, render_template, Response
import cv2


app = Flask(__name__)
Host = '192.168.1.3'    # on-board computer's IP address
PORT = 8080

img = None


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


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


def gen():
    """Video streaming generator function."""
    global img
    while True:
        try:
            cv2.imwrite('t.jpg', img)
            yield(b'--frame\r\n'
                b'Content-Type: image/jpeg\r\n\r\n' + open('t.jpg', 'rb').read() + b'\r\n')
        except NameError as e:
            print(e)


if __name__ == '__main__':
    app.run(Host=HOST, port=PORT, debug=True, threaded=True)
8
user3173015

ラップトップのウェブカメラ以外のカメラにアクセスするには、次のようなRTSPリンクを使用できますrtsp:// admin:[email protected]:554/h264/ch1/main/av_stream "

どこで

>        username:admin
>         password:12345
>         your camera ip address and port
>         ch1 is first camera on that DVR

お使いのカメラのcv2.VideoCamera(0)をこのようなリンクに置き換えれば、動作します

camera.py

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)
        # 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()

main.py

from flask import Flask, render_template, Response
from camera import VideoCamera

app = Flask(__name__)

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

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('/video_feed')
def video_feed():
    return Response(gen(VideoCamera()),
                    mimetype='multipart/x-mixed-replace; boundary=frame')

if __name__ == '__main__':
    app.run(Host='0.0.0.0', debug=True)

このブログをフォローしてFPSを向上させることができます

https://www.pyimagesearch.com/2015/12/21/increasing-webcam-fps-with-python-and-opencv/

7
Kushal Parikh