mirror of https://github.com/opencv/opencv.git
Open Source Computer Vision Library
https://opencv.org/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
67 lines
1.5 KiB
67 lines
1.5 KiB
/** |
|
* @file LinearTransforms.cpp |
|
* @brief Simple program to change contrast and brightness |
|
* @date Mon, June 6, 2011 |
|
* @author OpenCV team |
|
*/ |
|
|
|
#include "opencv2/imgcodecs.hpp" |
|
#include "opencv2/highgui.hpp" |
|
|
|
using namespace cv; |
|
|
|
/** Global Variables */ |
|
const int alpha_max = 5; |
|
const int beta_max = 125; |
|
int alpha; /**< Simple contrast control */ |
|
int beta; /**< Simple brightness control*/ |
|
|
|
/** Matrices to store images */ |
|
Mat image; |
|
|
|
/** |
|
* @function on_trackbar |
|
* @brief Called whenever any of alpha or beta changes |
|
*/ |
|
static void on_trackbar( int, void* ) |
|
{ |
|
Mat new_image = Mat::zeros( image.size(), image.type() ); |
|
|
|
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>( alpha*( image.at<Vec3b>(y,x)[c] ) + beta ); |
|
|
|
imshow("New Image", new_image); |
|
} |
|
|
|
|
|
/** |
|
* @function main |
|
* @brief Main function |
|
*/ |
|
int main( int, char** argv ) |
|
{ |
|
/// Read image given by user |
|
image = imread( argv[1] ); |
|
|
|
/// Initialize values |
|
alpha = 1; |
|
beta = 0; |
|
|
|
/// Create Windows |
|
namedWindow("Original Image", 1); |
|
namedWindow("New Image", 1); |
|
|
|
/// Create Trackbars |
|
createTrackbar( "Contrast Trackbar", "New Image", &alpha, alpha_max, on_trackbar ); |
|
createTrackbar( "Brightness Trackbar", "New Image", &beta, beta_max, on_trackbar ); |
|
|
|
/// Show some stuff |
|
imshow("Original Image", image); |
|
imshow("New Image", image); |
|
|
|
/// Wait until user press some key |
|
waitKey(); |
|
return 0; |
|
}
|
|
|