python實現(xiàn)簡單顏色識別程序
本文實例為大家分享了python實現(xiàn)簡單顏色識別程序的具體代碼,供大家參考,具體內(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)#打開電腦內(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)#可以認為是過濾出紅色部分,獲得紅色的掩膜 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)#三部分掩膜進行按位或運算 image1,cnts1,hierarchy1=cv2.findContours(mask_red,cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_NONE)#輪廓檢測 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ù)返回矩陣四個點 cv2.rectangle(frame, (x, y), (x + w, y + h), (0, 0, 255), 2)#將檢測到的顏色框起來 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ù)返回矩陣四個點 cv2.rectangle(frame, (x, y), (x + w, y + h), (0, 255, 0), 2) # 將檢測到的顏色框起來 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)只要多于兩種顏色識別起來誤差就極大極大,等以后學(xué)到會回來進行優(yōu)化的。目前識別兩種顏色還是比較穩(wěn)的。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python并發(fā)爬蟲實用工具tomorrow實用解析
這篇文章主要介紹了python并發(fā)爬蟲實用工具tomorrow實用解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-09-09解決Pytorch dataloader時報錯每個tensor維度不一樣的問題
這篇文章主要介紹了解決Pytorch dataloader時報錯每個tensor維度不一樣的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-05-05python框架django項目部署相關(guān)知識詳解
這篇文章主要介紹了python框架django項目部署相關(guān)知識詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-11-11Scrapy中如何向Spider傳入?yún)?shù)的方法實現(xiàn)
這篇文章主要介紹了Scrapy中如何向Spider傳入?yún)?shù)的方法實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09Python設(shè)計模式結(jié)構(gòu)型代理模式
這篇文章主要介紹了Python設(shè)計模式結(jié)構(gòu)型代理模式,代理模式即Proxy?Pattern,為其他對象提供一種代理以控制對這個對象的訪問,下文內(nèi)容詳細介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-02-02基于Python實現(xiàn)自動用小寫字母替換文件后綴的大寫字母
本文介紹基于Python語言,基于一個大文件夾,遍歷其中的多個子文件夾,對于每一個子文件夾中的大量文件,批量將其文件的名稱或后綴名中的字母由大寫修改為小寫的方法,文中有相關(guān)的代碼示例供大家參考,需要的朋友可以參考下2024-04-04