java调用opencv的sift方法

简介: java调用opencv的sift方法

网络异常,图片无法展示
|


代码找了好多,但是没有java版本的


网络异常,图片无法展示
|


网络异常,图片无法展示
|


public static void TestSift(Mat image1,Mat image2) {
Mat clone1=image1.clone();
Mat src1=image1.clone();
Mat clone2=image2.clone();
Mat src2=image2.clone();
Imgproc.GaussianBlur(clone1, clone1, new Size(3, 3), 0, 0);
Imgproc.cvtColor(clone1, clone1,Imgproc.COLOR_BGR2GRAY);
Imgproc.GaussianBlur(clone2, clone2, new Size(3, 3), 0, 0);
Imgproc.cvtColor(clone2, clone2,Imgproc.COLOR_BGR2GRAY);
MatOfKeyPoint keypoints1 = new MatOfKeyPoint();
MatOfKeyPoint keypoints2 = new MatOfKeyPoint();
Mat des1=new Mat();
Mat des2=new Mat();
//  匹配的点数
SIFT sift=SIFT.create(200);
  //提取对象关键点
//  sift.detect(clone1,keypoints1);
//  sift.detect(clone2,keypoints2);
  //提取描述子
//  sift.compute(clone1,keypoints1, des1);
//  sift.compute(clone2,keypoints2, des2);
sift.detectAndCompute(clone1, new Mat(), keypoints1, des1);
sift.detectAndCompute(clone2, new Mat(), keypoints2, des2);
MatOfDMatch md=new  MatOfDMatch();
FlannBasedMatcher matcher=FlannBasedMatcher.create();
matcher.match(des1, des2, md);
double maxDist = 0;
double minDist = 50;
DMatch[] mats = md.toArray();
List<DMatch> bestMatches= new ArrayList<DMatch>();
for (int i = 0; i < mats.length; i++) {
  double dist = mats[i].distance;
  if (dist < minDist) {
    minDist = dist;
  }
  if (dist > maxDist) {
    maxDist = dist;
  }
}
System.out.println("max_dist : "+maxDist);
System.out.println("min_dist : "+minDist);
double threshold = 3 * minDist;
double threshold2 = 2 * minDist;
if (threshold2 >= maxDist){
    threshold = minDist * 1.1;
}
else if (threshold >= maxDist){
    threshold = threshold2 * 1.4;
}
if(0d==threshold) {
  threshold=0.3*maxDist;
}
System.out.println("Threshold : "+threshold);
for (int i = 0; i < mats.length; i++)
{
  //distance越小,代表DMatch的匹配率越高,
    Double dist = (double) mats[i].distance;
    System.out.println(String.format(i + " match distance best : %s", dist));
    if (dist <= threshold)
    {
        bestMatches.add(mats[i]);
        System.out.println(String.format(i + " best match added : %s", dist));
    }
}
md.fromList(bestMatches);
Mat result=new Mat();
Features2d.drawMatches(src1, keypoints1, src2, keypoints2, md, result);
HighGui.imshow("SIFT", result);
}
复制代码


knn写法


public static void TestSiftKnn(Mat image1,Mat image2) {
  //FastFeatureDetector detector = FastFeatureDetector.create(FastFeatureDetector.FAST_N);
  Mat clone1=image1.clone();
  Mat src1=image1.clone();
  Mat clone2=image2.clone();
  Mat src2=image2.clone();
  Imgproc.GaussianBlur(clone1, clone1, new Size(3, 3), 0, 0);
  Imgproc.cvtColor(clone1, clone1,Imgproc.COLOR_BGR2GRAY);
  Imgproc.GaussianBlur(clone2, clone2, new Size(3, 3), 0, 0);
  Imgproc.cvtColor(clone2, clone2,Imgproc.COLOR_BGR2GRAY);
  MatOfKeyPoint keypoints1 = new MatOfKeyPoint();
  MatOfKeyPoint keypoints2 = new MatOfKeyPoint();
  Mat des1=new Mat();
  Mat des2=new Mat();
  SIFT sift=SIFT.create(200);
  //提取对象关键点
//  sift.detect(clone1,keypoints1);
//  sift.detect(clone2,keypoints2);
  //提取描述子
//  sift.compute(clone1,keypoints1, des1);
//  sift.compute(clone2,keypoints2, des2);
  sift.detectAndCompute(clone1, new Mat(), keypoints1, des1);
  sift.detectAndCompute(clone2, new Mat(), keypoints2, des2);
  MatOfDMatch md=new  MatOfDMatch();
  FlannBasedMatcher matcher=FlannBasedMatcher.create();
  //matcher.match(des1, des2, md);
  List<Mat> matList=new ArrayList<Mat>();
  List<MatOfDMatch> mdList=new ArrayList<MatOfDMatch>();
  matList.add(des1);
    matcher.add(matList);
    matcher.train();
    matcher.knnMatch(des2, mdList, 2);
    List<DMatch> dMatchList = new ArrayList<DMatch>();
    Iterator<MatOfDMatch> ite=mdList.iterator();
    while(ite.hasNext()) {
      MatOfDMatch next=ite.next();
      if (next.toArray()[0].distance < 0.2 * next.toArray()[1].distance) {
        System.out.println(next.toArray()[0].distance+"->"+next.toArray()[1].distance);
        dMatchList.add(next.toArray()[0]);
      }else {
        ite.remove();
      }
    }
   md.fromList(dMatchList);
  Mat result=new Mat();
//  Features2d.drawMatches(src1, keypoints1, src2, keypoints2, md, result);
  Features2d.drawMatchesKnn(src1, keypoints1, src2, keypoints2, mdList, result);
  HighGui.imshow("SIFT", result);
}


