zoukankan      html  css  js  c++  java
  • 图像修改亮度和对比度

    #include <opencv2/opencv.hpp>
    #include <iostream>
    #include <math.h>
    using namespace cv;
    using namespace std;
    
    int main()
    {
        Mat src1,dst,dst2;
        //原图
        src1 = imread(".//pic//kate.png",IMREAD_UNCHANGED);
        
        if (!src1.data)
        {
            cout << "load error" << endl;
            return -1;
        }
    
        char input_win[] = "imput image";
        namedWindow(input_win , CV_WINDOW_AUTOSIZE);
        imshow(input_win, src1);
    
        int height = src1.rows;
        int width = src1.cols;
        dst = Mat::zeros(src1.size(), src1.type());
        dst2 = Mat::zeros(src1.size(), src1.type());
    
        float alpha = 1.5;//对比度
        float beta = 10;//亮度
    
        Mat m1;
        src1.convertTo(m1, CV_32F);
        dst2.convertTo(dst2, CV_32F);
        for (int row = 0; row < height; row++)
        {
            for (int col = 0; col < width; col++)
            {
                if (src1.channels() == 3)
                {
                    
    
                    float b = src1.at<Vec3b>(row, col)[0];
                    float g = src1.at<Vec3b>(row, col)[1];
                    float r = src1.at<Vec3b>(row, col)[2];
    
                    float b2 = m1.at<Vec3f>(row, col)[0];
                    float g2 = m1.at<Vec3f>(row, col)[1];
                    float r2 = m1.at<Vec3f>(row, col)[2];
    
                    dst.at<Vec3b>(row, col)[0] = saturate_cast<uchar>(b * alpha + beta);
                    dst.at<Vec3b>(row, col)[1] = saturate_cast<uchar>(g * alpha + beta);
                    dst.at<Vec3b>(row, col)[2] = saturate_cast<uchar>(r * alpha + beta);
    
                    dst2.at<Vec3f>(row, col)[0] = saturate_cast<uchar>(b2 * alpha + beta);
                    dst2.at<Vec3f>(row, col)[1] = saturate_cast<uchar>(g2 * alpha + beta);
                    dst2.at<Vec3f>(row, col)[2] = saturate_cast<uchar>(r2 * alpha + beta);
                }
                else if (src1.channels() == 1)
                {
                    float v = src1.at<uchar>(row, col);
                    dst.at<uchar>(row, col) = saturate_cast<uchar>(v * alpha + beta);
                }
            }
        }
        imshow("提高对比度", dst);
        imshow("提高对比度(float)", dst);
        
        waitKey(0);
        return 0;
    }
  • 相关阅读:
    [转]解密回声消除技术之二(应用篇)
    [转]解密回声消除技术之一(理论篇)
    Linux命令练级初级
    [转]win7+ubuntu 13.04双系统安装方法
    c/c++常用代码--清空目录
    c++程序开发利器
    vc2005 编译ACE-6.2.0
    Facebook Login api
    IIS7.0 下使用Intelligencia.UrlRewriter时Session为空问题
    无后缀名伪静态路径在IIS7.0的网站提示 "404
  • 原文地址:https://www.cnblogs.com/xiaochi/p/11995086.html
Copyright © 2011-2022 走看看