質問編集履歴
3
更新
test
CHANGED
File without changes
|
test
CHANGED
@@ -226,4 +226,4 @@
|
|
226
226
|
|
227
227
|
```
|
228
228
|
|
229
|
-
またこのプログラムはhttp://www.digifie.jp/blog/archives/1438のプログラムを参考にして作ったものですが円を検出した途端に終了してしまいます
|
229
|
+
またこのプログラムは[http://www.digifie.jp/blog/archives/1438](http://www.digifie.jp/blog/archives/1438)のプログラムを参考にして作ったものですが円を検出した途端に終了してしまいます
|
2
更新
test
CHANGED
File without changes
|
test
CHANGED
@@ -143,3 +143,87 @@
|
|
143
143
|
```
|
144
144
|
|
145
145
|
このプログラムは画像を読み込んで円検出するもので画像ならうまくいきます。
|
146
|
+
|
147
|
+
|
148
|
+
|
149
|
+
```python
|
150
|
+
|
151
|
+
import numpy as np
|
152
|
+
|
153
|
+
import cv2
|
154
|
+
|
155
|
+
|
156
|
+
|
157
|
+
cam = cv2.VideoCapture(0)
|
158
|
+
|
159
|
+
|
160
|
+
|
161
|
+
while(cam.isOpened()):
|
162
|
+
|
163
|
+
|
164
|
+
|
165
|
+
ret, frame = cam.read()
|
166
|
+
|
167
|
+
|
168
|
+
|
169
|
+
frame = frame[:,::-1]
|
170
|
+
|
171
|
+
|
172
|
+
|
173
|
+
size = (640, 480)
|
174
|
+
|
175
|
+
frame = cv2.resize(frame, size)
|
176
|
+
|
177
|
+
|
178
|
+
|
179
|
+
gray = cv2.cvtColor(frame, cv2.COLOR_RGB2GRAY)
|
180
|
+
|
181
|
+
|
182
|
+
|
183
|
+
gray = cv2.GaussianBlur(gray, (33,33), 1)
|
184
|
+
|
185
|
+
|
186
|
+
|
187
|
+
|
188
|
+
|
189
|
+
colimg = frame.copy() #cv2.cvtColor(gray, cv2.COLOR_GRAY2BGR)
|
190
|
+
|
191
|
+
|
192
|
+
|
193
|
+
|
194
|
+
|
195
|
+
circles = cv2.HoughCircles(gray, cv2.HOUGH_GRADIENT, 1, 60, param1=10, param2=85, minRadius=10, maxRadius=80)
|
196
|
+
|
197
|
+
if circles != None:
|
198
|
+
|
199
|
+
circles = np.uint16(np.around(circles))
|
200
|
+
|
201
|
+
for i in circles[0,:]:
|
202
|
+
|
203
|
+
|
204
|
+
|
205
|
+
cv2.circle(colimg,(i[0],i[1]),i[2],(255,255,0),2)
|
206
|
+
|
207
|
+
|
208
|
+
|
209
|
+
cv2.circle(colimg,(i[0],i[1]),2,(0,0,255),3)
|
210
|
+
|
211
|
+
|
212
|
+
|
213
|
+
|
214
|
+
|
215
|
+
cv2.imshow('preview', colimg)
|
216
|
+
|
217
|
+
if cv2.waitKey(1) & 0xFF == ord('q'):
|
218
|
+
|
219
|
+
break
|
220
|
+
|
221
|
+
|
222
|
+
|
223
|
+
cap.release()
|
224
|
+
|
225
|
+
cv2.destroyAllWindows()
|
226
|
+
|
227
|
+
```
|
228
|
+
|
229
|
+
またこのプログラムはhttp://www.digifie.jp/blog/archives/1438のプログラムを参考にして作ったものですが円を検出した途端に終了してしまいます
|
1
改善
test
CHANGED
File without changes
|
test
CHANGED
@@ -106,7 +106,7 @@
|
|
106
106
|
|
107
107
|
|
108
108
|
|
109
|
-
img = cv2.imread('
|
109
|
+
img = cv2.imread('ファイル名',0)
|
110
110
|
|
111
111
|
img = cv2.medianBlur(img,5)
|
112
112
|
|