Python-Opencv 輪廓常用操作

Python-Opencv 輪廓常用操作

1.顏色空間轉換

使用cv2.cvtColor(input_image ,flag),flag為轉換類型

常用的轉換類型有:

  • BGR和灰度圖的轉換使用 cv2.COLOR_BGR2GRAY
  • BGR和HSV的轉換使用 cv2.COLOR_BGR2HSV
img_gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)

2.二值化

ret, dst = cv2.threshold(src, thresh, maxval, type)

  • src:表示的是圖片源(灰度圖)
  • thresh:表示的是閾值(起始值)
  • maxval:表示的是最大值
  • type:表示的是這里劃分的時候使用的是什么類型的算法,常用值為0(cv2.THRESH_BINARY)

返回值

  • ret:指定的thresh

  • dst: 目標圖像

ret, dst = cv2.threshold(img_gray, 200, 255, cv2.THRESH_BINARY)

3.查找并繪制輪廓

參考引用:原文鏈接:https://blog.csdn.net/weixin_42216109/article/details/89840323

3.1 cv2.findContours(image, mode, method[, offset])

概述:

尋找一個二值圖像的輪廓。注意黑色表示背景,白色表示物體,即在黑色背景里尋找白色物體的輪廓

參數:

  • image: 8位單通道圖像。非零像素值視為1,所以圖像視作二值圖像
  • mode: 輪廓檢索的方式
    • cv2.RETR_EXTERNAL: 只檢索外部輪廓
    • cv2.RETR_LIST: 檢測所有輪廓且不建立層次結構
    • cv2.RETR_CCOMP: 檢測所有輪廓,建立兩級層次結構。上面的一層為外邊界,里面的一層為內孔的邊界信息。如果內孔內還有一個連通物體,這個物體的邊界也在頂層。
    • cv2.RETR_TREE: 檢測所有輪廓,建立完整的層次結構
  • method: 輪廓近似的方法
    • cv2.CHAIN_APPROX_NONE: 存儲所有的輪廓點
    • cv2.CHAIN_APPROX_SIMPLE: 壓縮水平,垂直和對角線段,只留下端點。 例如矩形輪廓可以用4個點編碼
    • cv2.CHAIN_APPROX_TC89_L1,cv2.CHAIN_APPROX_TC89_KCOS:使用Teh-Chini chain近似算法
  • offset:(可選參數)輪廓點的偏移量,格式為tuple,如(-10,10)表示輪廓點沿X負方向偏移10個像素點,沿Y正方向偏移10個像素點

返回值:

  • contours: 輪廓點。列表格式,每一個元素為一個3維數組(其形狀為(n,1,2),其中n表示輪廓點個數,2表示像素點坐標),表示一個輪廓
  • hierarchy: 輪廓間的層次關系,為三維數組,形狀為(1,n,4),其中n表示輪廓總個數,4指的是用4個數表示各輪廓間的相互關系。第一個數表示同級輪廓的下一個輪廓編號,第二個數表示同級輪廓的上一個輪廓的編號,第三個數表示該輪廓下一級輪廓的編號,第四個數表示該輪廓的上一級輪廓的編號

補充: 若想得到輪廓點的集合的列表,可使用

cnt = np.squeeze(contours[0])

3.2 cv2.drawContours(image, contours, contourIdx, color[, thickness[, lineType[, hierarchy[, maxLevel[, offset]]]])

參數:

  • image: 需要繪制輪廓的目標圖像,注意會改變原圖
  • contours: 輪廓點,上述函數cv2.findContours()的第一個返回值
  • contourIdx: 輪廓的索引,表示繪制第幾個輪廓,-1表示繪制所有的輪廓
  • color: 繪制輪廓的顏色
  • thickness:(可選參數)輪廓線的寬度,-1表示填充
  • lineType:(可選參數)輪廓線型,包括cv2.LINE_4,cv2.LINE_8(默認),cv2.LINE_AA,分別表示4鄰域線,8領域線,抗鋸齒線(可以更好地顯示曲線)
  • hierarchy:(可選參數)層級結構,上述函數cv2.findContours()的第二個返回值,配合maxLevel參數使用
  • maxLevel:(可選參數)等于0表示只繪制指定的輪廓,等于1表示繪制指定輪廓及其下一級子輪廓,等于2表示繪制指定輪廓及其所有子輪廓
  • offset:(可選參數)輪廓點的偏移量
import cv2
img = cv2.imread('D:/2.jpg',1)

img_gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
ret, dst = cv2.threshold(img_gray, 200, 255, cv2.THRESH_BINARY)

contours,hierarchy = cv2.findContours(dst, cv2.RETR_LIST, cv2.CHAIN_APPROX_NONE)
cv2.drawContours(img, contours, -1, (0, 255, 0), 3)

cv2.imshow('img',img)
cv2.waitKey(0)

4.點與輪廓位置關系

此功能可查找圖像中的點與輪廓之間的最短距離。當點在輪廓外時返回負值,當點在內部時返回正值,如果點在輪廓上則返回零

dist = cv2.pointPolygonTest(cnt, (100, 100), True)

檢查(100,100)與輪廓(cnt)的距離

在函數中,第二個參數需要tuple類型;第三個參數是measureDist。 如果為True,則查找距離. 如果為False,則查找該點是在內部還是外部或在輪廓上(它分別返回+1,-1,0)

如果不需要到距離,請確保第三個參數為False,因為這是一個耗時的過程。因此,將其設為False可提供2-3倍的加速

5.直線擬合fitline函數

參考:原文鏈接:https://blog.csdn.net/lovetaozibaby/article/details/99482973

output = cv2.fitLine(InputArray points, distType, param, reps, aeps)

參數:

  • InputArray Points: 待擬合的直線的集合,必須是矩陣形式(如numpy.array)
  • distType: 距離類型。fitline為距離最小化函數,擬合直線時,要使輸入點到擬合直線的距離和最小化。這里的距離的類型有以下幾種:
    • cv2.DIST_USER : User defined distance
    • cv2.DIST_L1: distance = |x1-x2| + |y1-y2|
    • cv2.DIST_L2: 歐式距離,此時與最小二乘法相同
    • cv2.DIST_C: distance = max(|x1-x2|,|y1-y2|)
    • cv2.DIST_L12: L1-L2 metric: distance = 2(sqrt(1+x*x/2) - 1))
    • cv2.DIST_FAIR
    • cv2.DIST_WELSCH
    • cv2.DIST_HUBER
  • param: 距離參數,跟所選的距離類型有關,值可以設置為0
  • reps,aeps: 第5/6個參數用于表示擬合直線所需要的徑向和角度精度,通常情況下兩個值均被設定為1e-2

返回值:

  • output:對于二維直線,輸出output為4維,前兩維代表擬合出的直線的方向,后兩位代表直線上的一點。(即通常說的點斜式直線)
loc = np.array(loc)
output = cv2.fitLine(loc, cv2.DIST_L2, 0, 0.01, 0.01)
k = output[1] / output[0]
b = output[3] - k * output[2]#k[key]報錯?
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,247評論 6 543
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,520評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,362評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,805評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,541評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,896評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,887評論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,062評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,608評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,356評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,555評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,077評論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,769評論 3 349
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,175評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,489評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,289評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,516評論 2 379