前言
这篇文章主要讲述如何通过读取图像三个通道上的值取平均来获得灰度图。
一、代码
#include <opencv2/opencv.hpp>
#include <iostream>
using namespace cv;
int main()
{
cv::Mat srcMat = imread("C://Users//john//Desktop//1.jpg");
int height = srcMat.rows;
int width = srcMat.cols;
for (int j = 0; j < height; j++)
{
for (int i = 0; i < width; i++)
{
uchar average = (srcMat.at<Vec3b>(j, i)[0] + srcMat.at<Vec3b>(j, i)[1] + srcMat.at<Vec3b>(j, i)[2]) / 3;
srcMat.at<Vec3b>(j, i)[0] = average;
srcMat.at<Vec3b>(j, i)[1] = average;
srcMat.at<Vec3b>(j, i)[2] = average;
}
}
imshow("src", srcMat);
waitKey(0);
}
总结
上述代码运行成功,就实现了三通道图像与灰度图的转化。