Android OpenCv进行图片比对

OpenCv 对于图片有很多的处理方式,现在我想要实现俩张图片的比对。

首先要知道做个需要那些步骤:

(1)加载俩张图片

(2)将两张图片转换为Mat矩阵

(3)把Mat矩阵的type转换为Cv_8uc1类型,然后转换为Cv_32F,

因为在c++代码中会判断他的类型。

(4)通过OpenCv 来进行俩个矩阵的比较(俩个矩阵必须一样大小的高宽)

我使用的比较类型是Imgproc.CV_COMP_CORREL,

double target = Imgproc.compareHist(mat, mat2, Imgproc.CV_COMP_CORREL);

这个target的值越大那么也就是说相似度越高,如果完全一样就是1.0     。

效果图:

思路就是这样,看看代码的实现:

package com.example.opencv_comparepic;

import java.util.Arrays;

import org.opencv.android.BaseLoaderCallback;
import org.opencv.android.OpenCVLoader;
import org.opencv.android.Utils;
import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;
import org.opencv.core.MatOfFloat;
import org.opencv.core.MatOfInt;
import org.opencv.core.Point;
import org.opencv.core.Rect;
import org.opencv.core.Scalar;
import org.opencv.core.Size;
import org.opencv.imgproc.Imgproc;

import android.os.Bundle;
import android.app.Activity;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.util.Log;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.Toast;

public class MainActivity extends Activity  implements OnClickListener{
	public static final String TAG = "OpenCv_compare";
	private Bitmap mBitmap1,mBitmap2;
	private ImageView mIv_ImageView1,mIv_ImageView2;
	private Button mBtn_compare;
	private BaseLoaderCallback callback = new BaseLoaderCallback(this) {
		@Override
		public void onManagerConnected(int status) {
			super.onManagerConnected(status);
			switch (status) {
			case BaseLoaderCallback.SUCCESS:

				break;

			default:
				break;
			}
		}
	};
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		init();
	}

	public void init(){
		mBitmap1 = BitmapFactory.decodeResource(getResources(), R.drawable.b);
		mBitmap2 = BitmapFactory.decodeResource(getResources(), R.drawable.c);
		mIv_ImageView1 = (ImageView)findViewById(R.id.iv_img1);
		mIv_ImageView2 = (ImageView)findViewById(R.id.iv_img2);
		mBtn_compare = (Button)findViewById(R.id.btn_compare);
		mIv_ImageView1.setImageBitmap(mBitmap1);
		mIv_ImageView2.setImageBitmap(mBitmap2);
		mBtn_compare.setOnClickListener(this);
	}

	@Override
	public void onClick(View v) {
		Mat mat1 = new Mat();
		Mat mat2 = new Mat();
		Mat mat11 = new Mat();
		Mat mat22 = new Mat();
		Utils.bitmapToMat(mBitmap1, mat1);
		Utils.bitmapToMat(mBitmap2, mat2);
		Imgproc.cvtColor(mat1, mat11, Imgproc.COLOR_BGR2GRAY);
		Imgproc.cvtColor(mat2, mat22, Imgproc.COLOR_BGR2GRAY);
		comPareHist(mat11, mat22);
	}

	    private Mat                  mMat0;
	    private MatOfInt             mChannels[];
	    private MatOfInt             mHistSize;
	    private int                  mHistSizeNum = 25;
	    private MatOfFloat           mRanges;
	    private Scalar               mColorsRGB[];
	    private Point                mP1;
	    private Point                mP2;
	    private float                mBuff[];
	public Mat procSrc2GrayJni(Mat srcMat,int type) {
		Mat grayMat = new Mat();
		Imgproc.cvtColor(srcMat, grayMat, type);//转换为灰度图
		// Imgproc.HoughCircles(rgbMat, gray,Imgproc.CV_HOUGH_GRADIENT, 1, 18);
		// //霍夫变换找园
        mChannels = new MatOfInt[] { new MatOfInt(0), new MatOfInt(1), new MatOfInt(2) };
        mBuff = new float[mHistSizeNum];
        mHistSize = new MatOfInt(mHistSizeNum);
        mRanges = new MatOfFloat(0f, 256f);
        mMat0  = new Mat();
        mColorsRGB = new Scalar[] { new Scalar(200, 0, 0, 255), new Scalar(0, 200, 0, 255), new Scalar(0, 0, 200, 255) };
        mP1 = new Point();
        mP2 = new Point();

		 Mat rgba = srcMat;
	     Size sizeRgba = rgba.size();
		 Mat hist = new Mat(); //转换直方图进行绘制
         int thikness = (int) (sizeRgba.width / (mHistSizeNum + 10) / 5);
         if(thikness > 5) thikness = 5;
         int offset = (int) ((sizeRgba.width - (5*mHistSizeNum + 4*10)*thikness)/2);
         // RGB
         for(int c=0; c<3; c++) {
             Imgproc.calcHist(Arrays.asList(rgba), mChannels[c], mMat0, hist, mHistSize, mRanges);
             Core.normalize(hist, hist, sizeRgba.height/2, 0, Core.NORM_INF);
             hist.get(0, 0, mBuff);
             for(int h=0; h<mHistSizeNum; h++) {
                 mP1.x = mP2.x = offset + (c * (mHistSizeNum + 10) + h) * thikness;
                 mP1.y = sizeRgba.height-1;
                 mP2.y = mP1.y - 2 - (int)mBuff[h];
                 Core.line(rgba, mP1, mP2, mColorsRGB[c], thikness);
             }
         }

		return rgba;
	}
	/**
	 * 比较来个矩阵的相似度
	 * @param srcMat
	 * @param desMat
	 */
	public void comPareHist(Mat srcMat,Mat desMat){

		srcMat.convertTo(srcMat, CvType.CV_32F);
		desMat.convertTo(desMat, CvType.CV_32F);
		double target = Imgproc.compareHist(srcMat, desMat, Imgproc.CV_COMP_CORREL);
		Log.e(TAG, "相似度 :   ==" + target);
		Toast.makeText(this, "相似度 :   ==" + target, 1000).show();
	}

	@Override
	protected void onResume() {
		super.onResume();
		// 通过OpenCV引擎服务加载并初始化OpenCV类库,所谓OpenCV引擎服务即是
        // OpenCV_2.4.9.2_Manager_2.4_*.apk程序包,存在于OpenCV安装包的apk目录中
        OpenCVLoader.initAsync(OpenCVLoader.OPENCV_VERSION_2_4_9, this,
                callback);
	}
}

