通过jni调用OpenCv跟直接调用android版openCv对图片进行简单的变换

看看效果图,如果运行时提示需要安装xxxx.mamager,那么就去现在Opencvforandroid,解压以后安装相应的manager安装包就好了





这就是运行的效果,关于jni的调用就不说了,就看下他改变不同效果图的代码


package com.example.opencvdemo1;

import org.opencv.android.BaseLoaderCallback;
import org.opencv.android.LoaderCallbackInterface;
import org.opencv.android.OpenCVLoader;
import org.opencv.android.Utils;
import org.opencv.core.Mat;
import org.opencv.imgproc.Imgproc;

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

import com.example.openjni.ImageProc;

public class MainActivity extends Activity implements OnClickListener{
	private Button mBtn_type1,mBtn_type2,mBtn_type3,mBtn_type4,mBtn_type5,mBtn_type6,mBtn_type7,mBtn_src;
	private ImageView mIv_src;
	private Bitmap mDes_Bitmap;
	private boolean isGray = false;
	private BaseLoaderCallback loaderCallback = new BaseLoaderCallback(this) {
		public void onManagerConnected(int status) {
			switch (status) {
			case LoaderCallbackInterface.SUCCESS:
				System.loadLibrary("image_proc");
				break;
			case LoaderCallbackInterface.INIT_FAILED:
				
				break;
				
			case LoaderCallbackInterface.INSTALL_CANCELED:
				
				break;
				
			case LoaderCallbackInterface.MARKET_ERROR:
				
				break;
				
			case LoaderCallbackInterface.INCOMPATIBLE_MANAGER_VERSION:
			
				break;
			
			default:
				super.onManagerConnected(status);
				break;
			}
			
		};
		
	};
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		init();
	}

	
	public void init(){
		
		mBtn_type1 = (Button)findViewById(R.id.btn_type1);
		mBtn_type2 = (Button)findViewById(R.id.btn_type2);
		mBtn_type3 = (Button)findViewById(R.id.btn_type3);
		mBtn_type4 = (Button)findViewById(R.id.btn_type4);
		mBtn_type5 = (Button)findViewById(R.id.btn_type5);
		mBtn_type6 = (Button)findViewById(R.id.btn_type6);
		mBtn_type7 = (Button)findViewById(R.id.btn_type7);
		mBtn_src = (Button)findViewById(R.id.btn_src);
		mIv_src = (ImageView)findViewById(R.id.iv_img);
		mDes_Bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.a);
		mIv_src.setImageBitmap(mDes_Bitmap);
		mBtn_type1.setOnClickListener(this);
		mBtn_type2.setOnClickListener(this);
		mBtn_type3.setOnClickListener(this);
		mBtn_type4.setOnClickListener(this);
		mBtn_src.setOnClickListener(this);
		mBtn_type5.setOnClickListener(this);
		mBtn_type6.setOnClickListener(this);
		mBtn_type7.setOnClickListener(this);
	}

	public Bitmap procSrc2GrayJni(){
			int w = mDes_Bitmap.getWidth();
		int h = mDes_Bitmap.getHeight();
		int [] pixels = new int [w*h];
		mDes_Bitmap.getPixels(pixels, 0, w, 0, 0, w, h);
		int[] resultInt = ImageProc.grayProc(pixels, w, h);
		
		Bitmap bitmap = Bitmap.createBitmap(w, h, Config.ARGB_8888);
		bitmap.setPixels(resultInt, 0, w, 0, 0, w, h);
		return bitmap;
				 
	}
    public Bitmap procSrc2Gray(int type){  
        Mat rgbMat = new Mat();  
        Mat grayMat = new Mat();  
       Bitmap grayBitmap = Bitmap.createBitmap(mDes_Bitmap.getWidth(), mDes_Bitmap.getHeight(), Config.RGB_565);  
        Utils.bitmapToMat(mDes_Bitmap, rgbMat);//convert original bitmap to Mat, R G B.  
        Imgproc.cvtColor(rgbMat, grayMat,type);//rgbMat to gray grayMat  
        Utils.matToBitmap(grayMat, grayBitmap); //convert mat to bitmap  
        Log.i("TAG", "procSrc2Gray sucess...");  
        return grayBitmap;
    }  
	
	@Override
	protected void onResume() {
		super.onResume();
		OpenCVLoader.initAsync(OpenCVLoader.OPENCV_VERSION_2_4_9,this, loaderCallback);
	}


	@Override
	public void onClick(View arg0) {
		switch (arg0.getId()) {
		case R.id.btn_type1:
			mIv_src.setImageBitmap(procSrc2Gray(Imgproc.COLOR_RGB2GRAY)); 
			break;
		case R.id.btn_type2:
			mIv_src.setImageBitmap(procSrc2Gray(Imgproc.COLOR_RGB2HLS));
			break;
		case R.id.btn_type3:
			mIv_src.setImageBitmap(procSrc2Gray(Imgproc.COLOR_RGB2HSV));
			break;
		case R.id.btn_type4:
			Log.e("TAG", "procSrc2Gray sucess...");  
			mIv_src.setImageBitmap(procSrc2Gray(Imgproc.COLOR_RGB2Lab));
			break;
		case R.id.btn_type5:
			mIv_src.setImageBitmap(procSrc2Gray(Imgproc.COLOR_RGB2Luv));
			break;
		case R.id.btn_type6:
			mIv_src.setImageBitmap(procSrc2Gray(Imgproc.COLOR_RGB2XYZ));
			break;
		case R.id.btn_type7:
			mIv_src.setImageBitmap(procSrc2Gray(Imgproc.COLOR_RGB2YUV));
			break;
		case R.id.btn_src:
			mIv_src.setImageBitmap(mDes_Bitmap);
			break;
		default:
			break;
		}
	}
}
Android openCv 
Imgproc :该类是用来对图片进行处理的一个类,你可以让图片改变成你想要的样子,变成灰色的,或是素描,或是底片类型,等等,都可以。
他是通过jni调用来让我们可以在android里边能用openCv的功能。
 private static native void Canny_0(long image_nativeObj, long edges_nativeObj, double threshold1, double threshold2, int apertureSize, boolean L2gradient);
