質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
85.50%
Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Q&A

解決済

1回答

1855閲覧

任意の画像を二値化して四角で囲みたい

Mr_K

総合スコア28

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

0グッド

0クリップ

投稿2019/06/10 10:33

任意の画像を二値化して四角で囲みたいのですが以下のようなエラーが出てしまい困っています.
https://ymgsapo.com/2018/12/12/find-contours/
これを参考にしました.

python

1import cv2 2import matplotlib.pyplot as plt 3 4#画像を読み込みリサイズ 5#img_path='C:/Users/mkou0/Desktop/interest' 6img = cv2.imread("./spidy01.jpg") 7#img = cv2.resize(img,(300,300)) 8 9#グレースケールにする 10gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY) 11 12#ブラーと二値化 13gray = cv2.GaussianBlur(gray,(7,7),0) 14im2 = cv2.threshold(gray,140,240,cv2.THRESH_BINARY_INV)[1] 15 16#二値化した画像を左にプロット 17plt.subplot(1,2,1) 18plt.imshow(img,cmap='gray') 19 20#輪郭を検出 21cnts = cv2.findContours(im2,cv2.RETR_LIST,cv2.CHAIN_APPROX_SIMPLE)[1] 22 23for pt in cnts: 24 x,y,w,h = cv2.boundingRect(pt) 25 #幅が40以下のものをスキップ 26 if w%40 <= 40: 27 continue 28 print(x,y,w,h) 29 #四角形を赤色で描く 30 cv2.rectangle(img,(x,y),(x+w,y+h),(0,0,255),2) 31#輪郭抽出の結果を右にプロット 32plt.subplot(1,2,2) 33plt.imshow(cv2.cvtColor(img,cv2.COLOR_BGR2RGB)) 34plt.show 35

error

1cv2.error: OpenCV(4.1.0) C:\projects\opencv-python\opencv\modules\imgproc\src\shapedescr.cpp:743: error: (-215:Assertion failed) npoints >= 0 && (depth == CV_32F || depth == CV_32S) in function 'cv::pointSetBoundingRect'

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

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

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

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

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

tiitoi

2019/06/10 10:41

OpenCV のバージョンはいくつですか。 print(cv2.__version__) で確認できます。
Mr_K

2019/06/10 10:42

4.1.0と出てきました
guest

回答1

0

ベストアンサー

OpenCV 3 以前と OpenCV 4 では、findContours() の返り値の仕様が変わりました。

OpenCV3

1image, contours, hierarchy = cv2.findContours(image, mode, method[, contours[, hierarchy[, offset]]])

OpenCV4

1contours, hierarchy = cv2.findContours(image, mode, method[, contours[, hierarchy[, offset]]])

コードの変更が必要な箇所

diff

1- cnts = cv2.findContours(im2,cv2.RETR_LIST,cv2.CHAIN_APPROX_SIMPLE)[1] 2+ cnts = cv2.findContours(im2,cv2.RETR_LIST,cv2.CHAIN_APPROX_SIMPLE)[0]

投稿2019/06/10 10:44

編集2019/06/10 10:45
tiitoi

総合スコア21956

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問