中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

opencv如何實現特定顏色線條提取與定位

發布時間:2020-07-20 09:45:09 來源:億速云 閱讀:983 作者:小豬 欄目:開發技術

這篇文章主要為大家展示了opencv如何實現特定顏色線條提取與定位,內容簡而易懂,希望大家可以學習一下,學習完之后肯定會有收獲的,下面讓小編帶大家一起來看看吧。

主要步驟:

將RGB圖像轉化為HSV,H表示色調(度數表示0-180),S表示飽和度(取值0-255),V表示亮度(取值0-255),不同的顏色有著不同的取值范圍,一般給出如下:

設定待提取顏色的HSV范圍值,然后調用inRange函數實現對顏色空間的提取,該函數會將除目標顏色外的其余顏色為黑色背景,僅保留該顏色為前景

cv2.inRange(hsv, lower_red, upper_red)

參數解析:

第一個參數:hsv指的是原圖

第二個參數:lower_red指的是圖像中低于這個lower_red的值,圖像值變為0

第三個參數:upper_red指的是圖像中高于這個upper_red的值,圖像值變為0

而在lower_red~upper_red之間的值變成255

二值化

腐蝕與膨脹操作,去除噪點,連接斷點

調用findContours函數進行輪廓檢測

cv2.findContours()函數接受的參數為二值圖,即黑白的(不是灰度圖)

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

參數解析

第一個參數是尋找輪廓的圖像;

第二個參數表示輪廓的檢索模式,有四種(本文介紹的都是新的cv2接口):

cv2.RETR_EXTERNAL表示只檢測外輪廓

cv2.RETR_LIST檢測的輪廓不建立等級關系

cv2.RETR_CCOMP建立兩個等級的輪廓,上面的一層為外邊界,里面的一層為內孔的邊界信息。如果內孔內還有一個連通物體,這個物體的邊界也在頂層。

cv2.RETR_TREE建立一個等級樹結構的輪廓。

第三個參數method為輪廓的近似辦法

cv2.CHAIN_APPROX_NONE存儲所有的輪廓點,相鄰的兩個點的像素位置差不超過1,即max(abs(x1-x2),abs(y2-y1))==1

cv2.CHAIN_APPROX_SIMPLE壓縮水平方向,垂直方向,對角線方向的元素,只保留該方向的終點坐標,例如一個矩形輪廓只需4個點來保存輪廓信息

cv2.CHAIN_APPROX_TC89_L1,CV_CHAIN_APPROX_TC89_KCOS使用teh-Chinl chain 近似算法

返回值

cv2.findContours()函數返回三個值,一個是圖像,一個是輪廓本身,還有一個是每條輪廓對應的屬性。

對于輪廓是以坐標的形式返回,可以通過函數cv2.drawContours()繪制出輪廓

繪制矩形區域對輪廓進行定位

主要代碼如下:

import numpy as np
import cv2
import os
image = 'image1.jpg'
savefile = './mark1'
# image = os.listdir(image_file)
save_image = os.path.join(savefile, image)

#設定顏色HSV范圍,假定為紅色
redLower = np.array([156, 43, 46])
redUpper = np.array([179, 255, 255])

#讀取圖像
img = cv2.imread(image)

#將圖像轉化為HSV格式
hsv = cv2.cvtColor(img, cv2.COLOR_BGR2HSV)

#去除顏色范圍外的其余顏色
mask = cv2.inRange(hsv, redLower, redUpper)

# 二值化操作
ret, binary = cv2.threshold(mask, 0, 255, cv2.THRESH_BINARY)

#膨脹操作,因為是對線條進行提取定位,所以腐蝕可能會造成更大間隔的斷點,將線條切斷,因此僅做膨脹操作
kernel = np.ones((5, 5), np.uint8)
dilation = cv2.dilate(binary, kernel, iterations=1)

#獲取圖像輪廓坐標,其中contours為坐標值,此處只檢測外形輪廓
_, contours, hierarchy = cv2.findContours(dilation, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)

if len(contours) > 0:
  #cv2.boundingRect()返回輪廓矩陣的坐標值,四個值為x, y, w, h, 其中x, y為左上角坐標,w,h為矩陣的寬和高
  boxes = [cv2.boundingRect(c) for c in contours]
  for box in boxes:
    x, y, w, h = box
    #繪制矩形框對輪廓進行定位
    cv2.rectangle(img, (x, y), (x+w, y+h), (153, 153, 0), 2)
	#將繪制的圖像保存并展示
	cv2.imwrite(save_image, img)
	cv2.imshow('image', img)
	cv2.waitKey(0)
	cv2.destroyAllWindows()

效果如圖,一試卷紅色批改字樣為例:

原圖:

opencv如何實現特定顏色線條提取與定位

對批改區域定位圖:

opencv如何實現特定顏色線條提取與定位

以上就是關于opencv如何實現特定顏色線條提取與定位的內容,如果你們有學習到知識或者技能,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

昔阳县| 平远县| 凤庆县| 犍为县| 彰化县| 兴业县| 都昌县| 万盛区| 抚远县| 内乡县| 象州县| 哈密市| 商洛市| 德钦县| 浠水县| 从化市| 古交市| 子长县| 淮北市| 关岭| 英山县| 栾城县| 隆回县| 车险| 临泉县| 施秉县| 高邑县| 六安市| 民县| 炎陵县| 鲁甸县| 阿克苏市| 呼伦贝尔市| 汝阳县| 柳州市| 沅陵县| 南宁市| 济源市| 蓝山县| 奉新县| 澳门|