相关文章
|
2月前
|
前端开发 JavaScript Java
Java 开发中 Swing 界面嵌入浏览器实现方法详解
摘要:Java中嵌入浏览器可通过多种技术实现:1) JCEF框架利用Chromium内核,适合复杂网页;2) JEditorPane组件支持简单HTML显示,但功能有限;3) DJNativeSwing-SWT可内嵌浏览器,需特定内核支持;4) JavaFX WebView结合Swing可完美支持现代网页技术。每种方案各有特点,开发者需根据项目需求选择合适方法,如JCEF适合高性能要求,JEditorPane适合简单展示。(149字)
279 1
|
1月前
|
算法 Java 开发者
Java 项目实战数字华容道与石头迷阵游戏开发详解及实战方法
本文介绍了使用Java实现数字华容道和石头迷阵游戏的技术方案与应用实例,涵盖GUI界面设计、二维数组操作、游戏逻辑控制及自动解法算法(如A*),适合Java开发者学习游戏开发技巧。
189 46
|
2月前
|
Java 索引
Java ArrayList中的常见删除操作及方法详解。
通过这些方法,Java `ArrayList` 提供了灵活而强大的操作来处理元素的移除,这些方法能够满足不同场景下的需求。
368 30
|
5月前
|
Java 开发者
Java 中的 toString() 方法详解:为什么它如此重要?
在Java开发中,`toString()`方法至关重要,用于返回对象的字符串表示。默认实现仅输出类名和哈希码,信息有限且不直观。通过重写`toString()`,可展示对象字段值,提升调试效率与代码可读性。借助Lombok的`@Data`注解,能自动生成标准化的`toString()`方法,简化开发流程,尤其适合字段较多的场景。合理运用`toString()`,可显著提高开发效率与代码质量。
396 0
|
2月前
|
安全 Java API
Java 17 及以上版本核心特性在现代开发实践中的深度应用与高效实践方法 Java 开发实践
本项目以“学生成绩管理系统”为例,深入实践Java 17+核心特性与现代开发技术。采用Spring Boot 3.1、WebFlux、R2DBC等构建响应式应用,结合Record类、模式匹配、Stream优化等新特性提升代码质量。涵盖容器化部署(Docker)、自动化测试、性能优化及安全加固,全面展示Java最新技术在实际项目中的应用,助力开发者掌握现代化Java开发方法。
122 1
|
2月前
|
安全 Java API
Java 集合高级应用与实战技巧之高效运用方法及实战案例解析
本课程深入讲解Java集合的高级应用与实战技巧,涵盖Stream API、并行处理、Optional类、现代化Map操作、不可变集合、异步处理及高级排序等核心内容,结合丰富示例,助你掌握Java集合的高效运用,提升代码质量与开发效率。
199 0
|
3月前
|
人工智能 前端开发 Java
Java 面试资料中相关代码使用方法与组件封装方法解析
这是一份详尽的Java面试资料代码指南,涵盖使用方法与组件封装技巧。内容包括环境准备(JDK 8+、Maven/Gradle)、核心类示例(问题管理、学习进度跟踪)、Web应用部署(Spring Boot、前端框架)、单元测试及API封装。通过问题库管理、数据访问组件、学习进度服务和REST接口等模块化设计,帮助开发者高效组织与复用功能,同时支持扩展如用户认证、AI推荐等功能。适用于Java核心技术学习与面试备考,提升编程与设计能力。资源链接:[点此下载](https://pan.quark.cn/s/14fcf913bae6)。
102 6
Java 面试资料中相关代码使用方法与组件封装方法解析
|
2月前
|
算法 搜索推荐 Java
Java中的Collections.shuffle()方法及示例
`Collections.shuffle()` 是 Java 中用于随机打乱列表顺序的方法,基于 Fisher-Yates 算法实现,支持原地修改。可选传入自定义 `Random` 对象以实现结果可重复,适用于抽奖、游戏、随机抽样等场景。
114 0
|
2月前
|
安全 Java
JAVA:Collections类的shuffle()方法
`Collections.shuffle()` 是 Java 中用于随机打乱列表顺序的工具方法,适用于洗牌、抽奖等场景。该方法直接修改原列表,支持自定义随机数生成器以实现可重现的打乱顺序。使用时需注意其原地修改特性及非线程安全性。
124 0
|
2月前
|
算法 安全 Java
java中Collections.shuffle方法的功能说明
`Collections.shuffle()` 是 Java 中用于随机打乱列表顺序的方法,基于 Fisher-Yates 算法实现,常用于洗牌、抽奖等场景。可选 `Random` 参数支持固定种子以实现可重复的随机顺序。方法直接修改原列表,无返回值。
110 0