0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

OpenCV中幾何形狀識別與測量

OpenCV學堂 ? 來源:OpenCV學堂 ? 作者:OpenCV學堂 ? 2022-06-02 15:31 ? 次閱讀

OpenCV中幾何形狀識別與測量

經(jīng)常看到有學習OpenCV不久的人提問,如何識別一些簡單的幾何形狀與它們的顏色,其實通過OpenCV的輪廓發(fā)現(xiàn)與幾何分析相關的函數(shù),只需不到100行的代碼就可以很好的實現(xiàn)這些簡單幾何形狀識別與對象測量相關操作。本文就會演示給大家如何通過OpenCV 輪廓發(fā)現(xiàn)與幾何分析相關函數(shù)實現(xiàn)如下功能:

幾何形狀識別(識別三角形、四邊形/矩形、多邊形、圓)

計算幾何形狀面積與周長、中心位置

提取幾何形狀的顏色

在具體代碼實現(xiàn)與程序演示之前,我們先要搞清楚一些概念。

一:基本概念與函數(shù)介紹

1. 輪廓(contours)

什么是輪廓,簡單說輪廓就是一些列點相連組成形狀、它們擁有同樣的顏色、輪廓發(fā)現(xiàn)在圖像的對象分析、對象檢測等方面是非常有用的工具,在OpenCV中使用輪廓發(fā)現(xiàn)相關函數(shù)時候要求輸入圖像是二值圖像,這樣便于輪廓提取、邊緣提取等操作。輪廓發(fā)現(xiàn)的函數(shù)與參數(shù)解釋如下:

findContours(image, mode, method, contours=None, hierarchy=None, offset=None)

- image輸入/輸出的二值圖像

- mode 返回輪廓的結構、可以是List、Tree、External

- method 輪廓點的編碼方式,基本是基于鏈式編碼

- contours 返回的輪廓集合

- hieracrchy 返回的輪廓層次關系

- offset 點是否有位移

2. 多邊形逼近

多邊形逼近,是通過對輪廓外形無限逼近,刪除非關鍵點、得到輪廓的關鍵點,不斷逼近輪廓真實形狀的方法,OpenCV中多邊形逼近的函數(shù)與參數(shù)解釋如下:

approxPolyDP(curve, epsilon, closed, approxCurve=None)

- curve 表示輸入的輪廓點集合

- epsilon 表示逼近曲率,越小表示相似逼近越厲害

- close 是否閉合

3. 幾何距計算

圖像幾何距是圖像的幾何特征,高階幾何距中心化之后具有特征不變性,可以產(chǎn)生Hu距輸出,用于形狀匹配等操作,這里我們通過計算一階幾何距得到指定輪廓的中心位置,計算幾何距的函數(shù)與參數(shù)解釋如下:

moments(array, binaryImage=None)

- array表示指定輸入輪廓

- binaryImage默認為None

二:代碼實現(xiàn)與演示

基于輪廓發(fā)現(xiàn)與多邊形逼近、幾何距實現(xiàn)幾何形狀識別與對象測量,測量時候還用到另外兩個相關API分別是計算輪廓的周長與面積。具體用法在代碼中體現(xiàn)。整個代碼實現(xiàn)分為如下幾步完成:1.圖像二值化

# 二值化圖像

print("start to detect lines... ")

gray = cv.cvtColor(frame, cv.COLOR_BGR2GRAY)

ret, binary = cv.threshold(gray, 0, 255, cv.THRESH_BINARY_INV | cv.THRESH_OTSU)

cv.imshow("input image", frame)

2.輪廓發(fā)現(xiàn)

out_binary, contours, hierarchy = cv.findContours(binary, cv.RETR_EXTERNAL, cv.CHAIN_APPROX_SIMPLE)

for cnt in range(len(contours)):

# 提取與繪制輪廓

cv.drawContours(result, contours, cnt, (0, 255, 0), 2)

3.幾何形狀識別

# 輪廓逼近

epsilon = 0.01 * cv.arcLength(contours[cnt], True)

approx = cv.approxPolyDP(contours[cnt], epsilon, True)

# 分析幾何形狀

corners = len(approx)

shape_type = ""

