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 }