OpenCV绘制三通道彩色直方图

1、概述

  案例:输入一张图片计算此图片的直方图并绘制出来。

  图像直方图概念:直方图概念是基于图像像素值,其实对图像梯度、每个像素的角度、等一切图像的属性值,我们都可以建立直方图。这个才是直方图的概念真正意义,不过是基于图像像素灰度直方图是最常见的

本文福利,费领取Qt开发学习资料包、技术视频,内容包括(C++语言基础,Qt编程入门,QT信号与槽机制,QT界面开发-图像绘制,QT网络,QT数据库编程,QT项目实战,QSS,OpenCV,Quick模块,面试题等等)↓↓↓↓↓↓见下面↓↓文章底部点击费领取↓↓

  函数介绍:

calcHist(
 const Mat* images,//输入图像指针
int images,// 输入图像的个数
const int* channels,// 需要统计直方图的第几通道
InputArray mask,// 输入mask,可选,不用,填写Mat()
OutputArray hist,//输出的直方图数据 Mat
int dims,// 维数,灰度图是1,彩色图一般是3
const int* histsize,// 直方图级数,0~255,填256。指的是直方图分成多少个区间,就是 bin的个数
const float* ranges,// 值域范围,{0~256} 统计像素值得区间
bool uniform,// 是否对得到的直方图数组进行归一化处理,默认为 true一般不改。
bool accumulate// 在多个图像时,是否累计计算像素值的个数,默认为false 一般不改
)

2、代码示例  

Mat src = imread(filePath);
    if(src.empty()){
        return;
    }
    imshow("src",src);

    Mat dst;
    //通道分离
    vector<Mat> mats;
    split(src,mats);

    int histsize = 256;//直方图级数,例如:0~255中间有256级
    float range[] = {0,256};//值域范围,也就是直方图值的范围
    const float *histRange = {range};
    Mat r_hist,g_hist,b_hist;
    calcHist(&mats[0],1,0,Mat(),r_hist,1,&histsize,&histRange,true,false);
    calcHist(&mats[1],1,0,Mat(),g_hist,1,&histsize,&histRange,true,false);
    calcHist(&mats[2],1,0,Mat(),b_hist,1,&histsize,&histRange,true,false);

    //创建直方图画布
    int hist_w = 512;
    int hist_h = 400;
    Mat histImage(hist_w,hist_h,CV_8UC3,Scalar(0,0,0));

    //将直方图数据归一化到指定范围
    normalize(r_hist,r_hist,0,hist_h,NORM_MINMAX,-1,Mat());
    normalize(g_hist,g_hist,0,hist_h,NORM_MINMAX,-1,Mat());
    normalize(b_hist,b_hist,0,hist_h,NORM_MINMAX,-1,Mat());
    int bin_w = hist_w/histsize;//直方图数据宽

    //在histImage中绘制出直方图
    for(int i=1;i<histsize;i++){
        line(histImage,
             Point(bin_w*(i-1),hist_h-cvRound(b_hist.at<float>(i-1))),
             Point(bin_w*(i),hist_w-cvRound(b_hist.at<float>(i))),Scalar(255,0,0),2,LINE_AA);
        line(histImage,
             Point(bin_w*(i-1),hist_h-cvRound(r_hist.at<float>(i-1))),
             Point(bin_w*(i),hist_w-cvRound(r_hist.at<float>(i))),Scalar(0,0,255),2,LINE_AA);
        line(histImage,
             Point(bin_w*(i-1),hist_h-cvRound(g_hist.at<float>(i-1))),
             Point(bin_w*(i),hist_w-cvRound(g_hist.at<float>(i))),Scalar(0,255,0),2,LINE_AA);
    }
    imshow("histImage",histImage);

3、示例图片

 

 

 本文福利,费领取Qt开发学习资料包、技术视频,内容包括(C++语言基础,Qt编程入门,QT信号与槽机制,QT界面开发-图像绘制,QT网络,QT数据库编程,QT项目实战,QSS,OpenCV,Quick模块,面试题等等)↓↓↓↓↓↓见下面↓↓文章底部点击费领取↓↓

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值