Android+OpenCv4实现边缘检测及轮廓绘制出图像最大边缘

 更新时间:2021年05月18日 09:52:41   作者:Best-dadong  
最近工作需求,需要用opencv来先做一个demo,扫描照片进行边缘检测和最大边缘,就整理出来介绍一下,感兴趣的小伙伴们可以参考一下

实现步骤:

  • 图像灰度化
  • 边缘检测
  • 根据Canny检测得出来的Mat寻找轮廓
  • 算出最大轮廓周长or面积
  • 根据获取到的最大轮廓下标进行轮廓绘制
  • 画出最大矩形,并返回Rect

Canny边缘检测

基于Canny算法的边缘检测主要有5个步骤,依次是高斯滤波、像素梯度计算、非极大值像素梯度抑制、滞后阈值处理和孤立弱边缘抑制。Canny在有噪声的情况下表现好不好,取决于前面的降噪过程,可以手动做高斯处理提高识别率。

/**
		image  输入图像,必须是CV_8U的单通道或者三通道图像。
		edges  输出图像,与输入图像具有相同尺寸的单通道图像,且数据类型为CV_8U。
		threshold1  第一个滞后阈值。
		threshold2  第二个滞后阈值。
		apertureSize  Sobel算子的直径。
		L2gradient  计算图像梯度幅值方法的标志。默认为false
**/
public static void Canny(Mat image, Mat edges, double threshold1, double threshold2, int apertureSize, boolean L2gradient)

使用

    /**
     * canny算法,边缘检测

     */
    public static Mat canny(Bitmap bitmap) {
        Mat mSource = new Mat();

        Utils.bitmapToMat(bitmap, mSource);
        Mat grayMat = new Mat();
        Imgproc.cvtColor(mSource,grayMat,Imgproc.COLOR_BGR2GRAY);//转换成灰度图
        Mat mat = mSource.clone();
        Imgproc.Canny(mSource, mat, 75, 200);
        return mat;
    }

在这里插入图片描述

获取图像最大矩形

   /**
     * 返回边缘检测之后的最大矩形,并返回
     *
     * @param cannyMat
     *            Canny之后的mat矩阵
     * @return
     */
    public  Rect findMaxRect(Mat cannyMat) {
        Mat tmp = mSource.clone();
        List<MatOfPoint> contours = new ArrayList<MatOfPoint>();
        Mat hierarchy = new Mat();
        // 寻找轮廓
        Imgproc.findContours(cannyMat, contours, hierarchy, Imgproc.RETR_EXTERNAL, Imgproc.CHAIN_APPROX_SIMPLE);
        int index = 0;
        double perimeter = 0;
        // 找出匹配到的最大轮廓
        for (int i = 0; i < contours.size(); i++) {
            // 最大面积
//            double area = Imgproc.contourArea(contours.get(i));
            //最大周长
            MatOfPoint2f source = new MatOfPoint2f();
            source.fromList(contours.get(i).toList());
            double length = Imgproc.arcLength(source,true);
            if(length>perimeter){
                perimeter =  length;
                index = i;
            }
        }
      
        /**
         * 参数一:image,待绘制轮廓的图像。
         *
         * 参数二:contours,待绘制的轮廓集合。
         *
         * 参数三:contourIdx,要绘制的轮廓在contours中的索引,若为负数,表示绘制全部轮廓。
         *
         * 参数四:color,绘制轮廓的颜色。
         *
         * 参数五:thickness,绘制轮廓的线条粗细。若为负数,那么绘制轮廓的内部。
         *
         * 参数六:lineType,线条类型。FILLED   LINE_4   4连通   LINE_8   8连通  LINE_AA  抗锯齿
         */
        Imgproc.drawContours(
                tmp,
                contours,
                index,
                new Scalar(0.0, 0.0, 255.0),
                9,
                Imgproc.LINE_AA

        );

        Rect rect = Imgproc.boundingRect(contours.get(index));
//        Imgproc.rectangle(tmp, rect, new Scalar(0.0, 0.0, 255.0), 4, Imgproc.LINE_8);
        showImg(tmp);

        return rect;
    }

  /**
     * 显示图像
     * @param mat
     */
    private void showImg(Mat mat){

        Bitmap bitmap = Bitmap.createBitmap(mat.width(), mat.height(), Bitmap.Config.ARGB_8888);
        Utils.matToBitmap(mat, bitmap);
        mIvSrc.setImageBitmap(bitmap);
        mat.release();
    }