if corners == 3:

count = self.shapes['triangle']

count = count+1

self.shapes['triangle'] = count

shape_type = "三角形"

if corners == 4:

count = self.shapes['rectangle']

count = count + 1

self.shapes['rectangle'] = count

shape_type = "矩形"

if corners >= 10:

count = self.shapes['circles']

count = count + 1

self.shapes['circles'] = count

shape_type = "圓形"

if 4 < corners < 10:

count = self.shapes['polygons']

count = count + 1

self.shapes['polygons'] = count

shape_type = "多邊形"

4.測量周長、面積、計算中心

# 求解中心位置

mm = cv.moments(contours[cnt])

cx = int(mm['m10'] / mm['m00'])

cy = int(mm['m01'] / mm['m00'])

cv.circle(result, (cx, cy), 3, (0, 0, 255), -1)

# 計算面積與周長

p = cv.arcLength(contours[cnt], True)

area = cv.contourArea(contours[cnt])

5.顏色提取

# 顏色分析

color = frame[cy][cx]

color_str = "(" + str(color[0]) + ", " + str(color[1]) + ", " + str(color[2]) + ")"

運行顯示原圖如下:

a8ed07b0-e191-11ec-ba43-dac502259ad0.png

分析結果:

a923e762-e191-11ec-ba43-dac502259ad0.png

控制臺輸出:

a9471d18-e191-11ec-ba43-dac502259ad0.png

審核編輯 :李倩

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 幾何
    +關注

    關注

    0

    文章

    37

    瀏覽量

    12314
  • 測量
    +關注

    關注

    10

    文章

    4614

    瀏覽量

    110578
  • OpenCV
    +關注

    關注

    29

    文章

    622

    瀏覽量

    41089

原文標題:OpenCV中幾何形狀識別與測量

文章出處:【微信號:CVSCHOOL,微信公眾號:OpenCV學堂】歡迎添加關注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關推薦

    OpenCV圖像識別C++代碼

    安裝OpenCV庫 首先,您需要在您的計算機上安裝OpenCV庫。您可以從OpenCV官網(wǎng)下載預編譯的庫或從源代碼編譯。安裝完成后,確保將OpenCV的頭文件和庫文件添加到您的項目中。
    的頭像 發(fā)表于 07-16 10:42 ?1098次閱讀

    opencv圖像識別有什么算法

    圖像識別算法: 邊緣檢測 :邊緣檢測是圖像識別的基本步驟之一,用于識別圖像的邊緣。常見的邊緣檢測算法有Canny邊緣檢測器、Sobel邊
    的頭像 發(fā)表于 07-16 10:40 ?372次閱讀

    基于OpenCV的人臉識別系統(tǒng)設計

    基于OpenCV的人臉識別系統(tǒng)是一個復雜但功能強大的系統(tǒng),廣泛應用于安全監(jiān)控、人機交互、智能家居等多個領域。下面將詳細介紹基于OpenCV的人臉識別系統(tǒng)的基本原理、實現(xiàn)步驟,并附上具體
    的頭像 發(fā)表于 07-11 15:37 ?1.1w次閱讀

    精準測量第一步:如何選擇合適的幾何尺寸測量儀器?

    在現(xiàn)代工業(yè)和制造業(yè),幾何尺寸測量是確保產(chǎn)品質(zhì)量和精度的關鍵環(huán)節(jié)。選擇合適的幾何尺寸測量儀器,不僅能提升
    的頭像 發(fā)表于 07-01 10:46 ?218次閱讀
    精準<b class='flag-5'>測量</b>第一步:如何選擇合適的<b class='flag-5'>幾何</b>尺寸<b class='flag-5'>測量</b>儀器?

    機床的幾何精度什么和什么時是有區(qū)別的

    機床的幾何精度是指機床在加工過程,其各部件的幾何形狀和相互位置精度。它直接關系到機床的加工精度和加工質(zhì)量。機床的幾何精度主要包括機床的直線
    的頭像 發(fā)表于 06-07 10:31 ?653次閱讀

    三坐標測量需要哪些基礎知識?

    三坐標測量(CoordinateMeasuringMachine,CMM)是一種利用測頭沿三個坐標軸移動來測量工件幾何尺寸和形狀的精密測量
    的頭像 發(fā)表于 05-17 09:51 ?1713次閱讀
    三坐標<b class='flag-5'>測量</b>需要哪些基礎知識?

    基于圖像處理技術的螺紋幾何參數(shù)測量系統(tǒng)設計

    摘要:針對螺紋幾何參數(shù)測量過程中,傳統(tǒng)人工測量效率低、儀器昂貴、耗時費力、偶伴有人為誤差等不足。本研究采用非接觸測量的方法, 利用計算機視覺的圖像處理技術,通過系統(tǒng)標定、圖像采集、圖像
    的頭像 發(fā)表于 01-15 11:13 ?728次閱讀
    基于圖像處理技術的螺紋<b class='flag-5'>幾何</b>參數(shù)<b class='flag-5'>測量</b>系統(tǒng)設計

    幾何尺寸測量工具介紹

    原理測量物體的三維形狀,到百米級激光跟蹤儀高精度(μm級)、大工作空間(百米級)的坐標和空間姿態(tài)測量,大大提高了幾何尺寸測量儀器設備的精度和
    的頭像 發(fā)表于 12-26 17:16 ?855次閱讀
    <b class='flag-5'>幾何</b>尺寸<b class='flag-5'>測量</b>工具介紹

    幾何測量基本原理及精密儀器

    從納米級光學3D表面輪廓儀通過光學原理測量物體的三維形狀,到百米級激光跟蹤儀高精度(μm級)、大工作空間(百米級)的坐標和空間姿態(tài)測量,越來越多高精度測量儀器被應用于
    的頭像 發(fā)表于 12-20 16:43 ?674次閱讀
    <b class='flag-5'>幾何</b>量<b class='flag-5'>測量</b>基本原理及精密儀器

    幾何量公差與檢測基本原理及測量儀器

    三本精密儀器小編獲悉,在現(xiàn)代科技的發(fā)展,幾何測量已經(jīng)成為許多工程領域不可或缺的一部分。通過準確測量物體的形狀、尺寸等
    的頭像 發(fā)表于 12-20 15:48 ?525次閱讀
    <b class='flag-5'>幾何</b>量公差與檢測基本原理及<b class='flag-5'>測量</b>儀器

    如何在 CFD 設計利用網(wǎng)格維護幾何形狀并減少運行時間?

    如何在 CFD 設計利用網(wǎng)格維護幾何形狀并減少運行時間?
    的頭像 發(fā)表于 11-24 17:07 ?402次閱讀
    如何在 CFD 設計<b class='flag-5'>中</b>利用網(wǎng)格維護<b class='flag-5'>幾何</b><b class='flag-5'>形狀</b>并減少運行時間?

    對于形狀近似矩形但邊緣有規(guī)則起伏的情況,可以使用OpenCV的approxPolyDP函數(shù)進行多邊形擬合和矩形檢測。

    對于形狀近似矩形但邊緣有規(guī)則起伏的情況,可以使用OpenCV的approxPolyDP函數(shù)進行多邊形擬合和矩形檢測。 approxPolyDP函數(shù)通過在給定的點集上使用動態(tài)規(guī)劃算法,計算出近似
    發(fā)表于 11-01 09:23

    智能車識別圖an用openmv還是用opencv?

    智能車創(chuàng)意組識別圖an用openmv 還是用 opencv 比較好
    發(fā)表于 10-24 06:24

    【幸狐Core3566模組試用體驗】基于openCV的貓臉識別

    本文主要介紹如何基于openCV來實現(xiàn)一個簡單的貓臉識別應用。
    的頭像 發(fā)表于 09-25 09:05 ?841次閱讀
    【幸狐Core3566模組試用體驗】基于<b class='flag-5'>openCV</b>的貓臉<b class='flag-5'>識別</b>

    【幸狐 Core3566 模組試用體驗】基于openCV的貓臉識別

    本文主要介紹如何基于openCV來實現(xiàn)一個簡單的貓臉識別應用。 一、基礎準備 首先需要安裝openCV,因為python版的方便點,所以直接安裝python版openCV,通過命令su
    發(fā)表于 09-24 23:50