好的,既然没有人回答让我试着改变我的问题, 怎么可能试图找出这个盒子?
想要检测的图片
得到这个:
想要的图片
由于盒子里面有白色字母,因此我遇到了麻烦。(我认为) 任何人都可以提供解决方案吗?
我开始使用简历,做一个简单的项目来学习。 我试图在盒子里面装盒子并计算它们。 我正在检测边缘并执行Thresh二进制inv。 我得到了这个,我觉得这很好,我应该可以使用,
处理后的图片
在我继续进行形状检测后,我只找到一个盒子,一个大盒子。
我想到的是: A)问题是里面的盒子没有完成" B)线不是段
但是对于我读到的内容,如果它对边缘进行处理,它应该看到它有4个,并被检测为矩形。
这是一个代码
thresh = cv2.threshold(edges, 177, 255, cv2.THRESH_BINARY_INV)[1]
cv2.imshow("Image", thresh)
cv2.waitKey(0)
cnts = cv2.findContours(thresh.copy(), cv2.RETR_EXTERNAL,
cv2.CHAIN_APPROX_SIMPLE)
cnts = cnts[0] if imutils.is_cv2() else cnts[1]
sd = ShapeDetector()
在我迭代了边缘并尝试以绿色绘制它们之后
我的形状检测器
class ShapeDetector:
def __init__(self):
pass
def detect(self, c):
print("ola")
# initialize the shape name and approximate the contour
shape = "unidentified"
peri = cv2.arcLength(c, True)
approx = cv2.approxPolyDP(c, 0.04 * peri, True)
if len(approx) == 4:
# compute the bounding box of the contour and use the
# bounding box to compute the aspect ratio
(x, y, w, h) = cv2.boundingRect(approx)
ar = w / float(h)
print( "Found one!")
shape = "rectangulo"
return shape
提前致谢
答案 0 :(得分:1)
而不是cv2.RETR_EXTERNAL(仅检索外部轮廓),您应该使用其他内容,例如cv2.RETR_LIST(包含所有轮廓的简单列表)或cv2.RETR_TREE(层次结构中的所有轮廓)。
请参阅https://docs.opencv.org/3.1.0/d9/d8b/tutorial_py_contours_hierarchy.html
编辑: RETR_TREE更复杂,但为您提供其他轮廓内部轮廓的信息,因此您可以忽略其中一些轮廓。
如果想要完美的矩形,则应绘制boundingRect()的结果而不是原始轮廓。
如果您发现重叠的矩形,您还可以添加更多条件来消除它们(例如,w和h应介于最小值和最大值之间)。