🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
OpenCV

OpenCV(オープンソースコンピュータービジョン)は、1999年にインテルが開発・公開したオープンソースのコンピュータビジョン向けのクロスプラットフォームライブラリです。

Raspberry Pi

Raspberry Piは、ラズベリーパイ財団が開発した、名刺サイズのLinuxコンピュータです。 学校で基本的なコンピュータ科学の教育を促進することを意図しています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

967閲覧

pythonで同時に複数枚の画像で特定色を認識して複数のウィンドウに表示させたい

退会済みユーザー

退会済みユーザー

総合スコア0

OpenCV

OpenCV(オープンソースコンピュータービジョン)は、1999年にインテルが開発・公開したオープンソースのコンピュータビジョン向けのクロスプラットフォームライブラリです。

Raspberry Pi

Raspberry Piは、ラズベリーパイ財団が開発した、名刺サイズのLinuxコンピュータです。 学校で基本的なコンピュータ科学の教育を促進することを意図しています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2019/11/01 09:53

下のコードは画像から特定色を認識するコードです。
これはまだ一枚の画像を認識するだけなので、同時に複数の画像を認識して、複数のウィンドウで表示、または1つのウィンドウにまとめて結果を表示したいのですが、どのようにコードを変えたら良いでしょうか。

import cv2 import numpy as np def find_rect_of_target_color(image): hsv = cv2.cvtColor(image, cv2.COLOR_BGR2HSV_FULL) h = hsv[:, :, 0] s = hsv[:, :, 1] mask = np.zeros(h.shape, dtype=np.uint8) mask[(h > 240) & ((150 > s) & (s < 100))] = 255 mask, contours, hierarchy = cv2.findContours(mask, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE) rects = [] for contour in contours: approx = cv2.convexHull(contour) rect = cv2.boundingRect(approx) rects.append(np.array(rect)) return rects img = cv2.imread('/home/pi/picture/test1.png') rects = find_rect_of_target_color(img) if len(rects) > 0: rect = max(rects, key=(lambda x: x[2] * x[3])) cv2.rectangle(img, tuple(rect[0:2]), tuple(rect[0:2] + rect[2:4]), (0, 0, 255), thickness=2) cv2.imshow("red", img) cv2.waitKey(0) cv2.destroyAllWindows()

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

とりあえず動きますが、詳細は調整ください。

  1. mask[(h > 240) & ((150 > s) & (s < 100))] = 255

((150 > s) & (100 > s))を変形すると(150 > s) & (s < 100))となります。
これはsが150より小さくて100より小さいとなります。
私には具体的な値の範囲がわかりませんので、より広い (150 > s)にしました。

  1. cv2.findContours

帰ってくる値が3つ、と指定されていましたが、contours, hierarchyの2つが正解でしたので、そのように修正しました。

  1. ファイルの読み出し

今回はとりあえず動くことが重要だと思いますので、以下のように決め打ちしました。
img_list = ['/home/pi/picture/test1.png','/home/pi/picture/test2.png','/home/pi/picture/test3.png']
実際にはファイル検索のような方法でリストを作った方がスマートだと思います。

  1. 連結

for文の外側で連結しています。'np.vstack'や'np.hstack'で連結できます。

Python3

1 2import cv2 3import numpy as np 4 5def find_rect_of_target_color(image): 6 hsv = cv2.cvtColor(image, cv2.COLOR_BGR2HSV_FULL) 7 h = hsv[:, :, 0] 8 s = hsv[:, :, 1] 9 mask = np.zeros(h.shape, dtype=np.uint8) 10 mask[(h > 240) & (150 > s)] = 255 11 cv2.imshow("mask",mask) 12 13 # mask, contours, hierarchy = cv2.findContours(mask, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE) 14 contours, hierarchy = cv2.findContours(mask, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE) 15 16 rects = [] 17 for contour in contours: 18 approx = cv2.convexHull(contour) 19 rect = cv2.boundingRect(approx) 20 rects.append(np.array(rect)) 21 return rects 22 23 24##################### 25# 読み出し元の定義 26##################### 27img_list = ['/home/pi/picture/test1.png','/home/pi/picture/test2.png','/home/pi/picture/test3.png'] 28 29##################### 30# 繰り返し処理 (img_list の中のaddrを一つずつ読み込む) 31##################### 32for addr in img_list: 33 34 ##################### 35 #ファイルを読み出す実体 36 ##################### 37 img = cv2.imread(addr) 38 rects = find_rect_of_target_color(img) 39 if len(rects) > 0: 40 rect = max(rects, key=(lambda x: x[2] * x[3])) 41 cv2.rectangle(img, tuple(rect[0:2]), tuple(rect[0:2] + rect[2:4]), (0, 0, 255), thickness=2) 42 43 ##################### 44 #画像を表示 45 ##################### 46 cv2.imshow("red", img) 47 cv2.waitKey(0) 48 49 ##################### 50 #画像を連結 51 ##################### 52 img_array.append(img) 53 54 55##################### 56#画像を表示 57##################### 58img_stacked = np.vstack(np.array(img_array)) 59 60cv2.imshow("STACKED",img_stacked) 61cv2.waitKey(0) 62cv2.destroyAllWindows() 63 64

投稿2019/11/01 22:59

編集2019/11/01 23:19
退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2019/11/02 03:54

やってみましたが一枚しか、画像が表示されませんでした。 img_list = ['/home/pi/picture/test1.png','/home/pi/picture/test2.png','/home/pi/picture/test3.png'] ここの画像の名前をそれぞれ指定しただけなのですが、実行するに当たって他にするべきことはありますか?
退会済みユーザー

退会済みユーザー

2019/11/03 21:41 編集

img_stacked = np.vstack(np.array(img_array)) の部分で検索結果(img_array)を一枚(img_stacked )にまとめて表示できていると思います。 もし生画像しか表示されていないようであれば、HSVの制限値を緩くしないといけないと思います。例えば、255未満なら、や、0以上ならを指定すれば(デバグ用ではありますが)検出出来たらどう見えるか検証できますね。 > やってみましたが一枚しか、画像が表示されませんでした。 これは > または1つのウィンドウにまとめて結果を表示 を満たしていると考えます。いかがでしょうか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問