- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我发现一种算法可以消除照片的凸度,从而惹上麻烦。如您所见,照片是从书页上捕获的,我想去除凸面。我的问题类似于this,但是我所拥有的只是页面边界作为输入,我既没有网格也无法通过处理算法找到。
我想在下面的照片中将其作为正确的输出。
显然,首先要考虑的是透视变换。但是,您可以看到结果并不乐观:
最佳答案
这是解决您问题的可能途径。主要思想是识别文本,创建带有某种形态的 super Blob ,找到该 super Blob 的4个角,然后将这些点馈送到透 View “unwarper”(或整流器,或您想要称呼的那个)透视校正方法)。
首先将图像转换为灰度,然后将自适应阈值应用于图像。尝试使用参数更适合您的测试的高斯或均值方法。这是我在稍微调整一下值后获得的结果:
现在,想法是仅隔离文本。我应用的解决方案是:获得最大的 Blob 并将其从原始图像中减去。您将需要一种方法来计算每个二进制Blob的面积。 Check this上一篇文章,提供有关如何实现的建议。
这些是图片中最大的 Blob :
从原始图像中减去最大的 Blob 。结果如下:
如您所见,文本几乎是孤立的。让我再次应用区域滤镜来清理像素点。这次消除了小 Blob 。结果如下:
很好,在操作过程中会丢失一些字符,但是没关系。我们需要一个漂亮的连续文本块,因为我们要扩展的 hell 。我尝试应用大小为5和5 Op迭代的矩形结构元素。 侵 eclipse 输出,之后再进行5次迭代,因此最终得到了一个不错的-孤立的- super Blob ,以前的文本是:
一探究竟。您看到的3个标记是我在图像上检测到的最大 Blob 的质心。我们需要找到 super Blob 的 4个角。图像中最大的 Blob 是我们所追求的。我决定重新使用面积过滤器,并寻找面积最大的 Blob 。这是孤立的 super Blob :
从这里开始,操作非常简单。同样,目标是获得该Blob的四个角。您可以拟合矩形或应用边缘检测器,然后进行霍夫变换,以获得跟随 super Blob 边缘的直线。
我决定先应用 Canny Edge检测器,然后再应用 Hough转换。当然,我对转换进行了调整,以仅过滤出我感兴趣的可能的直线,即一定长度以上的直线。这是线路检测的结果:
图片上还有一些额外的信息。您看到的标记(红色和黄色)是线条的起点/终点。我的想法是找到这些线,然后计算这些点的平均值。这个想法是,我们有一个由“象限”分开的点簇。如果我们计算每个象限的每条线的起点和终点的平均值,我们将得到4个平均值–这些是 super Blob 的拐角的近似值!
我将K-means应用于行的起点和终点,但是您非常喜欢其他处理方法。没关系。我的近似角由上图中的大红色O标记标识。
正如我建议的那样,请尝试为这些角指定一个固定的输出位置。我为要映射的角定义了红色矩形。对于此测试,我几乎手动调整了矩形。透视校正产生以下结果:
一些建议:
关于python - OpenCV-如何消除凸轮扫描仪中的凸度缺陷?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60134783/
我的 slideToggle 在幻灯片切换的底部有点跳动。会不会是因为那里有一个按钮之类的。任何使它更平滑的方法。尝试使用缓动但不是很成功。有什么建议 点击视频设置自己看看 The site $(do
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
概述: 我的 B 对象是一个 100 000 * 5000 的 2 GB 大矩阵 我的 A 对象较小 1000 * 5000 analyse_with_glm <- function(Y) { c
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 6年前关闭。 Improve t
我在从 SQL Server (2008R2) 数据库中的 NVARCHAR 字段检索加密数据时遇到了问题,对于某些记录,我的 C# .NET 应用程序中数据的字符串值与数据库记录中的数据字符串值不同
我从 main.cpp 中包含两个头文件,它们在匿名命名空间中具有以下定义:const string strToken = ("%");使用 g++ 4.9 版编译结果如下: In file incl
我正在测试的代码中出现信任边界冲突。该代码在 session 中添加表单,并且由于违反信任边界而存在缺陷 Inside Struts Action class execute method { Ed
这个问题没有与之相关的实际问题,它更多的是一个好奇的问题,想知道我是否过于字面意思;)。 所以我一直在努力尽可能多地理解 c++ 标准。今天,在深入研究标准时,我注意到了这一点 (ISO/IEC 14
在我的数据库中,我必须做一个Circular Reference(cycle)来获取我想要的数据,我不知道如何重新排序表来获取我想要的数据而不需要循环. 这是我的数据库的模式(或模型)——只有表名是英
我有一个代表一组数字的类。构造函数接受三个参数: startValue 、 endValue 和 stepSize 。 该类负责保存一个列表,其中包含考虑 stepSize 的开始值和结束值之间的所有
如何删除下图中标记的三个间隙? 此代码可在 http://jsfiddle.net/69zj6smo/ 获得- 调整渲染区域的大小以查看通常存在的一些线条。 让我感到困惑的是,我认为我总是创建这样的流
double 的位格式在第一位存储符号。 double的C#哈希算法是高低32位二进制异或。 因此,当您对 double A 及其负数 -A 进行哈希处理时,哈希值的唯一区别在于第一位。 要散列多个字
当我在 Action 中使用重定向时,afterAction 方法(在 controller.php 中)不起作用!我该如何解决这个问题? 注意:我不能使用 beforeAction 因为我在我的 A
毫无疑问,还有其他可能更好的方法可以做到这一点,但我正在努力了解这里发生了什么。 在下面的示例中,coverity 在第四行报告了 FORWARD_NULL 缺陷。 double? foo = nul
我们希望针对 Jenkins 中失败的构建自动在 Jira 中创建缺陷。如果您成功完成了此操作,可以与我分享吗? 最佳答案 您应该能够使用JIRA plugin来做到这一点,以及“JIRA:创建问题”
有人能解释一下为什么 VeraCode 似乎认为使用 name 作为公共(public)属性(property)是一个坏主意,并提出了一个好的缓解措施吗? 代码(JavaScript): var Ba
我认为这是 C++11 标准中的一个(次要)缺陷。在 [dcl.dcl] 中我们有: simple-declaration: decl-specifier-seqopt init-
我做了以下... private static IDbConnectionProvider CreateSqlConnectionProvider(DbConfig dbConfig) { r
我现在在运行我的 cakephp 应用程序时遇到了很多麻烦。 在将 vom lenny 升级为 squeeze(甚至尝试完全重新安装 sqeeze)之后,imagick 的速度非常慢,以至于它只是关闭
我收到来自 Veracode 的信任边界违规。我的代码是 userName= req.getParameter(Constant.USERNAME); session.setAttribute(Con
我是一名优秀的程序员,十分优秀!