亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術文章
文章詳情頁

Android+OpenCv4實現邊緣檢測及輪廓繪制出圖像最大邊緣

瀏覽:8日期:2022-09-18 16:34:14
實現步驟: 圖像灰度化 邊緣檢測 根據Canny檢測得出來的Mat尋找輪廓 算出最大輪廓周長or面積 根據獲取到的最大輪廓下標進行輪廓繪制 畫出最大矩形,并返回RectCanny邊緣檢測

基于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; }

Android+OpenCv4實現邊緣檢測及輪廓繪制出圖像最大邊緣

獲取圖像最大矩形

/** * 返回邊緣檢測之后的最大矩形,并返回 * * @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實現邊緣檢測及輪廓繪制出圖像最大邊緣的文章就介紹到這了,更多相關Android OpenCv4邊緣檢測內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Android
相關文章:
主站蜘蛛池模板: 深夜做爰性大片很黄很色视频 | 久久99久久精品免费思思 | 永久黄网站色视频免费网站 | 狠狠狠狠狠 | 国产手机在线精品 | 亚洲精品在线免费观看视频 | 国产成人a福利在线观看 | 国产成人一区二区三区在线播放 | 久久精品国产99国产精品免费看 | 男人天堂日韩 | 欧美一级毛片无遮挡 | 国产欧美日韩视频在线观看 | 久久成| 波多野结衣一级 | 亚洲欧美一区二区三区在线 | 日本b站一卡二卡乱码入口 日本s色大片在线观看 | 日本韩国中文字幕 | 国产成人精品一区二区免费视频 | 美女黄视频免费观看 | 日韩99在线 | 五月久久噜噜噜色影 | 亚洲精品天堂一区在线观看 | 国产精品一区二区久久精品涩爱 | 一区二区三区观看 | 一区二区三区精品视频 | 国产日韩在线播放 | 中文乱码字幕午夜无线观看 | av狼论坛| 小屁孩cao大人免费网站 | 欧美一级在线免费观看 | 97影院理伦在线观看 | 特级毛片aaa免费版 特级毛片a级毛免费播放 | 特级毛片aaaa免费观看 | 亚洲精品字幕一区二区三区 | 中国老太性色xxxxxhd | 亚洲精品综合久久中文字幕 | 高清一级毛片免免费看 | 欧美成人精品不卡视频在线观看 | 国产中的精品一区的 | 午夜香港三级a三级三点 | 国内自拍视频在线看免费观看 |