java-opencv投影法提取内容

前言

投影法是最近学到的一个opencv内容提取和分割技巧,就好像前面一篇文章java-opencv再谈表格识别用到的技巧感觉很惊艳。了解了后思路很简单,但是做好也蛮难的因为干扰因素太多了,这里只是简单的用个demo分享下这个技巧。

基本思路

  1. 核心思想就是统计。
  2. 投影法分为水平和垂直两个方向。
  3. 首先把图像二值化。因为二值化后图像就是白(255)和黑(0)了。
  4. 水平法就是统计水平的白或者黑的个数。然后通过一些平均值或者根据图片特性预估的值过滤掉一些数据(因为有干扰项和文字自身的个性吧每个字的水平像素点不是均等的,可以看下面图片)。
  5. 计算其均值、方差等统计量,或者进行阈值分割
  6. 垂直法和水平思路一样。
  7. 通过水平和垂直我们可以得到坐标,如果是文字识别的话我们可以通过切割然后OCR就可以得到我们想要的东西。
  8. 最后结合之前的一些方式提取内容最终都不是万能的(受一些不确定参数的影响),但AI的万能兼容的模式多?脑回路受限了。
  9. 解决了我之前遇到的问题就是非表格内容的提取,关于表格的识别提取我前面文章写了一些思路。二者结合起来加上实际情况可以处理一些有标题和一些重要内容的且下面带表格的(例如回单)。当然更好的出路是用机器学习了进行切割(最近我入门了tensorflow的图像分割,用身份证号区域做了一个demo,后面我是想把生成的模型用opencv进行加载但是遇到了些问题还没解决)

投影水平发demo

通过demo说下上面的问题,算法很简单但是想要出好的结果不容易。图片样例加demo很容易理解的。

java 复制代码
public static List<Integer> cutImgX2(Mat mat){
    int i, j;
    int nWidth = mat.width(), nHeight = mat.height();
    int[] xNum = new int[nHeight], cNum;
    // 记录像素的平均值,这里的像素平均值也可以通过下面统计然后通过一些算法求出个平均数
    // 我这里demo直接写了个阈值 最简单点根据高度求个平均值然后过滤一点
    // 这里的影响我在上面第4点说过了,下面我贴个图以看就直到了,干扰和文字的影响
    int average = 100;
    // 统计出每行黑色像素点的个数
    for (i = 0; i < nHeight; i++) {
        for (j = 0; j < nWidth; j++) {
            //黑色点统计 也可以是别的颜色
            if (mat.get(i, j)[0] == 0) {
                xNum[i]++;
            }
        }
    }

    List<Integer> cutY = new ArrayList<Integer>();
    int lastIndex=0;
    for (i = 0; i < nHeight; i++) {
    //这里是过滤和保存高度的坐标
    //lastIndex我这里主要是项分割出文字的开始高度和结束高度
    //通过上面图片看可能更直观点
        if (xNum[i] > average && (lastIndex==0|| i-lastIndex>20)) {
            cutY.add(i);
            lastIndex=i;
        }
    }
    return cutY;
}
相关推荐
B站计算机毕业设计之家2 分钟前
计算机视觉:基于YOLOv8/YOLOv7/YOLOv6/YOLOv5的零售柜商品检测识别系统(Python+PySide6界面+训练代码)(源码+文档)✅
人工智能·深度学习·opencv·yolo·计算机视觉·零售·1024程序员节
Filotimo_9 分钟前
Spring MVC 数据校验
java·spring·mvc
沐浴露z16 分钟前
Kafka Consumer 详解API,分区分配策略以及消费offset
java·kafka
weixin_4045512425 分钟前
openrewrite Lossless Semantic Trees (LST)
java·tree·yaml·lossless·openrewrite·lst·semantic
一 乐29 分钟前
口腔健康系统|口腔医疗|基于java和小程序的口腔健康系统小程序设计与实现(源码+数据库+文档)
java·数据库·vue.js·小程序·毕设
进击的炸酱面31 分钟前
第三章 线性模型
人工智能·算法·机器学习
YDS82932 分钟前
苍穹外卖 —— 文件上传和菜品的CRUD
java·spring boot·后端
xiguolangzi1 小时前
mysql迁移PG库 主键、唯一处理、批量修改
java·后端
摇滚侠1 小时前
Spring Boot3零基础教程,Actuator 导入,笔记82
java·spring boot·笔记
San301 小时前
在浏览器中运行AI模型:用Brain.js实现前端智能分类
前端·javascript·机器学习