当前位置: 首页 > news >正文

Java Opencv识别图片上的虫子

最近有个需求,希望识别图片上的虫子,对于java来说,图像识别不是很好做。在网上也搜索了很多,很多的代码都是不完整,或者下载下载报错,有的写的很长看不懂。所以自己试着用java的opencv写了一段代码。发现识别的效果还不错,下面把代码贴出来。有需要的可以参考。但是这里面有一些缺陷,就是没有加入transformer和org.deeplearning4j,对于复杂的场景识别的不是很准确。后期再更新把神经网络加上去。

一、POM.xml文件导入jar包

<dependency><groupId>org.bytedeco</groupId><artifactId>javacv-platform</artifactId><version>1.5.10</version> <!-- 根据最新版本更新 --></dependency><dependency><groupId>org.opencv</groupId><artifactId>opencv</artifactId><version>4.9.0</version></dependency><dependency><groupId>org.deeplearning4j</groupId><artifactId>deeplearning4j-core</artifactId><version>1.0.0-M1.1</version></dependency><dependency><groupId>org.nd4j</groupId><artifactId>nd4j-native</artifactId><version>1.0.0-M2</version></dependency><dependency><groupId>org.nd4j</groupId><artifactId>nd4j-api</artifactId><version>1.0.0-M2</version></dependency>

二、主要的处理步骤和逻辑代码

  1. 读取图片
  2. 截取区域
  3. 转换灰度
  4. 二值化
  5. 高斯
  6. 中指滤波
  7. 双边滤波
  8. 去除线框干扰
  9. 形态学操作
  10. 轮廓检测
