opencv中對圖片的二值化操做並提取特定顏色區域

1、最近由於所在的實習公司要求用opencv視覺庫來寫一個對圖片識別並提取指定區域的程序。看了不少資料,只學會了皮毛,下面附上簡單的代碼。運行程序以前須要安裝opencv庫,官網地址爲:https://opencv.org/。直接下載安裝包到本地,解壓便可。本人的opencv版本爲24.10 。集成環境是visual studio 2013。ios

 1 #include<opencv2/core/core.hpp>  
 2 #include<opencv2/highgui/highgui.hpp>  
 3 #include<opencv2/imgproc/imgproc.hpp>  
 4 #include <vector>
 5 #include<iostream>  
 6 #include<string>
 7 
 8 using namespace std;
 9 using namespace cv;
10 //bgr圖像  
11 Mat bgr;
12 //HSV圖像  
13 Mat hsv;
14 //色相  
15 int hmin = 0;//h份量取下限
16 int hmax = 180;//h份量取上限
17 int h_Max = 180; //h份量可取的最大值
18 //飽和度  
19 int smin = 0;//s份量取下限
20 int smax = 255;//s份量取上限
21 int s_Max = 255;//s份量可取的最大值
22 //亮度  
23 int vmin = 0;//v份量取下限
24 int vmax = 255;//v份量取上限
25 int v_Max = 255;//v份量可取的最大值
26 
27 string windowName = "src";
28 
29 string dstName = "dst";
30 //輸出圖像  
31 Mat dst;
32 //回調函數  
33 void callBack(int, void*)
34 {
35     //輸出圖像分配內存  
36     dst = Mat::zeros(bgr.size(), bgr.type());
37      
38     Mat mask;
39     inRange(hsv, Scalar(hmin, smin, vmin), Scalar(hmax, smax, vmax), mask);
40      
41     for (int r = 0; r < bgr.rows; r++)
42     {
43         for (int c = 0; c < bgr.cols; c++)
44         {
45             if (mask.at<uchar>(r, c) == 255)
46             {
47                 dst.at<Vec3b>(r, c)[0] = bgr.at<Vec3b>(r, c)[0];
48                 dst.at<Vec3b>(r, c)[1] = bgr.at<Vec3b>(r, c)[1];
49                 dst.at<Vec3b>(r, c)[2] = bgr.at<Vec3b>(r, c)[2];
50             }
51         }
52     }
53     imshow("mask", mask);
54     //輸出圖片
55     imshow("dst", dst);
56 }
57 int main()
58 {
59     //輸入圖片 
60     Mat srcImage = imread("C:\\Users\\Administrator\\Desktop\\0001.jpg");
61     if (!srcImage.data){
62         cout << "圖片讀取失敗" << endl;
63         system("pause");
64         return -1;
65     }
66     imshow(windowName, srcImage);
67     bgr = srcImage;
68     //顏色空間轉換  
69     cvtColor(bgr, hsv, COLOR_BGR2HSV);
70     //定義輸出圖像的顯示窗口  
71     namedWindow(dstName, 0);
72     //調節色相 H  
73     createTrackbar("hmin", dstName, &hmin, h_Max, callBack);
74     createTrackbar("hmax", dstName, &hmax, h_Max, callBack);
75     //調節飽和度 S  
76     createTrackbar("smin", dstName, &smin, s_Max, callBack);
77     createTrackbar("smax", dstName, &smax, s_Max, callBack);
78     //調節亮度 V  
79     createTrackbar("vmin", dstName, &vmin, v_Max, callBack);
80     createTrackbar("vmax", dstName, &vmax, v_Max, callBack);
81     callBack(0, 0);
82     waitKey(0);
83     return 0;
84 }
相關文章
相關標籤/搜索