OpenCV Java 图像不变矩

图像不变矩

百度百科介绍:

https://baike.baidu.com/item/%E5%9B%BE%E5%83%8F%E4%B8%8D%E5%8F%98/22105573?fr=aladdin

OpenCV for Java 实现

package com.opencv;

import java.util.ArrayList;
import java.util.List;
import java.util.Random;

import org.opencv.core.Core;
import org.opencv.core.Core.MinMaxLocResult;
import org.opencv.core.CvType;
import org.opencv.core.Mat;
import org.opencv.core.MatOfInt;
import org.opencv.core.MatOfPoint;
import org.opencv.core.MatOfPoint2f;
import org.opencv.core.Point;
import org.opencv.core.Rect;
import org.opencv.core.Scalar;
import org.opencv.core.Size;
import org.opencv.highgui.HighGui;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;
import org.opencv.imgproc.Moments;

public class OpenCvMain {
	
	//静态代码块加载动态链接库
	static {
		System.loadLibrary(Core.NATIVE_LIBRARY_NAME);
	}

	public static void main(String[] args) {
		
		/*
		 * IMREAD_UNCHANGED = -1 :不进行转化,比如保存为了16位的图片,读取出来仍然为16位。
		 * IMREAD_GRAYSCALE = 0 :进行转化为灰度图,比如保存为了16位的图片,读取出来为8位,类型为CV_8UC1。
		 * IMREAD_COLOR = 1 :进行转化为三通道图像。
		 * IMREAD_ANYDEPTH = 2 :如果图像深度为16位则读出为16位,32位则读出为32位,其余的转化为8位。
		 * IMREAD_ANYCOLOR = 4 :图像以任何可能的颜色格式读取
		 * IMREAD_LOAD_GDAL = 8 :使用GDAL驱动读取文件,GDAL(Geospatial Data Abstraction
		 * Library)是一个在X/MIT许可协议下的开源栅格空间数据转换库。它利用抽象数据模型来表达所支持的各种文件格式。
		 *	它还有一系列命令行工具来进行数据转换和处理。
		 */
		
		Mat src = Imgcodecs.imread("D:\\123.jpg");//待匹配图片
		Mat dst = new Mat();
		//将图像从一种颜色空间转换为另一种颜色空间 https://blog.csdn.net/ren365880/article/details/103869207
		Imgproc.cvtColor(src, dst, Imgproc.COLOR_BGR2GRAY);
		//均值模糊 https://blog.csdn.net/ren365880/article/details/103878059
		Imgproc.blur( dst, dst, new Size(3,3) );
		
		HighGui.imshow("原图", src);
		HighGui.waitKey();
		
		//提取边缘 https://blog.csdn.net/ren365880/article/details/103938232
		Mat edges=new Mat();
		Imgproc.Canny(dst,edges,200,100,3,false);
		
		HighGui.imshow("提取边缘", edges);
		HighGui.waitKey();
		/*
		 * 查找二进制图像中的轮廓
		 * https://blog.csdn.net/ren365880/article/details/103970023
		 */
		List<MatOfPoint> list = new ArrayList<MatOfPoint>();
		Mat hierarchy = new Mat();
		Imgproc.findContours(edges, list, hierarchy, Imgproc.RETR_TREE, Imgproc.CHAIN_APPROX_SIMPLE,new Point(0, 0));
		
		
		// 图像矩
		List<Moments> moments=new ArrayList<Moments>();
		List<Point> points=new ArrayList<Point>();
		for (int i = 0,len=list.size();i < len;i++) {
			/* 
			 * 计算图像中的中心矩(最高到三阶)
			 * array:输入数组,可以是光栅图像(单通道,8-bit或浮点型二维数组),或者是一个二维数组(1 X N或N X 1),二维数组类型为Point或Point2f
			 * binaryImage:默认值是false,如果为true,则所有非零的像素都会按值1对待,也就是说相当于对图像进行了二值化处理,阈值为1,此参数仅对图像有效。
			 */
			moments.add(Imgproc.moments(list.get(i)));
			points.add(new Point(moments.get(i).get_m10()/moments.get(i).get_m00(),moments.get(i).get_m01()/moments.get(i).get_m00()));
		}
		
		// 绘制轮廓
		for (int i = 0, len = list.size(); i < len; i++) {
			//https://blog.csdn.net/ren365880/article/details/103970023
			//Imgproc.drawContours(dst,list,i,new Scalar(0,0,255),2,Imgproc.LINE_AA);
			//https://blog.csdn.net/ren365880/article/details/103976504
			Imgproc.circle(src,points.get(i),0,new Scalar(0,0,255),4,Imgproc.LINE_AA);
		}
		
		
		HighGui.imshow("图像的不变矩", src);
		HighGui.waitKey();
	}
}

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梦里藍天

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值