teratail header banner
teratail header banner
質問するログイン新規登録

回答編集履歴

1

修正

2020/02/28 09:37

投稿

tiitoi
tiitoi

スコア21960

answer CHANGED
@@ -1,3 +1,28 @@
1
1
  > 画像のドットを検出して図形の変換にする良い方法が思いつきません。
2
2
 
3
- 画像のような白の背景に黒の4つの円が描かれている画像であれば、「輪郭抽出して、円の中心を求める」または「ハフ変換で円検出する」のどちらかの方法で4点の中心が求まりますので、あとは質問に記載のブログにあるようにモルフォロジー変換行列を求めればよいと思います。
3
+ 画像のような白の背景に黒の4つの円が描かれている画像であれば、「輪郭抽出して、円の中心を求める」または「ハフ変換で円検出する」のどちらかの方法で4点の中心が求まりますので、あとは質問に記載のブログにあるようにモルフォロジー変換行列を求めればよいと思います。
4
+
5
+ ## 輪郭抽出で4つの円の中心を求める例
6
+
7
+ ```python
8
+ import cv2
9
+
10
+ img = cv2.imread("sample.png")
11
+
12
+ # グレースケールに変換する。
13
+ gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
14
+
15
+ # 2値化
16
+ ret, binary = cv2.threshold(gray, 100, 255, cv2.THRESH_BINARY_INV + cv2.THRESH_OTSU)
17
+
18
+ # 輪郭抽出
19
+ contours, hierarchy = cv2.findContours(binary, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
20
+
21
+ points = []
22
+ for cnt in contours:
23
+ center, radius = cv2.minEnclosingCircle(cnt)
24
+ points.append(center)
25
+ print(points)
26
+ # [(161.5, 224.0), (77.5, 174.0), (171.5, 86.0), (56.5, 58.0)]
27
+
28
+ ```