影像對比度和亮度
影像對比度和亮度
影像亮度通俗理解便是影像的明暗程度,數字影像 f(x,y) = i(x,y) r(x, y) ,如果灰度值在[0,255]之間,則 f 值越接近0亮度越低,f 值越接近255亮度越高。而且我們也要把亮度和對比度區分開來,正如上述提的對比度指的是最高和最低灰度級之間的灰度差。
飽和度指的是影像顏色種類的多少, 上面提到影像的灰度級是[Lmin,Lmax],則在Lmin、Lmax 的中間值越多,便代表影像的顏色種類多,飽和度也就更高,外觀上看起來影像會更鮮豔,調整飽和度可以修正過度曝光或者未充分曝光的圖片。使影像看上去更加自然
對於數字影像變換,設原畫素灰度為 f(i,j),轉化後的畫素灰度為 g(i,j),則常用的線性變換是 g(i,j)= af(i,j) + b, 其中係數 a 影響影像的對比度,係數 b 影響影像的亮度,具體如下:
(1) a=1時是原圖;
(2) a>1時對比度增強,影像看起來更加清晰;
(3) a<1時對比度減弱,影像看起來變暗;
(4) b影響影像的亮度,隨著增加b (b>0)和減小b (b>0),影像整體的灰度值上移或者下移, 也就是影像整體變亮或者變暗, 不會改變影像的對比度
常用程式碼:
在opencv中影像資料是存放在Mat資料型別中,我們知道一個畫素有rgb構成,所以Mat是個三維陣列,一下就是簡單的獲取mat中影像畫素。
//三個for迴圈,執行運算 new_image(i,j) =a*image(i,j) + b for(int y = 0; y < image.rows; y++ ) { for(int x = 0; x < image.cols; x++ ) { for(int c = 0; c < 3; c++ ) { new_image.at<Vec3b>(y,x)[c]= saturate_cast<uchar>( (g_nContrastValue*0.01)*(image.at<Vec3b>(y,x)[c] ) + g_nBrightValue ); } } }
//g_nContrastValue是對比度, g_nBrightValu是亮度;及對應g(i,j)= af(i,j) + b, 其中係數 a 影響影像的對比度,係數 b 影響影像的亮度;
上述程式碼中image.at<Vec3b>(y,x)[c] 其中,y是畫素所在的行, x是畫素所在的列, c是R、G、B(對應0、1、2)其中之一。
saturate_cast為了安全轉換,運算結果可能超出畫素取值範圍(溢位),還可能是非整數(如果是浮點數的話),用saturate_cast對結果進行轉換,以確保它為有效值。
程式碼如下:
//-----------------------------------【標頭檔案包含部分】--------------------------------------- // 描述:包含程式所依賴的標頭檔案 //---------------------------------------------------------------------------------------------- #include <opencv2/core/core.hpp> #include <opencv2/highgui/highgui.hpp> #include "opencv2/imgproc/imgproc.hpp" #include <iostream> //-----------------------------------【名稱空間宣告部分】--------------------------------------- // 描述:包含程式所使用的名稱空間 //----------------------------------------------------------------------------------------------- using namespace std; using namespace cv; //-----------------------------------【全域性函式宣告部分】-------------------------------------- // 描述:全域性函式宣告 //----------------------------------------------------------------------------------------------- static void ContrastAndBright(int, void *); //-----------------------------------【全域性變數宣告部分】-------------------------------------- // 描述:全域性變數宣告 //----------------------------------------------------------------------------------------------- int g_nContrastValue; //對比度值 int g_nBrightValue; //亮度值 Mat g_srcImage, g_dstImage; //-----------------------------------【main( )函式】-------------------------------------------- // 描述:控制檯應用程式的入口函式,我們的程式從這裡開始 //----------------------------------------------------------------------------------------------- int main() { //改變控制檯前景色和背景色 system("color 2F"); // 讀入使用者提供的影像 g_srcImage = imread("E:\\VS2015Opencv\\vs2015\\project\\picture\\cat.jpg"); if (!g_srcImage.data) { printf("讀取g_srcImage圖片錯誤~! \n"); return false; } g_dstImage = Mat::zeros(g_srcImage.size(), g_srcImage.type()); //設定對比度和亮度的初值 g_nContrastValue = 80; g_nBrightValue = 80; //建立視窗 namedWindow("【效果圖視窗】", 1); //建立軌跡條 createTrackbar("對比度:", "【效果圖視窗】", &g_nContrastValue, 300, ContrastAndBright); createTrackbar("亮 度:", "【效果圖視窗】", &g_nBrightValue, 200, ContrastAndBright); //呼叫回撥函式 ContrastAndBright(g_nContrastValue, 0); ContrastAndBright(g_nBrightValue, 0); //輸出一些幫助資訊 cout << endl << "\t執行成功,請調整滾動條觀察影像效果\n\n" << "\t按下“q”鍵時,程式退出\n"; //按下“q”鍵時,程式退出 while (char(waitKey(1)) != 'q') {} return 0; } //-----------------------------【ContrastAndBright( )函式】------------------------------------ // 描述:改變影像對比度和亮度值的回撥函式 //----------------------------------------------------------------------------------------------- static void ContrastAndBright(int, void *) { // 建立視窗 namedWindow("【原始圖視窗】", 1); // 三個for迴圈,執行運算 g_dstImage(i,j) = a*g_srcImage(i,j) + b for (int y = 0; y < g_srcImage.rows; y++) { for (int x = 0; x < g_srcImage.cols; x++) { for (int c = 0; c < 3; c++) { g_dstImage.at<Vec3b>(y, x)[c] = saturate_cast<uchar>((g_nContrastValue*0.01)*(g_srcImage.at<Vec3b>(y, x)[c]) + g_nBrightValue); } } } // 顯示影像 imshow("【原始圖視窗】", g_srcImage); imshow("【效果圖視窗】", g_dstImage); }
效果圖:
相關文章
- 04-OpenCvSharp4調整影像亮度和對比度OpenCV
- PyTorch - transforms.ColorJitter 改變影像的屬性:亮度(brightness)、對比度(contrast)、飽和度(saturation)和色調(hue)PyTorchORMAST
- matlab影像對比度增強,拉伸和灰度變換Matlab
- 影像增強之對比度拉伸
- 有1000000:1高對比度及600nits峰值亮度
- matlab影像點運算 對比度增強 對比度拉伸 灰度變換Matlab
- matlab實現 線性拉伸某灰度影像的對比度 程式碼 對比度拉伸Matlab
- MATLAB影像處理imadjust()函式調節影像的對比度示例Matlab函式
- 影像相似度比較和檢測影像中的特定物
- 數字影像處理實驗之對比度拉伸
- 圖片相似度對比SSIM和PHash
- 用 matlab 對圖片進行對比度和均衡度調整Matlab
- 華碩好屏在色彩、亮度、對比度等引數上本就遠超傳統筆記本筆記
- Adobe國際認證指南|一張照片修圖前後,亮度對比度究竟有多重要?
- Python影像讀寫方法對比Python
- 【影像增強】CLAHE 限制對比度自適應直方圖均衡化直方圖
- 影像增強 | CLAHE 限制對比度自適應直方圖均衡化直方圖
- Matlab——對比度拉伸Matlab
- win10怎麼調對比度_windows10如何調整對比度Win10Windows
- win10對比度在哪調 win10調節螢幕對比度Win10
- 新的顏色對比度演算法-感知對比度演算法APCA演算法PCA
- 【影像處理知識複習】03對比度線性拉伸matlab,C++實現MatlabC++
- intrans函式(對比度拉伸)函式
- 檔案和影像比較工具Kaleidoscope
- 百度人臉對比
- Kaleidoscope for Mac(檔案和影像比較工具)Mac
- Mac檔案和影像比較工具:KaleidoscopeMac
- 檔案和影像比較工具:Kaleidoscope MacMac
- 對比Javascript和TypeScriptJavaScriptTypeScript
- 對比XcodeDebugMemoryGraph和FBMemoryProfilerXCode
- vite和webpack對比ViteWeb
- WinRunner和QTP對比QT
- TCP和UDP對比TCPUDP
- python語言之影像處理:亮度調整演算法Python演算法
- Mac檔案和影像比較工具——Kaleidoscope for MacMac
- win10怎麼調電腦對比度_win10電腦對比度怎麼設定Win10
- 小米10ultra ISO12233 超廣角IMX350 不同亮度下比較 解析度
- RabbitMQ和Erlang相容對比MQ