今作っているプログラムで、赤色抽出まで完了しているのですが、その後座標抽出を行いたいです。
この下出ている4つの矢印の真ん中あたりの座標のデータだけをExcelのデータとして書き込みを行うプログラムを作りたいのですが、ここからどのようなプログラムを書けばいいかわからず止まっている状態です。二値化した画像からでも、赤色の画像どちらから読み取っても可能です。
利用環境
Python
1#-*- coding:utf-8 -*- 2import cv2 3import numpy as np 4 5# 赤色の検出 6def detect_red_color(img): 7 # HSV色空間に変換 8 hsv = cv2.cvtColor(img, cv2.COLOR_BGR2HSV) 9 10 # 赤色のHSVの値域1 11 hsv_min = np.array([0,200,50]) 12 hsv_max = np.array([30,255,255]) 13 mask1 = cv2.inRange(hsv, hsv_min, hsv_max) 14 15 # 赤色のHSVの値域2 16 hsv_min = np.array([150, 200, 50]) 17 hsv_max = np.array([179,255,255]) 18 mask2 = cv2.inRange(hsv, hsv_min, hsv_max) 19 20 # 赤色領域のマスク(255:赤色、0:赤色以外) 21 mask = mask1 + mask2 22 23 # マスキング処理 24 masked_img = cv2.bitwise_and(img, img, mask=mask) 25 26 return mask, masked_img 27 28 29img = cv2.imread("frequency.png") 30 31# 色検出(赤、緑、青) 32red_mask, red_masked_img = detect_red_color(img) 33 34# 結果を出力 35cv2.imwrite("red.png", red_mask) 36cv2.imwrite("red1.png", red_masked_img) 37
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/10/22 01:53