回答編集履歴

1

修正

2020/02/28 09:37

投稿

tiitoi
tiitoi

スコア21956

test CHANGED
@@ -3,3 +3,53 @@
3
3
 
4
4
 
5
5
  画像のような白の背景に黒の4つの円が描かれている画像であれば、「輪郭抽出して、円の中心を求める」または「ハフ変換で円検出する」のどちらかの方法で4点の中心が求まりますので、あとは質問に記載のブログにあるようにモルフォロジー変換行列を求めればよいと思います。
6
+
7
+
8
+
9
+ ## 輪郭抽出で4つの円の中心を求める例
10
+
11
+
12
+
13
+ ```python
14
+
15
+ import cv2
16
+
17
+
18
+
19
+ img = cv2.imread("sample.png")
20
+
21
+
22
+
23
+ # グレースケールに変換する。
24
+
25
+ gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
26
+
27
+
28
+
29
+ # 2値化
30
+
31
+ ret, binary = cv2.threshold(gray, 100, 255, cv2.THRESH_BINARY_INV + cv2.THRESH_OTSU)
32
+
33
+
34
+
35
+ # 輪郭抽出
36
+
37
+ contours, hierarchy = cv2.findContours(binary, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
38
+
39
+
40
+
41
+ points = []
42
+
43
+ for cnt in contours:
44
+
45
+ center, radius = cv2.minEnclosingCircle(cnt)
46
+
47
+ points.append(center)
48
+
49
+ print(points)
50
+
51
+ # [(161.5, 224.0), (77.5, 174.0), (171.5, 86.0), (56.5, 58.0)]
52
+
53
+
54
+
55
+ ```