RGB颜色图像直方图使用OpenCV C 进行对比度拉伸



i编写一个程序,使用像素数据值为灰色图像制作直方图。我使用波纹管段来增加访问像素值的图像的对比度。如何将这些逻辑应用于彩色图像以增加图像的对比度。gr是灰色图像(从彩色图像转换),而gr_im是新图像。

int x = 0;
    for (int  i = 0; i < h; i++)
    {
        for (int j = 0; j < w; j++) 
        {
            x = gr.at<uchar>(i,j);
            if (x < r1) 
            {
                gr_im.at<uchar>(i, j) = cvRound((s1/double(r1))*double(x));
            }
            else if(x <= r2){
                gr_im.at<uchar>(i, j) = cvRound((s2-s1 / double(r2-r1))*(x-r1) + s1);
            }
            else if (x > r2) {
                gr_im.at<uchar>(i, j) = cvRound((255-s2 / double(r1))*(x - r2) + s2);
            }
        }
    }

您可以使用以下代码之类的内容:

cv::Mat hsv;
cv::cvtColor(image, hsv, CV_BGR2HSV);
std::vector<cv::Mat> channels;
cv::split(hsv, channels)
// now call your function to specific channel
cv::merge(channels, hsv);
cv::cvtColor(hsv, image, CV_HSV2BGR);

最新更新