Panasonicのネットワークカメラ(WV-S1511LNJ)を使用しており、
これより得られた映像を使って、物体検出や単純な動画保存を検討しております。
下記プログラムにて、表示することは可能ですが、Githubなどに公開されている、
その他プログラムに読み込ませることも考慮して、VideoCapture構造体で取り込めるようにしたいと考えております。
下記は、requestsを使って表示した参考になりますが、
単純にcap=VideoCapture(”URL”)で取得した場合には、Printにて各値(FPSや解像度)を出力させることは、可能でした。
(おそらく、H.264でストリーミングされているとおもわれます。)
しかし、ret, frame cap.read() と単純に配列を変えようとしてもエラーとなります。
方法としては、ネットワークカメラ側のフォーマットを適応した製品に変更することも考えられますが、コストがかかるため、
プログラムで解決したい次第です。
よろしくお願いいたします。
Python
1import requests 2from requests.auth import HTTPDigestAuth 3 4import io 5from PIL import Image 6import numpy as np 7import cv2 8 9delay = 1 10# カメラのIPアドレス 192.168.0.10 11# 画像データの取得 /cgi-bin/camera 12# 解像度の指定 resolution 13url = "http://00.00.00.00/cgi-bin/camera?resolution=1280" 14 15# 認証情報 16user = "12345" 17pswd = "12345" 18 19while True: 20 21 # 画像の取得 22 rs = requests.get(url, auth=HTTPDigestAuth(user, pswd)) 23 24 # 取得した画像データをOpenCVで扱う形式に変換 25 img_bin = io.BytesIO(rs.content) 26 img_pil = Image.open(img_bin) 27 img_np = np.asarray(img_pil) 28 img = cv2.cvtColor(img_np, cv2.COLOR_RGBA2BGR) 29 cv2.imshow("window_name", img) 30 print(img) 31 np.save("img",img) 32 pil_img = Image.fromarray(img_np) 33 print(pil_img.mode) 34 # RGB 35 pil_img.save('img.jpg') 36 37 if cv2.waitKey(delay) & 0xFF == ord('q'): 38 break
あなたの回答
tips
プレビュー