您的位置:首页 > 其它

saturate_cast 图像对比度与亮度

2017-10-30 15:28 169 查看
#include<iostream>

#include<opencv2\opencv.hpp>

using namespace std;

using namespace cv;

int main(int argc,char** argv){
Mat src,dst;
src = imread("1.jpg");
if (src.empty())
{
cout << "could not load image.." << endl;
return -1;
}
char input_win[] = "input image";
namedWindow(input_win, CV_WINDOW_AUTOSIZE);
imshow(input_win, src);
int height = src.rows;
int weight = src.cols;
float alpha = 1.2;
float beta = 60;
dst = Mat::zeros(src.size(), src.type());
for (int i = 0; i < height; i++) {
for (int j = 0; j < weight; j++) {
if (src.channels() == 3) {
float b = src.at<Vec3b>(i,j)[0];
float g = src.at<Vec3b>(i,j)[1];
float r = src.at<Vec3b>(i,j)[2]; 

              //对dst进行赋值操作
dst.at<Vec3b>(i, j)[0] = saturate_cast<uchar>(b*alpha+beta);
dst.at<Vec3b>(i, j)[1] = saturate_cast<uchar>(g*alpha + beta);
dst.at<Vec3b>(i, j)[2] = saturate_cast<uchar>(r*alpha + beta);

}
else if (src.channels() == 1)
{
float v = src.at<uchar>(i, j);
dst.at<uchar>(i,j)= saturate_cast<uchar>(v*alpha + beta);
}
}
}
char output_title[] = "调整图像亮度和对比度";
cvNamedWindow(output_title, CV_WINDOW_AUTOSIZE);
imshow(output_title, dst);
waitKey(0);
return 0;

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: