opencv图像对比度和亮度调整
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 | #include <istream> #include <opencv2/opencv.hpp> using namespace cv; using namespace std; int main( int argc, char **argv) { Mat src, dst; // 加载图片 src = imread( "../../picture/bg1.webp" , 1); if (!src.data) { printf ( "No image data \n" ); return -1; } namedWindow( "src" , WINDOW_AUTOSIZE); imshow( "src" , src); int rows = src.rows; int cols = src.cols; dst = Mat::zeros(src.size(), src.type()); float alpha = 1.2; float beta = 10; for ( int row = 0; row < rows; row++) { for ( int col = 0; col < cols; col++) { if (src.channels() == 3) { float a = src.at<Vec3b>(row, col)[0]; float b = src.at<Vec3b>(row, col)[1]; float c = src.at<Vec3b>(row, col)[2]; dst.at<Vec3b>(row, col)[0] = saturate_cast<uchar>(alpha * a + beta); dst.at<Vec3b>(row, col)[1] = saturate_cast<uchar>(alpha * b + beta); dst.at<Vec3b>(row, col)[2] = saturate_cast<uchar>(alpha * c + beta); } else if (src.channels() == 1) { float d = src.at<uchar>(row, col); dst.at<uchar>(row, col) = saturate_cast<uchar>(alpha * d + beta); } } } namedWindow( "dst" , WINDOW_AUTOSIZE); imshow( "dst" , dst); // 等待按键 waitKey(0); return 0; } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)