Opencv图片明暗处理
#include <iostream> #include <opencv2/opencv.hpp> using namespace std; using namespace cv; //图片明暗处理 cv::Mat shadingTreatment(cv::Mat imgParam); int main() { double alpha; //对比度 int beta; //亮度 //Mat image = imread("F:\\OpencvProject\\CamerasAndSurveillance201910\\x64\\Debug\\face_data\\20191025143712025.jpg"); Mat image = imread("D:\\images\\特朗普\\0.jpg"); if (image.empty()) { return 0; } cv::Mat new_image = shadingTreatment(image); /// 目标图像空间预分配 /// 显示图像 imshow("原图像", image); imshow("新图像", new_image); /// 等待键盘事件 waitKey(0); return 0; } //图片明暗处理 cv::Mat shadingTreatment(cv::Mat imgParam) { Mat new_image = Mat::zeros(imgParam.size(), imgParam.type()); /// 输入初始化值 //cout << "请输入对比度1-3: "; //cin >> alpha; //cout << "请输入亮度1-100: "; //cin >> beta; double alpha = 1.2; int beta = 50; /// 执行变换 new_image(i,j) = alpha * image(i,j) + beta for (int y = 0; y < imgParam.rows; y++) { for (int x = 0; x < imgParam.cols; x++) { for (int c = 0; c < 3; c++) { new_image.at<Vec3b>(y, x)[c] = saturate_cast<uchar>(alpha * (imgParam.at<Vec3b>(y, x)[c]) + beta); } } } return new_image; }