javacv学习之实现matlab中imfill算法(孔洞填充)

javacv学习之实现matlab中imfill算法(孔洞填充)因生产需要计算图像的面积,首先第一步就是要先将图像中有洞的地方给它填上,网上找了半天说是matlab中的imfill算法就能直接填上,但我对matlab也不熟也不想用它,结果网上搜资料看看到很多C++的博主写的可以直接用opencv搞定,我一想opencv能搞定那肯定javacv也能搞,所以就有了下面的内容。废话不多说直接上代码publicstaticvoidmain(String[]args){System.loadLibrary(Core.NATIVE_LIBRAR

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

因生产需要计算图像的面积,首先第一步就是要先将图像中有洞的地方给它填上,网上找了半天说是matlab中的imfill算法就能直接填上,但我对matlab也不熟也不想用它,结果网上搜资料看看到很多C++的博主写的可以直接用opencv搞定,我一想opencv能搞定那肯定javacv也能搞,所以就有了下面的内容。

废话不多说直接上代码

 public static void main(String[] args) {
        System.loadLibrary(Core.NATIVE_LIBRARY_NAME);
        Mat src = Imgcodecs.imread("C:\\Users\\Administrator\\Desktop\\aa\\2020040113285386.jpg", Imgcodecs.IMREAD_GRAYSCALE);
        Mat out_th = new Mat();//二值化后的图像
        Imgproc.threshold(src, out_th, 220, 255, Imgproc.THRESH_BINARY_INV);//灰度图像二值化
        Imgcodecs.imwrite("C:\\Users\\Administrator\\Desktop\\aa\\out_th.jpg", out_th);

        Size lagerSize = new Size();//这里的mat要比原图周围大一个像素,这里是重点
        lagerSize.height = out_th.height() +2;
        lagerSize.width = out_th.width() +2 ;
        Mat lager = Mat.zeros(lagerSize,out_th.type());
        Mat lager1 = lager.rowRange(1,out_th.rows()+1).colRange(1,out_th.cols()+1);//将图片复制到大图的中间,
        out_th.copyTo(lager1);
        Imgcodecs.imwrite("C:\\Users\\Administrator\\Desktop\\aa\\lager.jpg", lager);
        Imgcodecs.imwrite("C:\\Users\\Administrator\\Desktop\\aa\\lager1.jpg", lager1);
        Mat newMat = out_th.clone();
        Imgproc.floodFill(newMat,lager,new Point(0,0),new Scalar(255));//漫水填充法填充 从0,0开始,有空洞的地方用255代替
        Imgcodecs.imwrite("C:\\Users\\Administrator\\Desktop\\aa\\lager_1.jpg", lager);
        Imgcodecs.imwrite("C:\\Users\\Administrator\\Desktop\\aa\\lager1_1.jpg", lager1);
        Imgcodecs.imwrite("C:\\Users\\Administrator\\Desktop\\aa\\out_th_1.jpg", out_th);
        Imgcodecs.imwrite("C:\\Users\\Administrator\\Desktop\\aa\\newMat.jpg", newMat);
        Mat inv_ = new Mat();
        Core.bitwise_not(newMat,inv_);//二值化图像取反
        Imgcodecs.imwrite("C:\\Users\\Administrator\\Desktop\\aa\\inv_.jpg", inv_);
        Mat or_ = new Mat();
        Core.bitwise_or(inv_,out_th,or_);//二值图像按位或
        Imgcodecs.imwrite("C:\\Users\\Administrator\\Desktop\\aa\\or_.jpg", or_);
        Mat or_inv = new Mat();
        Core.bitwise_not(or_,or_inv);//二值图像取反
        Imgcodecs.imwrite("C:\\Users\\Administrator\\Desktop\\aa\\or_inv.jpg", or_inv);
    }

解决思路参考:https://www.it610.com/article/1297086611263135744.htm

思路大致:

1.先将图片进行二值化处理

2.将图片向外延伸两个像素

3.调用漫水填充法填充

4.得到的图像在做相应的处理就得到填充的图像

最后这里附上原图和最终处理后的图像,中间的图可以自己处理一下就得到了。注意各个阶段图像像素的变化。

javacv学习之实现matlab中imfill算法(孔洞填充)

javacv学习之实现matlab中imfill算法(孔洞填充)

整理后的代码:

/**
     * 漫水填充法填补漏洞
     * @param src 原图进行二值化处理后的图像
     * @return 填补后输出的二值图
     */
    public static Mat floodFill(Mat src){
        Size lagerSize = new Size();//这里的mat要比原图周围大一个像素,这里是重点
        lagerSize.height = src.height() +2;
        lagerSize.width = src.width() +2 ;
        Mat lager = Mat.zeros(lagerSize,src.type());
        Mat lager1 = lager.rowRange(1,src.rows()+1).colRange(1,src.cols()+1);//将图片复制到大图的中间,
        src.copyTo(lager1);
        Mat src_clone = src.clone();
        Imgproc.floodFill(src_clone,lager,new Point(0,0),new Scalar(255));//漫水填充法填充 从0,0开始,有空洞的地方用255代替
        Mat src_clone_inv = new Mat();
        Core.bitwise_not(src_clone,src_clone_inv);//二值化图像取反
        Mat dst = new Mat();
        Core.bitwise_or(src_clone_inv,src,dst);//二值图像按位或
        return dst;
    }

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/194617.html原文链接:https://javaforall.net

(0)
上一篇 2025年11月2日 下午12:43
下一篇 2025年11月2日 下午1:15


相关推荐

  • ncnn笔记_cnn代码

    ncnn笔记_cnn代码最近看了ncnn的源码,代码风格清爽,遂想先抛开VULKAN记录一下它的推理流程。1. 先看个yolov2democsdn上的帖子https://blog.csdn.net/sina

    2022年8月6日
    10
  • 智谱AI GLM-Image零基础教程:5分钟搭建你的AI绘画Web界面

    智谱AI GLM-Image零基础教程:5分钟搭建你的AI绘画Web界面

    2026年3月12日
    2
  • linkedhashset有序吗_golang人工智能框架

    linkedhashset有序吗_golang人工智能框架一、特征1、继承了HashSet类,底层实现HashMap,数据结构是链表2.保证顺序、唯一、可以为null3.查找较慢、插入删除较快4.线程不同步、多线程使用不安全如果要实现同步的setSetset=Collections.synchronized(newLinkedHashSet(…));二、常用方法参考HashSet三、测试代码publiccla…

    2022年10月12日
    4
  • java tair,Tair 简介

    java tair,Tair 简介1Tair 的功能 Tair 是一个 Key Value 结构数据的解决方案 它默认支持基于内存和文件的两种存储方式 分别和我们通常所说的缓存和持久化存储对应 Tair 除了普通 Key Value 系统提供的功能 比如 get put delete 以及批量接口外 还有一些附加的实用功能 使得其有更广的适用场景 包括 Version 支持原子计数器 Item 支持 1 1Version 支持 Tair 中的每个数据都包含

    2026年3月19日
    2
  • 2022.01 激活码【最新永久激活】

    (2022.01 激活码)最近有小伙伴私信我,问我这边有没有免费的intellijIdea的激活码,然后我将全栈君台教程分享给他了。激活成功之后他一直表示感谢,哈哈~https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~2KLK…

    2022年4月1日
    75
  • Android面试题含答案

    Android面试题含答案面试的时候总会遇到一些各种各样的面试题,而且这些面试题很多都是关于平时容易疏忽的理论方面的,所以整理一份Android高级开发工程师面试集锦,对照这些问题进行复习,将会事半功倍。从基础到中级在高级,从Android到java,记录下来有需要的时候多复习复习,也希望能帮到有需要的你。Android部分1、Activity生命周期?2、Service生命周期?3、Activi…

    2022年5月22日
    32

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号