che*_*chi 5 c++ opencv image-processing hough-transform opencv-contour
我试图使用不同的方法检测灰度图像中的白色矩形:轮廓检测和霍夫变换.不幸的是,我正在处理的图像有一些限制,即
对于contonours方法,一些图像的轮廓被打破.此外,图像可能包含矩形等特征(例如字符"D").我不确定这是不是一个好方法.
我看过许多文章/论坛建议使用Hough变换检测矩形,如下面的帖子.不幸的是,我必须设置最小行长度的小值,并看到重复的行.我不知道如何处理上面提到的几点(例如,组合所有重复的行并为每个边选择一行,如何区分大多数部分的特征是线但是像'D'那样的小弧,以及如何隔离正方形,其中一条边与一条长直线合并,等等.
欢迎任何建议!
编辑:添加一些图片

角色D.

带徽标的矩形和边缘与长直线合并

梯形(顶部有阴影,底部形成梯形)
我建议您尝试在每个图像上使用二进制阈值(自适应或其他),这将为轮廓检测提供一些清晰的线条。您还可以腐蚀/膨胀图像以消除噪声(例如第二个图像中的细线)
然后使用轮廓检测,并对轮廓进行计数,找到图像中具有四个边的最大对象(这可能是您的对象)。
在使用二值/腐蚀之前制作图像的副本,以便一旦通过轮廓检测获得感兴趣的区域,就可以将副本图像裁剪到该区域。
抱歉,示例链接是用 python 编写的,但我确信一旦您明白了这个想法,将其移植到 C++ 将会很容易。
希望这可以帮助。
编辑
我自己尝试了上述方法,对每个图像进行阈值处理、轮廓检测,然后围绕最大的轮廓集绘制边界框。
下面看结果:

最大轮廓集周围的边界框

同样的,在原始图像上绘制
