笔记
在做 OCR 的时候遇到了个坑,在使用了 findContours 查找文字区域的时候,发现返回的文字是倒序的,有时还是无序emmm。
找了很久才发现是这个函数的问题,它的实现算法并不是想当然的从左到右查找标记序号的(从整体来看)。所以要想输出有序结果必须自己实现,如得到区域质心 Centroid ,可参考这篇详解 http://opencvpython.blogspot.com/2012/06/contours-3-extraction.html
而对单行 OCR 文字区域,可以直接在 boudingRect 获取的 Rect 基础上,利用它们的 x 坐标从左到右排序,这样就可以了
备注
findContours 函数具体用法参考这里 Java Code Examples for org.opencv.imgproc.Imgproc.findContours()
public List<Mat> findOrderContours(Mat m) {
List<MatOfPoint> contours = new ArrayList<>();

在使用OpenCV的findContours进行OCR时,发现返回的文字区域顺序可能为倒序或无序。原因是findContours的算法并不按从左到右的顺序标记。解决办法包括计算区域质心进行排序或根据boundingRect的x坐标对单行文字排序。
最低0.47元/天 解锁文章

被折叠的 条评论
为什么被折叠?