可以比较俩张照片的相似度的话那么就可以来进行类似人脸识别然后进行解锁的功能,以后可以用试试看能不能。

http://download.csdn.net/detail/u012808234/9419849

时间: 2024-10-29 20:42:21

Android OpenCv进行图片比对的相关文章

脸部识别-android Opencv 人脸检测

问题描述 android Opencv 人脸检测 请问有大神做过opencv人脸识别的相关demo吗?找了好长时间都是人脸检测 解决方案 最近在做人脸识别,现在初步只做了人脸检测,比较简单,仅供参考. 功能是打开图片,进行人脸检测,输出人脸个数和检测范围. .......省略包 public class Staticdetection2Activity extends Activity { final private static String TAG = "Staticrecognition.

android byte转图片的问题

问题描述 android byte转图片的问题 ```public class MainActivity extends Activity { private ImageView iv1iv2; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initview(); /

android 显示gif图片实例详解

  android 显示gif图片实例详解           在android中不支持gif格式的图片,但是由于我希望在我的程序中刚刚加载的时候有一个小人在跑步表示正在加载.而这个小人跑就是一个gif图片.也就是希望程序一启动时就加载gif图片.在网上查找了一些方法不知道是我使用的android的版本高(android4.4)还是什么问题就是加载不出来.最后想了一个办法加载了出来.这个办法就是将gif放在webView中让其显示. 下面是关于这个的代码: activity_prepare_fu

Android加载图片内存溢出问题解决方法

  这篇文章主要介绍了Android加载图片内存溢出问题解决方法,本文讲解使用BitmapFactory.Options解决内存溢出问题,需要的朋友可以参考下 1. 在Android软件开发过程中,图片处理是经常遇到的. 在将图片转换成Bitmap的时候,由于图片的大小不一样,当遇到很大的图片的时候会出现超出内存的问题,为了解决这个问题Android API提供了BitmapFactory.Options这个类. 2. 由于Android对图片使用内存有限制,若是加载几兆的大图片便内存溢出.Bi

android 我把图片放入放入缓存。可为什么却还是从网络加载勒?

问题描述 android 我把图片放入放入缓存.可为什么却还是从网络加载勒? 贴出来代码: public class MainActivity extends Activity { private ImageView ima; private MemoryCache lruCache; String path="http://android.apkbus.com/images/172034140lit.jpg"; @Override protected void onCreate(Bu

android webview中图片 长按点击保存本地 部分手机不能实现。

问题描述 android webview中图片 长按点击保存本地 部分手机不能实现. 代码如下 private String imgurl = """"; /*** * 功能:长按图片保存到手机 */@Overridepublic void onCreateContextMenu(ContextMenu menu View v ContextMenuInfo menuInfo) { super.onCreateContextMenu(menu v menuInfo)

【游戏开发备注之一】关于COCOS2DX_V1.X版本IPHONE与ANDROID运行出现图片白块、添加GAMECENTER报错问题及编译ANDROID闪退的解决办法&amp;&amp;CCLOG与CCLOG的区别

本站文章均为 李华明Himi 原创,转载务必在明显处注明:  转载自[黑米GameDev街区] 原文链接: http://www.himigame.com/android-game/1035.html 今天备注几个童鞋们可能会遇到的问题: 1. 关于Cocos2dx v1.x版本运行在iphone与Android平台出现图片变白块,尺寸一样.图片纯白问题. 之前出现此问题原因如下: 1.1  CCSprite与CCNode强转之间的问题造成: 1.2  pvr.ccz的资源大小宽高不是正方形的话

Android远程获取图片并本地缓存_Android

对于客户端--服务器端应用,从远程获取图片算是经常要用的一个功能,而图片资源往往会消耗比较大的流量,对应用来说,如果处理不好这个问题,那会让用户很崩溃,不知不觉手机流量就用完了,等用户发现是你的应用消耗掉了他手机流量的话,那么可想而知你的应用将面临什么样的命运. 另外一个问题就是加载速度,如果应用中图片加载速度很慢的话,那么用户同样会等到崩溃. 那么如何处理好图片资源的获取和管理呢? *异步下载 *本地缓存 1.异步下载: 大家都知道,在android应用中UI线程5秒没响应的话就会抛出无响应异

初始化-MFC 利用opencv显示图片,需要在窗体完成哪一步后才可以

问题描述 MFC 利用opencv显示图片,需要在窗体完成哪一步后才可以 对对话框创建流程不是太清楚. 下面代码只能通过按钮点击响应才可以,但直接放在对话框初始化以及onsize里面就不行. cv::Mat mat, mat2; mat = cv::imread("D:\test1.jpg", 1); if(! mat.data) { MessageBox(_T("error", "no image loaded!"), MB_OK); retu