package org.example;import org.bytedeco.opencv.global.opencv_imgcodecs;
import org.bytedeco.opencv.global.opencv_imgproc;
import org.bytedeco.opencv.opencv_core.*;public class BugCounterTest {public static void main(String[] args) {// 读取图片文件Mat src = opencv_imgcodecs.imread("C:\\Users\\HP\\Desktop\\aaaa.png");if (src.empty()) {System.out.println("Error: Cannot read image!");return;}// 截取感兴趣区域Rect roi = new Rect(0, 180, 1300, 600);Mat croppedImage = new Mat(src, roi);// 转换为灰度图像Mat gray = new Mat();opencv_imgproc.cvtColor(croppedImage, gray, opencv_imgproc.COLOR_BGR2GRAY);// 二值化图像Mat binary = new Mat();opencv_imgproc.threshold(gray, binary, 100, 255, opencv_imgproc.THRESH_BINARY_INV);//高斯模糊处理Mat blurredImage = new Mat();opencv_imgproc.GaussianBlur(binary,blurredImage,new Size(5, 5),0);//中值滤波Mat medianFilteredImage = new Mat();opencv_imgproc.medianBlur(blurredImage, medianFilteredImage, 5);// 双边滤波Mat bilateralFilteredImage = new Mat();opencv_imgproc.bilateralFilter(medianFilteredImage, bilateralFilteredImage, 9, 75, 75);// 去除线框干扰Mat edgeImage = new Mat();opencv_imgproc.Canny(bilateralFilteredImage, edgeImage, 50, 150); // 可调整参数// 形态学操作Mat kernel = opencv_imgproc.getStructuringElement(opencv_imgproc.MORPH_RECT, new Size(3, 3));opencv_imgproc.dilate(edgeImage, edgeImage, kernel);opencv_imgproc.erode(edgeImage, edgeImage, kernel);// 轮廓检测MatVector contours = new MatVector();Mat hierarchy = new Mat();opencv_imgproc.findContours(edgeImage, contours, hierarchy, opencv_imgproc.RETR_EXTERNAL, opencv_imgproc.CHAIN_APPROX_SIMPLE);int blackPointsCount = 0;// 在原始图像上绘制轮廓for (int i = 0; i < contours.size(); i++) {Rect rect = opencv_imgproc.boundingRect(contours.get(i));Scalar scalar = new Scalar(0, 255, 0, 0);opencv_imgproc.rectangle(croppedImage, rect, scalar);if (rect.width() > 1 && rect.height() > 1) {blackPointsCount++;}}// 保存标记后的图像opencv_imgcodecs.imwrite("C:\\Users\\HP\\Desktop\\output.jpg", croppedImage);System.out.println("黑点数量: " + blackPointsCount);}
}

对于复杂的图片识别有差距

相关文章:

  • [汇总] CentOS中查询端口终止进程的指令
  • 启动mysql 3.5时出现 MySql 服务正在启动 . MySql 服务无法启动。
  • tim定时器 输入捕获模式下 TIM–ICStructinit(TIM–ICStructinit) 这个值 解析
  • C++中的结构体——结构体嵌套结构体
  • 全球5G时代,智启未来生活
  • HandyControl的属性编辑器如何绑定自定义控件,并集成到自定义编辑器
  • 接口自动化测试框架-fixture函数使用
  • 【FreeRTOS】软件定时器 software timer(上)
  • 教你一招,告警恢复时如何拿到恢复时的值?
  • 代理模式与静态代理、动态代理的实现(Proxy.newProxyInstance、InvocationHandler)
  • 网站选择定制化的优缺点
  • 我们何时才能体验到超高清?
  • Django render()函数页面渲染
  • 性能测试2【搬代码】
  • 【办公类-04-02】华为助手导出照片读取拍摄时间分类导出,视频不行)
  • (十五)java多线程之并发集合ArrayBlockingQueue
  • Android单元测试 - 几个重要问题
  • Angular 响应式表单 基础例子
  • angular组件开发
  • CSS盒模型深入
  • extract-text-webpack-plugin用法
  • java中的hashCode
  • leetcode386. Lexicographical Numbers
  • Linux后台研发超实用命令总结
  • Spring Boot快速入门(一):Hello Spring Boot
  • SQL 难点解决:记录的引用
  • vue从入门到进阶:计算属性computed与侦听器watch(三)
  • 大整数乘法-表格法
  • 聚簇索引和非聚簇索引
  • 开年巨制!千人千面回放技术让你“看到”Flutter用户侧问题
  • 前端技术周刊 2019-01-14:客户端存储
  • 通过几道题目学习二叉搜索树
  • 最近的计划
  • ​【C语言】长篇详解,字符系列篇3-----strstr,strtok,strerror字符串函数的使用【图文详解​】
  • ​LeetCode解法汇总1276. 不浪费原料的汉堡制作方案
  • ​人工智能之父图灵诞辰纪念日,一起来看最受读者欢迎的AI技术好书
  • # Maven错误Error executing Maven
  • (4)Elastix图像配准:3D图像
  • (4)事件处理——(7)简单事件(Simple events)
  • (HAL库版)freeRTOS移植STMF103
  • (Redis使用系列) Springboot 使用redis实现接口幂等性拦截 十一
  • (二)pulsar安装在独立的docker中,python测试
  • (机器学习-深度学习快速入门)第一章第一节:Python环境和数据分析
  • (十六)一篇文章学会Java的常用API
  • (四)js前端开发中设计模式之工厂方法模式
  • (最全解法)输入一个整数,输出该数二进制表示中1的个数。
  • .NET Core WebAPI中使用Log4net 日志级别分类并记录到数据库
  • .NET Core、DNX、DNU、DNVM、MVC6学习资料
  • .net on S60 ---- Net60 1.1发布 支持VS2008以及新的特性
  • .Net 路由处理厉害了
  • .NET/C# 阻止屏幕关闭,阻止系统进入睡眠状态
  • .sys文件乱码_python vscode输出乱码
  • [2]十道算法题【Java实现】
  • [240527] 谷歌 CEO 承认 AI 编造虚假信息问题难解(此文使用 @gemini 命令二次创作)| ICQ 停止运作
  • [APIO2015]巴厘岛的雕塑