最终效果图

在这里插入图片描述

获得矩形坐标点以后,后期可以做裁剪,旋转之类操作,可以自行研究。

到此这篇关于Android+OpenCv4实现边缘检测及轮廓绘制出图像最大边缘的文章就介绍到这了,更多相关Android OpenCv4边缘检测内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • python自带的http模块详解

    python自带的http模块详解

    本文主要是给大家详细讲解了Python中自带的http模块的使用方法和实例,非常的细致,有需要的小伙伴可以参考下
    2016-11-11
  • python运维自动化Paramiko的实现示例

    python运维自动化Paramiko的实现示例

    Paramiko是Python的SSH库,提供SSHClient和SFTPClient类,用于远程命令执行及文件传输,支持连接、执行、上传下载,适用于自动化部署等场景,下面就来详细介绍一下Paramiko的使用
    2025-08-08
  • Python参数的传递几种情况实例详解

    Python参数的传递几种情况实例详解

    这篇文章主要给大家介绍了关于Python参数的传递的相关资料,在Python中传递参数指的是函数或方法中的参数传输方式,文中给出了详细的代码示例,需要的朋友可以参考下
    2023-09-09
  • Python中利用函数装饰器实现备忘功能

    Python中利用函数装饰器实现备忘功能

    这篇文章主要介绍了Python中利用函数装饰器实现备忘功能,同时还降到了利用装饰器来检查函数的递归、确保参数传递的正确,需要的朋友可以参考下
    2015-03-03
  • 浅析Python中的多进程编程

    浅析Python中的多进程编程

    在这篇文章中,我们将专注于讨论Python中的多进程编程,例如进程的创建、管理和同步,以及一些更高级的概念,如进程池,需要的可以参考一下
    2023-07-07
  • pytorch+torchvision+python版本对应及环境安装

    pytorch+torchvision+python版本对应及环境安装

    本文主要介绍了pytorch+torchvision+python版本对应及环境安装,安装过程中需要注意Numpy版本的降级,以确保与PyTorch兼容,具有一定的参考价值,感兴趣的可以了解一下
    2025-03-03
  • tensorflow学习笔记之mnist的卷积神经网络实例

    tensorflow学习笔记之mnist的卷积神经网络实例

    这篇文章主要为大家详细介绍了tensorflow学习笔记之mnist的卷积神经网络实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-04-04
  • python常用的正则表达式大全

    python常用的正则表达式大全

    正则表达式是一个特殊的字符序列,它能帮助你方便的检查一个字符串是否与某种模式匹配,下面这篇文章主要给大家介绍了关于python常用正则表达式的相关资料,文中通过图文以及实例代码介绍的非常详细,需要的朋友可以参考下
    2022-02-02
  • python中的opencv 图像分割与提取

    python中的opencv 图像分割与提取

    这篇文章主要介绍了python中的opencv 图像分割与提取,图像中将前景对象作为目标图像分割或者提取出来。对背景本身并无兴趣分水岭算法及GrabCut算法对图像进行分割及提取。具体实现过程需要的朋友可以参考下面文章详细介绍
    2022-06-06
  • 详解pandas.DataFrame中删除包涵特定字符串所在的行

    详解pandas.DataFrame中删除包涵特定字符串所在的行

    这篇文章主要介绍了pandas.DataFrame中删除包涵特定字符串所在的行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04

最新评论