1 #include <opencv2/core/core.hpp> 2 #include <opencv2/highgui/highgui.hpp> 3 #include <iostream> 4 5 using namespace std; 6 using namespace cv; 7 8 double alpha; /**< 控制对比度 */ 9 int beta; /**< 控制亮度 */ 10 11 int main( int argc, char** argv ) 12 { 13 /// 读入用户提供的图像 14 Mat image = imread( argv[1] ); 15 Mat new_image = Mat::zeros( image.size(), image.type() ); 16 17 /// 初始化 18 cout << " Basic Linear Transforms " << endl; 19 cout << "-------------------------" << endl; 20 cout << "* Enter the alpha value [1.0-3.0]: "; 21 cin >> alpha; 22 cout << "* Enter the beta value [0-100]: "; 23 cin >> beta; 24 25 /// 执行运算 new_image(i,j) = alpha*image(i,j) + beta 26 for( int y = 0; y < image.rows; y++ ) 27 { 28 for( int x = 0; x < image.cols; x++ ) 29 { 30 for( int c = 0; c < 3; c++ ) 31 { 32 new_image.at<Vec3b>(y,x)[c] = saturate_cast<uchar>( alpha*( image.at<Vec3b>(y,x)[c] ) + beta ); 33 } 34 } 35 } 36 37 /// 创建窗口 38 namedWindow("Original Image", 1); 39 namedWindow("New Image", 1); 40 41 /// 显示图像 42 imshow("Original Image", image); 43 imshow("New Image", new_image); 44 45 /// 等待用户按键 46 waitKey(); 47 return 0; 48 }
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 全网最简单!3分钟用满血DeepSeek R1开发一款AI智能客服,零代码轻松接入微信、公众号、小程
· .NET 10 首个预览版发布,跨平台开发与性能全面提升
· 《HelloGitHub》第 107 期
· 全程使用 AI 从 0 到 1 写了个小工具
· 从文本到图像:SSE 如何助力 AI 内容实时呈现?(Typescript篇)