OpenCV Mat 圖像處理基本操作

1. 圖片加載、灰度圖、 顯示和保存

cv::Mat img = cv::imread("01.jpg");
//cv::Mat img = cv::imread("01.jpg", 0);  //以灰度圖讀入
    
cv::cvtColor(img, img, cv::COLOR_BGR2GRAY);
    
cv::imshow("img_show", img);
cv::waitKey();

cv::imwrite("save.jpg", img);

2. 圖片寬、高、通道模式、平均值獲取

cv::Mat img = cv::imread("01.jpg");

int width = img.cols;
int height = img.rows;
int channel_model = img.channels();
    
cv::Scalar tempVal = cv::mean(img);
float mean_B = tempVal.val[0];
float mean_G = tempVal.val[1];
float mean_R = tempVal.val[2];

3. 創建指定大小,指定通道類型的空圖像

cv::Mat img = cv::imread("01.jpg");
    
cv::Mat img_new1(300, 500, CV_8UC3);  //高300,寬500
cv::Mat img_new2(img.size(), CV_8UC1);

4. 訪問和操作圖像像素

int point_height = 50;
int point_width = 100;
    
cv::Mat img = cv::imread("01.jpg");
    
img.at<cv::Vec3b>(point_height, point_width)[0] = 255;
int point_value_B = img.at<cv::Vec3b>(point_height, point_width)[0];

cv::Mat img_gray;
cv::cvtColor(img, img_gray, cv::COLOR_BGR2GRAY);
    
int point_value_gray = img_gray.at<uchar>(point_height, point_width);
    
img_gray.convertTo(img_gray, CV_32F);  //轉爲float類型
float point_value_gray_f = img_gray.at<float>(point_height, point_width);

5. 圖像通道分離和合並

cv::Mat img = cv::imread("01.jpg");
    
std::vector<cv::Mat> rgb_images;
cv::split(img, rgb_images);
    
cv::Mat B = rgb_images[0];
cv::Mat G = rgb_images[1] ;
cv::Mat R = rgb_images[2];

cv::Mat merged_img;
cv::merge(rgb_images, merged_img);

6. 在圖像上輸出文字

cv::Mat img = cv::imread("01.jpg");
cv::putText(img, "Text", cv::Point(50, 100), 0, 2, cv::Scalar(0, 0, 255));

7. 圖像縮放

cv::Mat img = cv::imread("01.jpg");
cv::resize(img, img, cv::Size(0.5 * img.cols , 0.5 * img.rows), 0, 0, cv::INTER_CUBIC);

8. 查找非零值像素位置

// Created by 牧野 CSDN https://blog.csdn.net/dcrmg
cv::Mat img = cv::imread("01.jpg", 0);
std::vector<cv::Point> locations;
cv::findNonZero(img, locations); //查找非0像素位置
   
for (int i = 0; i < locations.size(); i++) {
    cv::Point pt = locations[i];
    int pt_value = img.at<uchar>(pt);
    std::cout<<pt_value<<std::endl;
}

9. 圖像閾值分割、 二值化

cv::Mat img = cv::imread("01.jpg", 0);
cv::Mat img_binary;
cv::threshold(img, img_binary, 100, 255, cv::THRESH_BINARY); //指定閾值分割
    
cv::Mat img_Otsu;
cv::threshold(img, img_Otsu, 0, 255, cv::THRESH_OTSU); //大津閾值

10. 圖像裁剪、ROI

cv::Mat img = cv::imread("01.jpg");
cv::Rect rect(100, 200, 500, 300);  //left-up point x, left-up point y, width, height
cv::Mat roi = img(rect).clone();

 

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