这个方法是用来找到图片边缘的。然后可以让你转换为一个类似描边的图像。里边的参数可以看到,第一个参数是要转换的图片的矩阵,第二个参数是转换以后的矩阵,第三个是阀值,第四个越是,你可以自己改变他俩个的大小看看效果,越大边缘月少。第五个参数其实也是调整显示的时候边缘化的程度了好像,我试验了一下以后
这些参数的大小在填的时候需要自己调整好,最后一个参数是用来判断是否要更准确一点。
private static native void Canny_1(long image_nativeObj, long edges_nativeObj, double threshold1, double threshold2);
这个跟上边的类似。

private static native void GaussianBlur_0(long src_nativeObj, long dst_nativeObj, double ksize_width, double ksize_height, double sigmaX, double sigmaY, int borderType);
高斯滤波器来对图片进行模糊化。第一个参数是图片原型矩阵,第二个是转换后输出矩阵,第三个为高斯滤波器模板的宽,第四个为高斯滤波器模板的高,第五第六sigmaX和sigmaY分别为高斯滤波在横线和竖向的滤波系数,borderType为边缘点插值类型。对于这个方法的使用参考http://blog.csdn.net/vblittleboy/article/details/9187447
    private static native void GaussianBlur_1(long src_nativeObj, long dst_nativeObj, double ksize_width, double ksize_height, double sigmaX, double sigmaY);
    private static native void GaussianBlur_2(long src_nativeObj, long dst_nativeObj, double ksize_width, double ksize_height, double sigmaX);
同上边

