python實(shí)現(xiàn)簡(jiǎn)單顏色識(shí)別程序
本文實(shí)例為大家分享了python實(shí)現(xiàn)簡(jiǎn)單顏色識(shí)別程序的具體代碼,供大家參考,具體內(nèi)容如下
import numpy as np
import cv2
font= cv2.FONT_HERSHEY_SIMPLEX
lower_red=np.array([0,127,128])#紅色閾值下界
higher_red=np.array([10,255,255])#紅色閾值上界
lower_green=np.array([35,110,106])#綠色閾值下界
higher_green=np.array([77,255,255])#綠色閾值上界
cap=cv2.VideoCapture(0)#打開(kāi)電腦內(nèi)置攝像頭
if(cap.isOpened()):
while(True):
ret,frame=cap.read()#按幀讀取,這是讀取一幀
img_hsv=cv2.cvtColor(frame,cv2.COLOR_BGR2HSV)
mask_red=cv2.inRange(img_hsv,lower_red,higher_red)#可以認(rèn)為是過(guò)濾出紅色部分,獲得紅色的掩膜
mask_green=cv2.inRange(img_hsv,lower_green,higher_green)#獲得綠色部分掩膜
mask_green = cv2.medianBlur(mask_green, 7) # 中值濾波
mask_red = cv2.medianBlur(mask_red, 7) # 中值濾波
mask=cv2.bitwise_or(mask_green,mask_red)#三部分掩膜進(jìn)行按位或運(yùn)算
image1,cnts1,hierarchy1=cv2.findContours(mask_red,cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_NONE)#輪廓檢測(cè)
image3,cnts3,hierarchy3=cv2.findContours(mask_green,cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_NONE)
for cnt in cnts1:
(x,y,w,h)=cv2.boundingRect(cnt)#該函數(shù)返回矩陣四個(gè)點(diǎn)
cv2.rectangle(frame, (x, y), (x + w, y + h), (0, 0, 255), 2)#將檢測(cè)到的顏色框起來(lái)
cv2.putText(frame,'red',(x,y-5),font,0.7,(0,0,255),2)
for cnt in cnts3:
(x, y, w, h) = cv2.boundingRect(cnt) # 該函數(shù)返回矩陣四個(gè)點(diǎn)
cv2.rectangle(frame, (x, y), (x + w, y + h), (0, 255, 0), 2) # 將檢測(cè)到的顏色框起來(lái)
cv2.putText(frame, 'green', (x, y - 5), font, 0.7, (0,255,0), 2)
cv2.imshow('frame',frame)
k=cv2.waitKey(20)&0xFF
if k ==27:
break
cv2.waitKey(0)
cv2.destroyAllWindows()
我發(fā)現(xiàn)只要多于兩種顏色識(shí)別起來(lái)誤差就極大極大,等以后學(xué)到會(huì)回來(lái)進(jìn)行優(yōu)化的。目前識(shí)別兩種顏色還是比較穩(wěn)的。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Python?OpenCV實(shí)現(xiàn)簡(jiǎn)單的顏色識(shí)別功能(對(duì)紅色和藍(lán)色識(shí)別并輸出)
- Python+OpenCV實(shí)現(xiàn)圖片及視頻中選定區(qū)域顏色識(shí)別
- Python+OpenCV實(shí)現(xiàn)基于顏色的目標(biāo)識(shí)別
- python+opencv實(shí)現(xiàn)文字顏色識(shí)別與標(biāo)定功能
- 50行Python代碼實(shí)現(xiàn)視頻中物體顏色識(shí)別和跟蹤(必須以紅色為例)
- 淺談Python3識(shí)別判斷圖片主要顏色并和顏色庫(kù)進(jìn)行對(duì)比的方法
- python微信跳一跳系列之棋子定位顏色識(shí)別
- python識(shí)別圖片中指定顏色的圖案并保存為圖片
相關(guān)文章
Python結(jié)合Sprak實(shí)現(xiàn)計(jì)算曲線與X軸上方的面積
這篇文章主要介紹了Python結(jié)合Sprak實(shí)現(xiàn)計(jì)算曲線與X軸上方的面積,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2023-02-02
numpy數(shù)組坐標(biāo)軸問(wèn)題解決
本文主要介紹了numpy數(shù)組坐標(biāo)軸問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03
Python中用PIL庫(kù)批量給圖片加上序號(hào)的教程
這篇文章主要介紹了Python中用PIL庫(kù)批量給圖片加上序號(hào)的教程,PIL庫(kù)是Python中一個(gè)非常強(qiáng)大的處理圖片的庫(kù),需要的朋友可以參考下2015-05-05
在PyCharm中打包Python項(xiàng)目并將其運(yùn)行到服務(wù)器上的方法(推薦)
在PyCharm中打包Python項(xiàng)目并運(yùn)行到服務(wù)器上,主要步驟包括:創(chuàng)建并設(shè)置項(xiàng)目、編寫(xiě)項(xiàng)目代碼、打包項(xiàng)目、配置服務(wù)器環(huán)境、上傳可執(zhí)行文件到服務(wù)器以及運(yùn)行項(xiàng)目,通過(guò)這些步驟,可以將Python項(xiàng)目打包并部署到服務(wù)器上2024-11-11
詳解Python的Django框架中Manager方法的使用
這篇文章主要介紹了Python的Django框架中Manager方法的使用,包括修改初始Manager QuerySets和增加額外的Manager方法等操作,需要的朋友可以參考下2015-07-07

