以下の図のように様々な画像がランダムで散らばっている画像について一番面積の大きい白い部分だけ残した画像を出力したいときどのような方法をとればよいのでしょうか?pythonでの実装を考えています。よろしくお願いします。
入力画像
出力画像
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
回答3件
0
出力画像では画像の赤い部分が表示されないことに気付いたので少し修正したものが以下のプログラムです。
python
1import cv2 2import numpy as np 3 4# 画像を読み込む。 5gray = cv2.imread('test.png', cv2.IMREAD_GRAYSCALE) 6 7# 輪郭抽出 8# OpenCV 3 の場合 9# contours = cv2.findContours( 10# binary, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)[1] 11contours = cv2.findContours( 12 gray, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)[0] 13 14# 一番面積が大きい輪郭を選択する。 15max_cnt = max(contours, key=lambda x: cv2.contourArea(x)) 16 17# 黒い画像に一番大きい輪郭だけ塗りつぶして描画する。 18out = np.zeros_like(gray) 19mask = cv2.drawContours(out, [max_cnt], -1, color=255, thickness=-1) 20 21# 背景画像と前景画像を合成 22result = np.where(mask==255, gray, out) 23 24cv2.imwrite('out.png', result)
投稿2019/02/25 08:28
退会済みユーザー
総合スコア0
0
ベストアンサー
このような感じでしょうか
python
1import cv2 2import numpy as np 3 4# 画像を読み込む。 5gray = cv2.imread('test.png', cv2.IMREAD_GRAYSCALE) 6 7# 輪郭抽出 8# OpenCV 3 の場合 9# contours = cv2.findContours( 10# binary, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)[1] 11contours = cv2.findContours( 12 gray, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)[0] 13 14# 一番面積が大きい輪郭を選択する。 15max_cnt = max(contours, key=lambda x: cv2.contourArea(x)) 16 17# 黒い画像に一番大きい輪郭だけ塗りつぶして描画する。 18out = np.zeros_like(gray) 19cv2.drawContours(out, [max_cnt], -1, color=255, thickness=-1) 20 21cv2.imwrite('out.png', out)
投稿2019/02/25 04:13
編集2019/02/25 04:15総合スコア21956
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2019/02/25 04:33
2019/02/25 04:34
2019/02/25 04:35
退会済みユーザー
2019/02/25 04:36
0
出力画像では画像の赤い部分が表示されないことに気付いたので少し修正したものが以下のプログラムです。
python
1import cv2 2import numpy as np 3 4# 画像を読み込む。 5gray = cv2.imread('test.png', cv2.IMREAD_GRAYSCALE) 6 7# 輪郭抽出 8# OpenCV 3 の場合 9# contours = cv2.findContours( 10# binary, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)[1] 11contours = cv2.findContours( 12 gray, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)[0] 13 14# 一番面積が大きい輪郭を選択する。 15max_cnt = max(contours, key=lambda x: cv2.contourArea(x)) 16 17# 黒い画像に一番大きい輪郭だけ塗りつぶして描画する。 18out = np.zeros_like(gray) 19mask = cv2.drawContours(out, [max_cnt], -1, color=255, thickness=-1) 20 21# 背景画像と前景画像を合成 22result = np.where(mask==255, gray, out) 23 24cv2.imwrite('out.png', result)
投稿2019/02/25 08:30
退会済みユーザー
総合スコア0
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2019/02/25 08:32
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。