Python+OpenCV圖像處理——實(shí)現(xiàn)輪廓發(fā)現(xiàn)
簡(jiǎn)介:輪廓發(fā)現(xiàn)是基于圖像邊緣提取的基礎(chǔ)尋找對(duì)象輪廓的方法,所以邊緣提取的閾值選定會(huì)影響最終輪廓發(fā)現(xiàn)結(jié)果。
代碼如下:
import cv2 as cv import numpy as np def contours_demo(image): dst = cv.GaussianBlur(image, (3, 3), 0) #高斯模糊去噪 gray = cv.cvtColor(dst, cv.COLOR_RGB2GRAY) ret, binary = cv.threshold(gray, 0, 255, cv.THRESH_BINARY | cv.THRESH_OTSU) #用大律法、全局自適應(yīng)閾值方法進(jìn)行圖像二值化 cv.imshow("binary image", binary) cloneTmage, contours, heriachy = cv.findContours(binary, cv.RETR_EXTERNAL, cv.CHAIN_APPROX_SIMPLE) for i, contour in enumerate(contours): cv.drawContours(image, contours, i, (0, 0, 255), 2) print(i) cv.imshow("contours", image) for i, contour in enumerate(contours): cv.drawContours(image, contours, i, (0, 0, 255), -1) cv.imshow("pcontours", image) src = cv.imread('E:/imageload/coins.jpg') cv.namedWindow('input_image', cv.WINDOW_NORMAL) #設(shè)置為WINDOW_NORMAL可以任意縮放 cv.imshow('input_image', src) contours_demo(src) cv.waitKey(0) cv.destroyAllWindows()
運(yùn)行結(jié)果:
注意:
1.Opencv發(fā)現(xiàn)輪廓的函數(shù)原型為:findContours(image, mode, method[, contours[, hierarchy[, offset]]]) -> image, contours, hierarchy
image參數(shù)表示8位單通道圖像矩陣,可以是灰度圖,但更常用的是二值圖像,一般是經(jīng)過(guò)Canny、拉普拉斯等邊緣檢測(cè)算子處理過(guò)的二值圖像。
mode參數(shù)表示輪廓檢索模式:
①CV_RETR_EXTERNAL:只檢測(cè)最外圍輪廓,包含在外圍輪廓內(nèi)的內(nèi)圍輪廓被忽略。
②CV_RETR_LIST:檢測(cè)所有的輪廓,包括內(nèi)圍、外圍輪廓,但是檢測(cè)到的輪廓不建立等級(jí)關(guān)系,彼此之間獨(dú)立,沒(méi)有等級(jí)關(guān)系,這就意味著這個(gè)檢索模式下不存在父輪廓或內(nèi)嵌輪廓。
③CV_RETR_CCOMP:檢測(cè)所有的輪廓,但所有輪廓只建立兩個(gè)等級(jí)關(guān)系,外圍為頂層,若外圍內(nèi)的內(nèi)圍輪廓還包含了其他的輪廓信息,則內(nèi)圍內(nèi)的所有輪廓均歸屬于頂層。
④CV_RETR_TREE:檢測(cè)所有輪廓,所有輪廓建立一個(gè)等級(jí)樹結(jié)構(gòu),外層輪廓包含內(nèi)層輪廓,內(nèi)層輪廓還可以繼續(xù)包含內(nèi)嵌輪廓。
method參數(shù)表示輪廓的近似方法:
①CV_CHAIN_APPROX_NONE 存儲(chǔ)所有的輪廓點(diǎn),相鄰的兩個(gè)點(diǎn)的像素位置差不超過(guò)1,即max (abs (x1 - x2), abs(y2 - y1) == 1。
②CV_CHAIN_APPROX_SIMPLE壓縮水平方向,垂直方向,對(duì)角線方向的元素,只保留該方向的終點(diǎn)坐標(biāo),例如一個(gè)矩形輪廓只需4個(gè)點(diǎn)來(lái)保存輪廓信息。
③CV_CHAIN_APPROX_TC89_L1,CV_CHAIN_APPROX_TC89_KCOS使用teh-Chinl chain 近似算法。
contours參數(shù)是一個(gè)list,表示存儲(chǔ)的每個(gè)輪廓的點(diǎn)集合。
hierarchy參數(shù)是一個(gè)list,list中元素個(gè)數(shù)和輪廓個(gè)數(shù)相同,每個(gè)輪廓contours[i]對(duì)應(yīng)4個(gè)hierarchy元素hierarchy[i][0] ~hierarchy[i][3],分別表示后一個(gè)輪廓、前一個(gè)輪廓、父輪廓、內(nèi)嵌輪廓的索引編號(hào),如果沒(méi)有對(duì)應(yīng)項(xiàng),則該值為負(fù)數(shù)。
offset參數(shù)表示每個(gè)輪廓點(diǎn)移動(dòng)的可選偏移量。
2.Opencv繪制輪廓的函數(shù)原型為:drawContours(image, contours, contourIdx, color[, thickness[, lineType[, hierarchy[, maxLevel[, offset]]]]]) -> image
imgae參數(shù)表示目標(biāo)圖像。
contours參數(shù)表示所有輸入輪廓。
contourIdx參數(shù)表示繪制輪廓list中的哪條輪廓, 如果是負(fù)數(shù),則繪制所有輪廓。
color參數(shù)表示輪廓的顏色。
thickness參數(shù)表示繪制的輪廓線條粗細(xì),如果是負(fù)數(shù),則繪制輪廓內(nèi)部。
lineType參數(shù)表示線型。
hierarchy參數(shù)表示有關(guān)層次結(jié)構(gòu)的可選信息。
maxLevel參數(shù)表示繪制輪廓的最大級(jí)別。 如果為0,則僅繪制指定的輪廓。 如果為1,則該函數(shù)繪制輪廓和所有嵌套輪廓。 如果為2,則該函數(shù)繪制輪廓,所有嵌套輪廓,所有嵌套到嵌套的輪廓,等等。 僅當(dāng)有可用的層次結(jié)構(gòu)時(shí)才考慮此參數(shù)。
offset參數(shù)表示可選的輪廓偏移參數(shù),該參數(shù)可按指定的方式移動(dòng)所有繪制的輪廓。
以上就是Python+OpenCV圖像處理——實(shí)現(xiàn)輪廓發(fā)現(xiàn)的詳細(xì)內(nèi)容,更多關(guān)于python 輪廓發(fā)現(xiàn)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- Opencv圖像處理:如何判斷圖片里某個(gè)顏色值占的比例
- Python+OpenCV圖像處理——圖像二值化的實(shí)現(xiàn)
- Opencv圖像處理之詳解掩膜mask
- Python+OpenCV圖像處理——實(shí)現(xiàn)直線檢測(cè)
- 詳解python opencv、scikit-image和PIL圖像處理庫(kù)比較
- OpenCV圖像處理之常見的圖像灰度變換
- Python+OpenCV數(shù)字圖像處理之ROI區(qū)域的提取
- Opencv圖像處理之輪廓外背景顏色改變
- Python+OpenCV圖像處理—— 色彩空間轉(zhuǎn)換
- OpenCV+Qt實(shí)現(xiàn)圖像處理操作
相關(guān)文章
Python內(nèi)置函數(shù)——__import__ 的使用方法
本篇文章主要介紹了Python內(nèi)置函數(shù)——__import__ 的使用方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11MacBook m1芯片采用miniforge安裝python3.9的方法示例
這篇文章主要介紹了MacBook m1芯片采用miniforge安裝python3.9的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04python中dir()與__dict__屬性的區(qū)別淺析
這篇文章主要給大家介紹了關(guān)于python中dir()與__dict__屬性的區(qū)別的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-12-12解決Mac下首次安裝pycharm無(wú)project interpreter的問(wèn)題
今天小編就為大家分享一篇解決Mac下首次安裝pycharm無(wú)project interpreter的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-10-10