private static native void HoughCircles_0(long image_nativeObj, long circles_nativeObj, int method, double dp, double minDist, double param1, double param2, int minRadius, int maxRadius);

    private static native void HoughCircles_1(long image_nativeObj, long circles_nativeObj, int method, double dp, double minDist);

	/**
	 *高斯模糊处理
	 * @return
	 */
    public Bitmap gaosiBlur(){
    	   Mat rgbMat = new Mat();  
           Mat grayMat = new Mat();  
          Bitmap gaosiBitmap = Bitmap.createBitmap(mDes_Bitmap.getWidth(), mDes_Bitmap.getHeight(), Config.ARGB_8888);  
           Utils.bitmapToMat(mDes_Bitmap, rgbMat);//convert original bitmap to Mat, R G B.  
            Size size = new Size();	  //进行高斯模糊处理
           size.height = 17;
           size.width = 17;
           Imgproc.GaussianBlur(rgbMat, grayMat, size, 2, 2, Imgproc.BORDER_DEFAULT);
           Utils.matToBitmap(grayMat, gaosiBitmap); //convert mat to bitmap  
           Log.i("TAG", "procSrc2Gray sucess...");  
           
           return gaosiBitmap;
    }
    public Bitmap getwarpPerspective(){
    	Mat srcMat = new Mat();
    	Mat dstMat = new Mat();
    	Mat perspectiveTransform = Imgproc.getPerspectiveTransform(srcMat, dstMat);
        Size size = new Size();	  //进行高斯模糊处理
        size.height = mDes_Bitmap.getHeight();
        size.width = mDes_Bitmap.getWidth();
    	Bitmap dstBitmap = Bitmap.createBitmap(mDes_Bitmap.getWidth(), mDes_Bitmap.getHeight(), Config.RGB_565);
    	Utils.bitmapToMat(mDes_Bitmap, srcMat);
    	 Core.perspectiveTransform(srcMat, dstMat, perspectiveTransform);
    	Imgproc.warpPerspective(srcMat, dstMat, perspectiveTransform, size);
    	Utils.matToBitmap(dstMat, dstBitmap);
    	return dstBitmap;
    	
    }
    /**
     * 进行边缘检测
     * @return
     */
    public Bitmap getCanny(){
        Mat rgbMat = new Mat();  
        Mat grayMat = new Mat();  
       Bitmap grayBitmap = Bitmap.createBitmap(mDes_Bitmap.getWidth(), mDes_Bitmap.getHeight(), Config.ARGB_8888);  
        Utils.bitmapToMat(mDes_Bitmap, rgbMat);//convert original bitmap to Mat, R G B.  
      Imgproc.Canny(rgbMat, grayMat,0,150);  //对图片进行边缘检测 
      Utils.matToBitmap(grayMat, grayBitmap); //convert mat to bitmap  
      Log.i("TAG", "procSrc2Gray sucess...");  
      return grayBitmap;
    }


Demo: http://download.csdn.net/detail/u012808234/9374169

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Android中使用JNI调用OpenCV库来实现摄像头功能是可行的。以下是调用摄像头的简单步骤: 首先,你需要在Android项目中集成OpenCV库。可以通过将OpenCV库添加到Gradle依赖项或手动导入库文件来完成。 其次,创建一个JNI接口,将Java代码与C/C++代码进行绑定。JNI接口允许在Java和C/C++之间进行双向通信。 然后,在C/C++代码中编写与摄像头相关的功能。可以使用OpenCV提供的函数和类来处理视频流。例如,你可以使用VideoCapture类打开摄像头并获取图像帧。 接下来,在JNI接口中实现调用摄像头的功能。通过JNI接口,将Java代码的请求传递给C/C++函数来执行摄像头操作。你可以设置一个循环,不断从摄像头读取图像帧并进行处理。 最后,在Java代码中调用JNI接口中的方法来启动摄像头。可以使用SurfaceView来显示摄像头捕获的图像。你可以使用Camera类来控制摄像头的预览以及其他设置。 需要注意的是,在JNI和C/C++代码中处理摄像头操作时,要遵循正确的线程管理和图像处理技术,以确保流畅的手机摄像头应用程序。 总之,通过JNI调用OpenCV库,可以很方便地在Android上实现摄像头功能。项目中要同时涉及Java和C/C++代码,需要进行正确的接口绑定和线程管理。这样,你可以轻松地使用OpenCV函数和类来处理摄像头操作并实现自己的摄像头应用程序。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值