opencv-python實現簡單的顏色識別程序

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)#打開電腦內置攝像頭
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)#該函數返回矩陣四個點
            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)  # 該函數返回矩陣四個點
            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()



我發現只要多於兩種顏色識別起來誤差就極大極大,等以後學到會回來進行優化的。目前識別兩種顏色還是比較穩的。
在這裏插入圖片描述
別問爲什麼就截一部分,問就是用嘴咬着手機識別的。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章