欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android+OpenCv4實現(xiàn)邊緣檢測及輪廓繪制出圖像最大邊緣

 更新時間:2021年05月18日 09:52:41   作者:Best-dadong  
最近工作需求,需要用opencv來先做一個demo,掃描照片進行邊緣檢測和最大邊緣,就整理出來介紹一下,感興趣的小伙伴們可以參考一下

實現(xiàn)步驟:

  • 圖像灰度化
  • 邊緣檢測
  • 根據(jù)Canny檢測得出來的Mat尋找輪廓
  • 算出最大輪廓周長or面積
  • 根據(jù)獲取到的最大輪廓下標進行輪廓繪制
  • 畫出最大矩形,并返回Rect

Canny邊緣檢測

基于Canny算法的邊緣檢測主要有5個步驟,依次是高斯濾波、像素梯度計算、非極大值像素梯度抑制、滯后閾值處理和孤立弱邊緣抑制。Canny在有噪聲的情況下表現(xiàn)好不好,取決于前面的降噪過程,可以手動做高斯處理提高識別率。

/**
		image  輸入圖像,必須是CV_8U的單通道或者三通道圖像。
		edges  輸出圖像,與輸入圖像具有相同尺寸的單通道圖像,且數(shù)據(jù)類型為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;
            }
        }
      
        /**
         * 參數(shù)一:image,待繪制輪廓的圖像。
         *
         * 參數(shù)二:contours,待繪制的輪廓集合。
         *
         * 參數(shù)三:contourIdx,要繪制的輪廓在contours中的索引,若為負數(shù),表示繪制全部輪廓。
         *
         * 參數(shù)四:color,繪制輪廓的顏色。
         *
         * 參數(shù)五:thickness,繪制輪廓的線條粗細。若為負數(shù),那么繪制輪廓的內部。
         *
         * 參數(shù)六: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實現(xiàn)邊緣檢測及輪廓繪制出圖像最大邊緣的文章就介紹到這了,更多相關Android OpenCv4邊緣檢測內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Python實現(xiàn)的搖骰子猜大小功能小游戲示例

    Python實現(xiàn)的搖骰子猜大小功能小游戲示例

    這篇文章主要介紹了Python實現(xiàn)的搖骰子猜大小功能小游戲,涉及Python隨機數(shù)運算與數(shù)值判斷相關操作技巧,需要的朋友可以參考下
    2017-12-12
  • 基于Python編寫將文本轉換為語音的簡易應用

    基于Python編寫將文本轉換為語音的簡易應用

    這篇文章主要介紹了如何使用Python編寫一個簡單的應用程序,將文本轉換為語音,文中的示例代碼講解詳細,感興趣的小伙伴可以動手嘗試一下
    2023-08-08
  • Pandas 按索引合并數(shù)據(jù)集的方法

    Pandas 按索引合并數(shù)據(jù)集的方法

    今天小編就為大家分享一篇Pandas 按索引合并數(shù)據(jù)集的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-11-11
  • Pytorch實現(xiàn)常用乘法算子TensorRT的示例代碼

    Pytorch實現(xiàn)常用乘法算子TensorRT的示例代碼

    pytorch 用于訓練,TensorRT用于推理是很多AI應用開發(fā)的標配。大家往往更加熟悉 pytorch 的算子,而不太熟悉TensorRT的算子。本文介紹了Pytorch中常用乘法的TensorRT實現(xiàn),感興趣的可以了解一下
    2022-06-06
  • 使用Nibabel庫對nii格式圖像的讀寫操作

    使用Nibabel庫對nii格式圖像的讀寫操作

    這篇文章主要介紹了使用Nibabel庫對nii格式圖像的讀寫操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • Python datetime庫函數(shù)的示例詳解

    Python datetime庫函數(shù)的示例詳解

    datetime?是 Python 內置的日期時間處理庫,它包含了處理日期、時間、時間間隔等的類和函數(shù),這篇文章主要介紹了Python datetime庫函數(shù)的詳解,需要的朋友可以參考下
    2023-07-07
  • python 字符串轉列表 list 出現(xiàn)\ufeff的解決方法

    python 字符串轉列表 list 出現(xiàn)\ufeff的解決方法

    下面小編就為大家?guī)硪黄猵ython 字符串轉列表 list 出現(xiàn)\ufeff的解決方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • NumPy內存布局的實現(xiàn)

    NumPy內存布局的實現(xiàn)

    本文主要介紹了NumPy內存布局的實現(xiàn),括連續(xù)內存布局(C順序)和分散內存布局(Fortran順序),并通過實例演示如何操作數(shù)組的內存布局,感興趣的可以了解一下
    2024-01-01
  • Python自動生產(chǎn)表情包

    Python自動生產(chǎn)表情包

    本文主要介紹了使用Python進行簡單圖像處理的方法以及Python自動生產(chǎn)表情包的實例,具有很好的參考價值,下面跟著小編一起來看下吧
    2017-03-03
  • Python利用flask sqlalchemy實現(xiàn)分頁效果

    Python利用flask sqlalchemy實現(xiàn)分頁效果

    這篇文章主要為大家詳細介紹了利用flask sqlalchemy實現(xiàn)分頁效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07

最新評論