前提・実現したいこと
以前同プログラムで質問したものです。(遊泳中のメダカの重心を撮る)
現ソースコードでやってると2値化後の映像がなぜか点滅気味でメダカの体も輪郭だけでキレイに映らないです。
撮影条件としては水槽の下から暗室で撮影しており,水槽の上からモニターで照らしている状態です。
前回のように横から照らした状態だと大丈夫なのですが下からの撮影だと画像の状態になってしまいます。
これをまず点滅しない状態+メダカの体がきれいに反映される状態にしたいです。
撮影条件の違いも検討していますがプログラム内でどこがわるいのか教えてくださると幸いです。
該当のソースコード
import cv2 import time import numpy as np movie = cv2.VideoCapture('upvideo.mp4') before = None /前回の画像を保存する変数 fps = int(movie.get(cv2.CAP_PROP_FPS)) /動画のFPSを取得 kernel = np.ones((3,3),np.uint8) kerne2 = np.ones((11,11),np.uint8) while True: /画像を取得 ret, frame = movie.read() /再生が終了したらループを抜ける if ret == False: break gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) if before is None: before = gray.astype("float") continue /現在のフレームと移動平均との差を計算 cv2.accumulateWeighted(gray, before, 0.6)# frameDelta = cv2.absdiff(gray, cv2.convertScaleAbs(before)) /frameDeltaの画像を2値化 thresh = cv2.threshold(frameDelta, 1, 255, cv2.THRESH_BINARY)[1] opening1 = cv2.morphologyEx(thresh, cv2.MORPH_OPEN, kernel) closing = cv2.morphologyEx(opening1, cv2.MORPH_CLOSE, kerne2) label = cv2.connectedComponentsWithStats(closing) /オブジェクト情報を項目別に抽出 n = label[0] - 1 data = np.delete(label[2], 0, 0) center = np.delete(label[3], 0, 0) /ラベリング結果書き出し用に二値画像をカラー変換 color_src = cv2.cvtColor(gray, cv2.COLOR_GRAY2BGR) /オブジェクト情報を利用してラベリング結果を表示 for i in range(n): x1 = data[i][0] + data[i][2] y1 = data[i][1] + data[i][3] /各オブジェクトの重心座標をに黄文字で表示 cv2.putText(color_src, "X: " + str(int(center[i][0])), (x1-10 , y1+15 ), cv2.FONT_HERSHEY_PLAIN, 1, (0, 255, 255)) cv2.putText(color_src, "Y: " + str(int(center[i][1])), (x1-10 , y1+30 ), cv2.FONT_HERSHEY_PLAIN, 1, (0, 0, 255)) time.sleep(0.05/fps) cv2.imshow('movie2',thresh) cv2.imshow('movie',color_src) cv2.imshow('target_bh', closing) /Enterキーが押されたらループを抜ける if cv2.waitKey(1) == 13: break cv2.destroyAllWindows() /ウィンドウを破棄
回答1件
あなたの回答
tips
プレビュー