




版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
第OpenCV半小時掌握基本操作之圖像輪廓目錄概述圖像輪廓繪制輪廓輪廓特征輪廓近似邊界矩形外接圓【OpenCV】高手勿入!半小時學會基本操作圖像輪廓
概述
OpenCV是一個跨平臺的計算機視覺庫,支持多語言,功能強大.今天小白就帶大家一起攜手走進OpenCV的世界.
圖像輪廓
cv2.findContours可以幫助我們查找輪廓.
格式:
cv2.findContours(image,mode,method,contours=None,hierarchy=None,offset=None)
參數(shù):
image:需要查找輪廓的圖片
mode:模式
RETR_EXTERNAL:只檢測最外面的輪廓
RETR_LIST:檢測所有的輪廓,并將其保存到一條鏈表中
RETR_CCOMP:檢索所有的輪廓,將他們組織為兩層:頂部是各分部法外部邊界,第二層是空洞的邊界
RRTR_TREE:檢索所有的輪廓,并重構嵌套輪廓的整個層次
method:輪廓逼近的方法
CHAIN_APPROX_NONE:以Freeman鏈碼的方式輸出輪廓,所有其他方法輸出多邊形(定點的序列)
CHAIN_APPROX_SIMPLE:壓縮水平的,垂直的和斜的部分,只保留他們的終點部分
返回值:
contours:輪廓本身
hierarchy:輪廓的對應編號
原圖:
繪制輪廓
cv2.drawContours可以實現(xiàn)輪廓繪制.
格式:
cv2.drawContours(image,contours,contourIdx,color,thickness=None,lineType=None,hierarchy=None,maxLevel=None,offset=None):
參數(shù):
image:需要繪制輪廓的圖片
contours:輪廓
color:顏色
thickness:輪廓粗細
繪制所有輪廓:
#讀取圖片
img=cv2.imread("contours.jpg")
#轉(zhuǎn)換成灰度圖
gray=cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
#二值化
ret,thresh=cv2.threshold(gray,127,255,cv2.THRESH_BINARY)
#獲取輪廓(所有)
contours,hierarchy=cv2.findContours(thresh,cv2.RETR_TREE,cv2.CHAIN_APPROX_NONE)
#繪制輪廓
draw_img=img.copy()
res=cv2.drawContours(draw_img,contours,-1,(0,0,255),2)
#圖片展示
cv2.imshow("res",res)
cv2.waitKey(0)
cv2.destroyAllWindows()
輸出結果:
繪制單個輪廓:
#讀取圖片
img=cv2.imread("contours.jpg")
#轉(zhuǎn)換成灰度圖
gray=cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
#二值化
ret,thresh=cv2.threshold(gray,127,255,cv2.THRESH_BINARY)
#獲取輪廓
contours,hierarchy=cv2.findContours(thresh,cv2.RETR_TREE,cv2.CHAIN_APPROX_NONE)
#繪制輪廓(單一)
draw_img=img.copy()
res=cv2.drawContours(draw_img,contours,0,(0,0,255),2)
#圖片展示
cv2.imshow("res",res)
cv2.waitKey(0)
cv2.destroyAllWindows()
輸出結果:
輪廓特征
#獲取輪廓
cnt=contours[0]#取第一個輪廓
area=cv2.contourArea(cnt)
print("輪廓面積:",area)
#周長,True表示合并
perimeter=cv2.arcLength(cnt,True)
print("輪廓周長:",perimeter)
輸出結果:
輪廓面積:8500.5
輪廓周長:437.9482651948929
輪廓近似
原圖:
代碼:
#讀取圖片
img=cv2.imread("contours2.jpg")
#轉(zhuǎn)換成灰度圖
gray=cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
#二值化
ret,thresh=cv2.threshold(gray,127,255,cv2.THRESH_BINARY)
#獲取輪廓
contours,hieratchy=cv2.findContours(thresh,cv2.RETR_TREE,cv2.CHAIN_APPROX_NONE)
#繪制輪廓
draw_img=img.copy()
res=cv2.drawContours(draw_img,contours,0,(0,0,255),2)
#圖片展示
cv2.imshow("res",res)
cv2.waitKey(0)
cv2.destroyAllWindows()
#取外圍輪廓
cnt=contours[0]
#輪廓近似
epsilon=0.1*cv2.arcLength(cnt,True)
approx=cv2.approxPolyDP(cnt,epsilon,True)
#繪制輪廓
draw_img=img.copy()
res=cv2.drawContours(draw_img,[approx],-1,(0,0,255),2)
#圖片展示
cv2.imshow("res",res)
cv2.waitKey(0)
cv2.destroyAllWindows()
輸出結果:
直接繪制輪廓:
輪廓近似:
邊界矩形
cv2.boundingRect可以幫助我們得到邊界矩形的位置和長寬.
例子:
#讀取圖片
img=cv2.imread("contours.jpg")
#轉(zhuǎn)換成灰度圖
gray=cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
#二值化
ret,thresh=cv2.threshold(gray,127,255,cv2.THRESH_BINARY)
#獲取輪廓
contours,hierarchy=cv2.findContours(thresh,cv2.RETR_TREE,cv2.CHAIN_APPROX_NONE)
#獲取第一個輪廓
cnt=contours[0]
#獲取正方形坐標長寬
x,y,w,h=cv2.boundingRect(cnt)
#圖片展示
img=cv2.rectangle(img,(x,y),(x+w,y+h),(0,255,0),2)
cv2.imshow("img",img)
cv2.waitKey(0)
cv2.destroyAllWindows()
#輪廓面積
area=cv2.contourArea(cnt)
#邊界矩形面積
rect_area=w*h
extent=area/rect_area
print('輪廓面積與邊界矩形比:',extent)
輸出結果:
輪廓面積與邊界矩形比:0.5154317244724715
外接圓
cv2.minEnclosingCircle可以幫助我們得到外接圓的位置和半徑.
例子:
#讀取圖片
img=cv2.imread("contours.jpg")
#轉(zhuǎn)換成灰度圖
gray=cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
#二值化
ret,thresh=cv2.threshold(gray,127,255,cv2.THRESH_BINARY)
#獲取輪廓
contours,hierarchy=cv2.findContours(thresh,cv2.RETR_TREE,cv2.CHAIN_APPROX_NONE)
#獲取第一個輪廓
cnt=contours[0]
#獲取
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 江蘇省南通市2024-2025學年高一上學期11月期中英語試題(解析版)
- 海洋量子科技應用可能
- 2025年四川九州電子科技股份有限公司招聘IT等崗位考試筆試試題(含答案)
- 2025年寧夏中衛(wèi)市屬國有企業(yè)財務總監(jiān)(總會計師)選聘考試筆試試題(含答案)
- 2025年巴戟天行業(yè)深度調(diào)查及發(fā)展前景研究報告
- 車輛抵押擔保合同書模板
- 采砂船運輸與海洋環(huán)境保護責任書
- 財稅返還合同原件
- 車輛掛靠汽車維修與保險理賠服務合同
- 地保巡查方案
- 輸變電工程多維立體參考價(2025年版)
- 冷卻塔維修施工方案設計
- 2025年重癥醫(yī)學科護理信息化建設計劃
- 遼寧省大連市金州區(qū)-普蘭店區(qū)2024-2025學年六年級上期末數(shù)學試題
- 綜采工作面液壓支架安裝回撤工職業(yè)技能理論考試題庫150題(含答案)
- 場地平整項目承包合同范本
- 河南省歷年中考語文現(xiàn)代文閱讀之非連續(xù)性文本閱讀5篇(截至2024年)
- 麥秸稈環(huán)保板材項目可行性研究報告
- 《中醫(yī)養(yǎng)生學》課件-八段錦
- 山東某智慧農(nóng)場項目可行性研究報告
- 交通運輸安全生產(chǎn)知識培訓
評論
0/150
提交評論