实战用OpenCV实现页面扭曲矫正

Posted 小白学视觉

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了实战用OpenCV实现页面扭曲矫正相关的知识,希望对你有一定的参考价值。


重磅干货,第一时间送达

前言


今天要分享的内容是关于页面扭曲矫正的内容,为了让大家有一个相关的概念,下面先预览一下效果图


【实战】用OpenCV实现页面扭曲矫正




页面扭曲矫正的原理


作者写这篇文章的目的也很有意思,因为 作者的妻子是一个老师,她的学生经常要发一些图片的作业给她,但是难免由于拍照技术和条件等各种原因,导致批改作业的难度提升,因此作者为了他的老婆,做出来了这一套方案。(爱的魔力)


【实战】用OpenCV实现页面扭曲矫正


对于一些经典的文本矫正的思路(例如Leptonica dewarping method 和 the CTM method)将问题分解为:

1. 将文本分成几行线

2.  找到使得线平行和水平的映射或坐标变换


本文作者同样采用了类似的思路,构建了一个参数模型用于页面(文本)的矫正,模型主要考虑的参数:

  • 页面在三维空间中的旋转向量   r 和平移向量 t

  • 指定页面表面的两个曲率   α  and  β

  • 页面上n个水平跨度的垂直偏移

  • 对于每个跨度,水平跨度中 m个点的水平偏移量


对于上面的一些参数,本人的理解是页面扭曲存在这旋转和偏移的变换,因为把文本内容分成几行,因此将每一行文本看成是一条曲线,这里假设扭曲后变成三次样条曲线,由两个系数 a 和 b 控制。垂直偏移是指分割后的每行之间的距离,水平偏移是指对每条线上设置点,用于后续的矫正变换处理。

(个人理解,可能与原文存在一点的偏差)

【实战】用OpenCV实现页面扭曲矫正


接下来的操作就非常牛了,作者通过对页面进行模拟,设置不同参数用于观察其中的规律


【实战】用OpenCV实现页面扭曲矫正

最后作者发现当设置的参数固定后,页面上的每个关键点都能在图片的平面内找到确定的对应点。


【实战】用OpenCV实现页面扭曲矫正


红色的是文本上检测到的关键点,蓝色的是通过模型的重投影的点。左图的蓝色点都是共线的(假设一开始文本是直线的),而右图是将确定页面的姿态/形状,使得蓝色点几乎上红色点上。




实现的细节


上面是大致的实现原理,接下来是作者实现功能的主要步骤:

1、获取页面的边界。这里并不是采用整幅图去处理,而是非常的巧妙采用内部文本内容以及文本与边界大致距离去确定页面的边界。


2、检测文本的轮廓。通过自适应阈值——> 膨胀+腐蚀——> 连通区域分析+PCA来近似文本

【实战】用OpenCV实现页面扭曲矫正


3、将文本组成跨度。

【实战】用OpenCV实现页面扭曲矫正


4、样本跨度。在每个跨度上生成代表性点。

【实战】用OpenCV实现页面扭曲矫正


5、创建初始参数估计。实现投影到图片平面内。


6、优化!使重投影的误差变小


7、重新映射图片和阈值。


【实战】用OpenCV实现页面扭曲矫正





总结


该项目是之前用到的,今天特意分享给大家,百度搜索出来的相关内容很少,因为个人觉得分享出来还是蛮有意义的,对于内容的理解由于本人水平有限,可能会存在一定的偏差,但是真的是花了挺大功夫来解读的。


使用起来并不难,但是由于作者的假设,对于并非这情况的文本,以及变形过大的矫正效果并不是非常理想。创作不易,希望能点个在看,转发一手,由于缺少留言功能,因此,只能通过后台的数据反馈才知道自己分享的内容是否真的有帮助到大家,大家的每个阅读在看和转发,我都非常的感谢。


代码和原文链接可以在后台回复”page_dewarp“,获取,建议复制,避免错误。



好消息

小白创建的OpenCV与图像处理交流群前一段时间已经满员,为了满足更多小伙伴的交流需求,我们近期成立了②号交流群,有需求的小伙伴添加小白微信,备注“研究方向+单位/学校+昵称”申请入群。让我们共同创造另一个活跃的交流群。


【实战】用OpenCV实现页面扭曲矫正






以上是关于实战用OpenCV实现页面扭曲矫正的主要内容,如果未能解决你的问题,请参考以下文章

利用OpenCV实现旋转文本图像矫正的原理及OpenCV代码

OpenCV实现文档自动矫正(含源码和测试数据)

Python OpenCV实现文档自动矫正(含源码和测试数据)

opencv实战——图像矫正算法深入探讨

毕业设计 python opencv实现车牌识别 矩形矫正

[python][转载]OpenCV-python 实现图片矫正