JAVA新实战3:opencv+java应用初探

        这两天在写一个地图瓦片采集工具,在将瓦片应用到geoserver时,需要将瓦片进行合并,因为合成的图片很大,尝试了普通的图片拼合后,还是决定使用opencv进行实现,虽然有点高射炮打蚊子的感觉,但还是用一下子,顺便把opencv与java开发环境下的使用进行一个总结和分享。

        这里我已经具备了java开发环境,相关项目工程已经建立,只讲如何把opencv整合到java工程项目中。opencv是一个超级伟大的计算机视觉处理库,免费开源,一级棒的推荐。

        本文所设开发环境:

操作系统:windows 11

Java JDK:OpenJDK21

构建工具:Gradle 8.4

开发工具:VsCode - Visual Studio Code 1.84.1

      1、下载opencv

        建议下载最新版,您可以从官网直接下载,网址:https://opencv.org/releases/。根据您的电脑选择不同的版本进行下载。

        如果官网下载慢,我找到个国内的镜像 https://www.raoyunsoft.com/opencv/ 经测试,速度还很快。

        这里以windows版为例,我选择安装了4.8.0版。

      2、安装/解压opencv

        双击下载的opencv-4.8.0-windows.exe,这里的安装实际上就是解压,指定任意一个目录即可,该目录对后续开发配置无实质性影响,主要是为了拿到其中相关的jar、dll文件。

      3、找到所需引用的文件

        在刚刚解压的目录下找到D:\Program Files\opencv\build\java,这个子目录下找到 opencv-480.jar、opencv_java480.dll(从x64、x86选择适合自己的)。

      4、所需文件放在JAVA项目

        在需要引入opencv处理库的JAVA项目根目录下,找到或者新建lib目录,在其下创建opencv子目录。

        然后将找到的 opencv-480.jar、opencv_java480.dll两个文件复制到刚刚在JAVA项目工程中创建的opencv目录下。

      5、在JAVA项目工程中配置

        我这里使用的 gradle构建,以下配置按gradle模式给出,maven方式雷同,这里简略。

//把以下代码放在 build.gradle 的 dependencies 代码块中

implementation(files("lib/opencv/opencv-480.jar"))

        结果如下:

      6、在JAVA项目运行入口加载dll

        仅仅更改配置文件是无法直接应用的,在实际使用时还需要先加载dll组件后才可以正常使用,我这里直接在项目运行入口处进行加载,这样整个系统各个块中都可以使用了。

	// 引入 opencv_java480 组件
	static {
		// windows
		System.load(System.getProperty("user.dir") + "/lib/opencv/opencv_java480.dll");
	}

        代码具体放置位置如下图,如果您需要同时支持windows、mac和linux,需要根据不同系统判断后引入各个系统版本下的库文件。

      7、调用opencv

        这里仅仅应用了opencv一点点的功能,写了一个多个瓦片合并为一张大图的功能,代码如下:

package com.jojava.joMapTile.utils;

import java.io.File;
import java.io.IOException;
import org.apache.commons.io.FileUtils;
import org.opencv.core.CvType;
import org.opencv.core.Mat;
import org.opencv.core.Range;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

import lombok.Getter;

public class TileMergeUtils {

    private Mat des = null;

    private int tileWidth = 256; // 瓦片大小 宽
    private int tileHeight = 256; // 瓦片大小 高

    @Getter
    private long allPixel = 0L;
    @Getter
    private long runPixel = 0L;

    public void init(int width, int height) {
        /*
         * CV_8uc1 单颜色通道 8位</br>
         * CV_8uc2 2颜色通道 16位</br>
         * CV_8uc3 3颜色通道 24位</br>
         * CV_8uc4 4颜色通道 32位</br>
         */
        // CV_8UC4为支持透明PNG的RGBA格式
        this.des = Mat.zeros(height, width, CvType.CV_8UC4);
        // 计算总像素数量
        this.allPixel = (long) width * height;
    }

    public void mergeToMat(String pathAndName, long x, long y) {
        // 读取图片
        var tileMat = Imgcodecs.imread(pathAndName, Imgcodecs.IMREAD_UNCHANGED);
        try {
            // 转换图片至RGBA格式
            Imgproc.cvtColor(tileMat, tileMat, Imgproc.COLOR_BGR2BGRA);
            // 确定坐标位置
            var rectForDes = this.des
                    .colRange(new Range((int) x, (int) x + tileWidth))
                    .rowRange(new Range((int) y, (int) y + tileHeight));
            // 填充至合并大图
            tileMat.copyTo(rectForDes);
        } catch (Exception ignored) {

        }
        // 完成后计算已合并的像素数量
        this.runPixel += (long) tileWidth * tileHeight;
    }

    public void output(String path, String name) throws IOException {
        String suffix = "png"; //合并后的图片后缀
        String out = path + name + "." + suffix;
        FileUtils.createParentDirectories(new File(out));
        Imgcodecs.imwrite(out, this.des);
    }

    public void destroy() {
        this.des.release();
        this.des = null;
    }
}

8、结语

        opencv的强大是公认的,希望本篇文章能在初步使用该跨平台计算机视觉和机器学习软件库上带给您一点点帮助,后面一篇文章我将给出完整的瓦片下载和合并模块的代码。

        如果您觉得这篇文章对您有所帮助和启发,请拿起您发财的小手点点关注、点点赞,作者将备受鼓舞,会努力持续分享。

        

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
YOLOv5是一种基于深度学习的目标检测算法,可以快速准确地检测图像中的不同目标。OpenCV是一个流行的计算机视觉库,提供了丰富的图像处理和分析功能。Java是一种常用的编程语言,可以用于开发各种应用程序。 如果想在Java上使用YOLOv5来进行印章识别,首先需要安装配置OpenCV和YOLOv5的相关环境。可以使用JavaCV库来方便地在Java中调用OpenCV的功能,同时也可以使用TensorFlow Java API来加载和使用YOLOv5的模型。 准备工作完成后,我们可以通过以下步骤进行印章识别: 1. 加载和初始化YOLOv5的模型。这包括加载模型文件、配置文件和权重文件,并根据需要进行参数设置。 2. 使用OpenCV读取待识别的图像,并进行预处理。预处理可以包括图像的缩放、归一化等操作,以便符合模型的输入要求。 3. 将预处理后的图像输入到YOLOv5模型中进行目标检测。模型将输出图像中检测到的印章的位置、类别和置信度等信息。 4. 根据模型的输出结果,可以根据置信度进行筛选和过滤,以得到最可信的印章检测结果。 5. 可以使用OpenCV的绘图功能,在原始图像上标注出检测到的印章位置和类别等信息,以便进行可视化展示或进一步的后续处理。 通过以上步骤,我们就可以实现在Java环境下使用YOLOv5和OpenCV进行印章识别。当然,具体实现的细节还需要根据实际情况进行调整和完善,比如模型的训练和优化等。此外,还需要考虑算法的性能和效果等因素,以便得到更好的印章识别结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值