Skip to main content

OpenCV : Make sharpen image color

We sometimes take pictures where there is no light, so the pictures come out dark. This means it did not have a wide range of colors. For example, an image with a minimum value of 20 and a maximum value of 100 will be dark. So we need to wide the color range of the image 0 to 255.






The full code is as follows.

#include <iostream>
#include <opencv2/opencv.hpp>
using namespace cv;
using namespace std;

void meanVal(Mat* inputArray){
    double minVal, maxVal;
    minMaxIdx(*inputArray, &minVal, &maxVal); //get min, max value of matrix    
    double ratio = (maxVal - minVal)/255; 
    *inputArray = (*inputArray - minVal)/ratio; // wide image range    
    cout << minVal << "," << maxVal << endl;
}

int main() {
    Mat img = imread("./res/woman.png");
    imshow("origin", img);
    vector<Mat> bgr_img;
    split(img, bgr_img); // split matrix to 3 channels (Blue, Green, Red)    
    meanVal(&bgr_img[0]);
    meanVal(&bgr_img[1]);
    meanVal(&bgr_img[2]);

    merge(bgr_img, img); // merge three channels to on matrix
    img = img + Scalar(10, 20, 20); // add warm color to img    
    imshow("result", img);
    waitKey(0);
    return 0;
}


  • Split matrix by channel

void split(InputArray mat, OutputArrayOfArrays mv)

  • Merge channels to one matrix

void merge(InoutArraysOfArrays mv, OutputArray mat)

  • Get min, max value of matrix

void minMaxIdx(InputArray src, double* minVal, double* maxVal = 0, int* minIdx = 0, int* maxIdx = 0, InputArray mask = noArray());

Comments

Popular posts from this blog

OpenGL SL - Show Video and Image

The simple image is made like this. void  mainImage(  out   vec4  fragColor,  in   vec2  fragCoord ){      // Normalized pixel coordinates (from 0 to 1)      vec2  uv = fragCoord/iResolution.xy;           //uv.x = uv.x - 0.3;      fragColor =  texture (iChannel0, uv); } I think GPU processing has two major steps. Normalizing and Pointing. 1. Normalizing Each pixel has screen coordinate and we need to normalizing from 0.0 to 1.0, because there are many displays with various resolutions around us. We can not manage it at each resolution. It is very troublesome. So we should normalize it :   vec2   uv = fragCoord/iResolution.xy; 2. Pointing I told you each pixel has a screen coordinate. At each coordinate we need to link with sampler's coordinate. Sampler has also coordinate 0.0 to 1.0. As a result, we see the samplers p...

OpenGL SL - Translate, roate, and scale

Translate, rotate and scale are most basic element of image effect. If you didn't understand how make effect at each pixel, please read again before post "Show Video and Image" . 1. Translate Translation means each pixel move parallel on the x, y-axis. In other words, if you want to translate 0.25 on the x-axis, a pixel should point to a distance of -0.25 from the original. Translate ex) void mainImage( out vec4 fragColor, in vec2 fragCoord ){     vec2 uv = fragCoord/iResolution.xy;     if (uv.x < 0.5 ){         // translate to x ( -0.25 )         uv.x += 0.25 ;     } else {         // translate to x ( +0.25 )         uv.x -= 0.25 ;     }     fragColor = texture (iChannel0, uv); } result) 2. Scale Scale also has a  similar concept to parallel translation. If you want to zoom in twice, each pixel s...

How to make gaussian blur in SparkAR

 Gaussian blur is result of blurring an image by Gaussian function. We need to use large kernel to make strong blur and this cause the high complexity. And that's why we should use multi-pass which is seperated into horizontal, vertical pass . It can reduce the complexity and make faster. In Spark AR there are many ways to make it. And I wanna introduce one of them using shader files (.sca). You can download it for free from the gumload link below. It is modulated to adjust horizontal, vertical strength easily . Hope this can help you. Loading...