Pythonで図形の輪郭の大きさを調べる(OpenCV編)
PythonのOpenCV(cv2)モジュールで描いた図形の輪郭の大きさを調べます。
目次
輪郭が占める面積の計算方法
PythonのOpenCV(CV2)モジュールでfindContoursを使うと図形の輪郭が得られます。具体的な方法は 別の投稿 を参照してください。
この輪郭の内側の面積は、contourAreaメソッドで計算できます。
retval = cv2.contourArea(contour, [oriented])
変数 |
型 |
内容 |
---|---|---|
contour |
ndarray |
輪郭のデータ。 |
oriented |
bool |
省略可。既定値はFalse。方向性を有効にするかどうか。 |
retval |
float |
輪郭が占める面積。 |
方向性についてはよくわかりません。
計算の実施例
この画像から全ての輪郭を抽出して、それぞれの面積を計算してみます。
data:image/s3,"s3://crabby-images/00c49/00c499179cfcd525d9e10208967c5479129ab584" alt="元画像"
コードはこんな感じです。
import cv2
im = cv2.imread('test.png')
im_gray = cv2.cvtColor(im, cv2.COLOR_BGR2GRAY)
retval, im_bw = cv2.threshold(im_gray, 0, 255, cv2.THRESH_BINARY_INV + cv2.THRESH_OTSU)
# 輪郭の検出
contours, hierarchy = cv2.findContours(im_bw, cv2.RETR_LIST, cv2.CHAIN_APPROX_SIMPLE)
# 輪郭を1つずつ書き込んで出力
for i in range(len(contours)):
im_con = im.copy()
print('ID', i, 'Area', cv2.contourArea(contours[i]))
im_con = cv2.drawContours(im_con, contours, i, (0,255,0), 2)
cv2.imwrite('result' + str(i) + '.png', im_con)
出力はこうなります。
data:image/s3,"s3://crabby-images/4d234/4d234b140e64794df629bfdcc2e17298ca106669" alt="ID0"
ID 0 Area 718.0
data:image/s3,"s3://crabby-images/03597/0359749672ff2249d333b10fb4085c6e2d406c00" alt="ID1"
ID 1 Area 5350.5
data:image/s3,"s3://crabby-images/117d9/117d99975641d99645cbae10c413cbae36be184a" alt="ID2"
ID 2 Area 2.0
data:image/s3,"s3://crabby-images/bb154/bb154ee8a9c718612c3f49dbca38b5afc85f9c8f" alt="ID3"
ID 3 Area 2.0
data:image/s3,"s3://crabby-images/76fa9/76fa9ba67d8a145ebd1452ca578c88eb1132f6e8" alt="ID4"
ID 4 Area 5755.5
data:image/s3,"s3://crabby-images/f3d5b/f3d5bf3bb3838a1224f9ec9ff09735452d41cb25" alt="ID5"
ID 5 Area 14848.0
data:image/s3,"s3://crabby-images/5433a/5433a1a1d3b10851836a5854fd2ec4090739d394" alt="ID6"
ID 6 Area 308.0
data:image/s3,"s3://crabby-images/f0cb2/f0cb2802a0bf3bea55c22fae48c037d505120c46" alt="ID7"
ID 7 Area 622.0
data:image/s3,"s3://crabby-images/2c11d/2c11d894df2d826794bddb5189ec908823d98608" alt="ID8"
ID 8 Area 5110.5
data:image/s3,"s3://crabby-images/2c34b/2c34beaa611557f98300615e7474586a07ae4572" alt="ID9"
ID 9 Area 7916.0
実用的には、面積が極端に小さいのを取り除くと使いやすそうです。
公開日
広告
Pythonで画像処理カテゴリの投稿
- Python (Pillow)でグラデーション画像を作る
- PythonでGIFアニメを作る(PILでファイルをつなげる編)
- PythonでOpenCVの画像データをMatplotlibで表示する
- PythonでPDFを画像に変換する(Windows10)
- PythonでPSDファイルをJPEGやPNGに変換する
- Pythonでカラー画像をグレイスケールに変換する(OpenCV編)
- Pythonでフォルダ内に同じ画像がないか検索してみた
- Pythonでマスク画像を作る方法(3選)
- Pythonで図形の外接矩形を描く(OpenCV編)
- Pythonで図形の輪郭の大きさを調べる(OpenCV編)
- Pythonで画像の余白を削除する(OpenCV編)
- Pythonで画像の余白を削除する(Pillow編)
- Pythonで画像の大きさやフォーマットを調べる(Pillow編)
- Pythonで画像の減色をする
- Pythonで画像をトリミングする(Pillow編)
- Pythonで画像を他の画像にペーストする(Pillow編)
- Pythonで画像を回転する(Pillow編)
- Pythonで画像を拡大縮小(リサイズ)する(Pillow編)
- Pythonで画像を読み込み、表示し、保存する(OpenCV編)
- Pythonで画像を読み込み、表示し、保存する(Pillow編)
- Pythonで画像を2値化する(OpenCV編)
- Pythonで記号の輪郭を検出する(OpenCV編)
- PythonとOpenCVで画像をグレースケールに変換してみた
- PythonとOpenCVで画像をネガポジ反転してみた