【发布时间】:2018-07-01 06:10:39
【问题描述】:
使用 python - OpenCV 我已成功读取以下图像,检测矩形,裁剪它们并将每个矩形保存为图像。
这是我成功裁剪并保存为图像的矩形示例。 (所以会有 12 个)
然后处理每个矩形图像,以便隔离圆并为每个圆创建一个新图像 - 我也使用 cv2.HoughCircles 成功地做到了。
图像A 的输出包含如下所示的圆圈:
现在:我需要做的是将绿色圆圈之外的所有内容都删除并将绿色圆圈之外的所有内容转换为黑色,然后得到B(只有绿色圆圈):
问题是:如何从A 得到B。
我从OpenCV : Remove background of an image 获取代码,但它不适用于图像A 作为例外,而是输出这样的图像:
这是取自OpenCV : Remove background of an image 的代码。
circle_path_test = 'D:\rec.png'
img = cv2.imread(circle_path_test)
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
## (2) Threshold
th, threshed = cv2.threshold(gray, 127, 255, cv2.THRESH_BINARY_INV|cv2.THRESH_OTSU)
## (3) Find the min-area contour
_, cnts, _ = cv2.findContours(threshed, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)
cnts = sorted(cnts, key=cv2.contourArea)
for cnt in cnts:
if cv2.contourArea(cnt) > 100:
break
## (4) Create mask and do bitwise-op
mask = np.zeros(img.shape[:2],np.uint8)
cv2.drawContours(mask, [cnt],-1, 255, -1)
dst = cv2.bitwise_and(img, img, mask=mask)
## Save it
# cv2.imshow("dst.png", dst);cv2.waitKey()
#rec_img_name_without_extension ,img_ext = os.path.splitext(circle_path_test)
cv2.imwrite(os.path.join(os.getcwd(), 'dst_circle_gray - Copy.png') , dst)
【问题讨论】:
-
明确一点:除了中心还有其他圆圈吗?其他区域会是绿色还是与中心圆相似?
-
除了中间的那个圆圈外,没有其他圆圈。是的。圆圈外的其他一些区域可以是绿色或类似于圆圈内的颜色。
-
好的,我会更新的。