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

溫馨提示×

溫馨提示×

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

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

基于opencv如何實現視頻中的顏色識別功能

發布時間:2022-07-28 11:05:29 來源:億速云 閱讀:226 作者:iii 欄目:開發技術

本篇內容介紹了“基于opencv如何實現視頻中的顏色識別功能”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

顏色識別的原理

opencv中的顏色模型

RGB

RGB具有三個通道其,分別表示紅色通道®,綠色通道(G),藍色通道(B),3個通道在opencv中的取值均為0~255,它的顏色由3個通道的取值來共同決定,因此如果使用RGB圖像來進行顏色的識別,會丟失很多的顏色。

HSV

HSV具有三個通道,其分別表示色調(H),飽和度(S),亮度(V),3個通道在opencv中的取值分別如下:

  • H:0~180

  • S:0~255

  • V:0~255

其中H通道和S通道決定了顏色,V通道決定亮度
各種顏色對應的三個通道的取值表如下:

基于opencv如何實現視頻中的顏色識別功能

因此通過限制HSV通道中相對應的數值,就可以識別出對應的顏色

顏色識別的實現(c++)

1.讀取攝像頭的實時畫面

VideoCapture capture(1);//0為電腦本身攝像頭,1位外置攝像頭

2.讀取攝像頭的當前一幀的數據并轉換到HSV空間

capture >> frame; //讀取當前幀
cvtColor(frame, imgHSV, COLOR_BGR2HSV);

3.對HSV圖像進行直方圖均衡化
在此處使用直方圖均衡化是因為可以使用這種方法可以使原來比較少像素的灰度會被分配到別的灰度去,像素相對集中, 處理后灰度范圍變大,對比度變大,清晰度變大,所以能有效增強圖像。

split(imgHSV,temporary);
equalizeHist(temporary[2], temporary[2]);
merge(temporary, imgHSV);   //將HSV圖像分割通道,并且做直方圖的均衡化

使用equalizeHist()函數,其輸入必須是單通道的,因此使用split函數將得到的HSV圖像分割為三個通道之后,在進行直方圖均衡化,然后再使用merge函數來合并三個通道。
此處僅對V通道進行了直方圖均衡化,因為通過比對發現只對V通道進行效果最好,具體的原因還不清楚。

4.將直方圖均衡化之后,使用inRange()函數來進行圖像的識別

inRange(imgHSV, Scalar(H_W_L, S_W_L, V_W_L), Scalar(H_W_H, S_W_H, V_W_H), image);

其中H_W_L,H_W_L, S_W_L, V_W_L. . . 等數值分別為前面表格對應的顏色值的最小值和最大值。
此函數是將在范圍內的像素值為255,其與為0,反映到圖像上就是,選中的顏色為白色,其與的均為黑色。
操作到此顏色可以進行識別,但是效果可能不會很好,因此可以再使用開操作來消除噪點,去掉小的干擾快,再使用閉操作來填充閉合區域。

5.開操作

kernel = getStructuringElement(MORPH_RECT, Size(3, 3));//3*3的矩形卷積核,只要是奇數的都可以
morphologyEx(image,image,2,kernel);

6.閉操作

morphologyEx(image,image,3,kernel);

源代碼

#include <opencv2\opencv.hpp>  
using namespace cv;
using namespace std;
int main()
{
	Mat frame,imgHSV,image,kernel;
	vector<Mat>temporary;
	int H_W_L = 0, H_W_H = 180;
	int S_W_L = 0, S_W_H = 30;
	int V_W_L = 221, V_W_H = 255;
	VideoCapture capture(1);//讀取視攝像頭實時畫面數據,0默認是筆記本的攝像頭;如果是外接攝像頭,這里改為1
	while (true)
	{
		capture >> frame; //讀取當前幀
		
		if (!frame.empty())
		{          //判斷輸入的視頻幀是否為空的
			cvtColor(frame, imgHSV, COLOR_BGR2HSV);
			//threshold(gray, two_value, 125, 255, THRESH_BINARY);//二值圖像
			
			split(imgHSV,temporary);
			equalizeHist(temporary[2], temporary[2]);
			/*equalizeHist(temporary[1], temporary[1]);
			equalizeHist(temporary[0], temporary[0]);*/
			merge(temporary, imgHSV);   //將HSV圖像分割通道,并且做直方圖的均衡化
			inRange(imgHSV, Scalar(H_W_L, S_W_L, V_W_L), Scalar(H_W_H, S_W_H, V_W_H), image);
			kernel = getStructuringElement(MORPH_RECT, Size(3, 3));
			morphologyEx(image,image,2,kernel);
			morphologyEx(image,image,3,kernel);
			imshow("直方圖", imgHSV);
			imshow("原圖",frame);
			imshow("window", image);  //在window窗口顯示frame攝像頭數據畫面
		}
		if (waitKey(20) == 'q')   //延時20ms,獲取用戶是否按鍵的情況,如果按下q,會推出程序 
			break;
	}
	capture.release();     //釋放攝像頭資源
	destroyAllWindows();   //釋放全部窗口
	return 0;
}

##結果

基于opencv如何實現視頻中的顏色識別功能

“基于opencv如何實現視頻中的顏色識別功能”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

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

AI

息烽县| 贞丰县| 衡阳市| 固原市| 乌恰县| 赣州市| 铜陵市| 小金县| 团风县| 南开区| 岳阳市| 南乐县| 麻江县| 江达县| 永仁县| 仪陇县| 大同县| 黎城县| 乌拉特前旗| 汪清县| 珲春市| 稷山县| 牡丹江市| 东乡族自治县| 黔西县| 江陵县| 德庆县| 连云港市| 沁水县| 荣昌县| 蛟河市| 华坪县| 当雄县| 无极县| 永嘉县| 墨脱县| 丰顺县| 江油市| 洞口县| 贵阳市| 咸宁市|