Android opencv 图片处理

两张图片对比

private void matchBitmaps(){

        Mat srcMat=new Mat();
        Mat endMat=new Mat();
        Mat output = new Mat();
        Mat srcMask = new Mat();
        Mat endMask = new Mat();
        MatOfKeyPoint srcKeyPoint = new MatOfKeyPoint();
        MatOfKeyPoint endKeyPoint = new MatOfKeyPoint();
        MatOfDMatch matches = new MatOfDMatch();

        Utils.bitmapToMat(srcBitmap, srcMat);
        Utils.bitmapToMat(endBitmap, endMat);

        Imgproc.cvtColor(srcMat, srcMat, Imgproc.COLOR_RGB2GRAY);
        Imgproc.cvtColor(endMat, endMat, Imgproc.COLOR_RGB2GRAY);

        FeatureDetector endDetector = FeatureDetector
                .create(FeatureDetector.ORB);
        endDetector.detect(endMat, endKeyPoint);
        DescriptorExtractor endDescriptor = DescriptorExtractor
                .create(DescriptorExtractor.ORB);
        endDescriptor.compute(endMat, endKeyPoint, endMask);

        FeatureDetector srcDetector = FeatureDetector
                .create(FeatureDetector.ORB);
        srcDetector.detect(srcMat, srcKeyPoint);
        DescriptorExtractor srcDescriptor = DescriptorExtractor
                .create(DescriptorExtractor.ORB);
        srcDescriptor.compute(srcMat, srcKeyPoint, srcMask);

        DescriptorMatcher descriptormatcher = DescriptorMatcher
                .create(DescriptorMatcher.BRUTEFORCE_HAMMING);
        descriptormatcher.match(srcMask, endMask, matches);

        Features2d.drawMatches(srcMat,srcKeyPoint,endMat, endKeyPoint, matches, output);

        Bitmap matchBitmap= Bitmap.createScaledBitmap(srcBitmap, output.width(),output.height(), false);
        Utils.matToBitmap(output, matchBitmap);

        image1.setImageBitmap(matchBitmap);
    }

边缘检测


 Mat rgbMat = new Mat();
 Mat grayMat = new Mat();
Bitmap grayBitmap = Bitmap.createBitmap(srcBitmap.getWidth(), srcBitmap.getHeight(), Bitmap.Config.ARGB_8888);
Utils.bitmapToMat(srcBitmap, rgbMat);
Imgproc.Canny(rgbMat, grayMat,0,150); 
Utils.matToBitmap(grayMat, grayBitmap); 

高斯模糊


        Mat rgbMat = new Mat();
        Mat grayMat = new Mat();
        Bitmap grayBitmap = Bitmap.createBitmap(srcBitmap.getWidth(), srcBitmap.getHeight(), Bitmap.Config.RGB_565);
        Utils.bitmapToMat(srcBitmap, rgbMat);
        Imgproc.cvtColor(rgbMat, grayMat,type);
        Utils.matToBitmap(grayMat, grayBitmap);

后面有时间在继续做吧

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值