显示一张图像的灰度直方图RGB

#include "highgui.h"
#include "cv.h"
#include "cxcore.h"

IplImage* DrawHistogram(CvHistogram* hist, float scaleX = 1, float scaleY = 1)  // 这个函数就是画直方图,
{
	float histMax = 0;
	cvGetMinMaxHistValue(hist, 0, &histMax, 0,0);

	IplImage*  imgHist = cvCreateImage(cvSize(256 * scaleX, 64 * scaleY), 8, 1);
	cvZero(imgHist);  // 清零防止在内存使用的时候存在随机数,

	for (int i = 0; i < 255; i++)
	{
		float histValue = cvQueryHistValue_1D(hist, i);  // 获取两个bin的值,
		float nextValue = cvQueryHistValue_1D(hist, i+1);

		CvPoint pt1 = cvPoint(i*scaleX, 64 * scaleY);   // 这是获取四个点,
		CvPoint pt2 = cvPoint((i+1)*scaleX, 64 * scaleY);
		CvPoint pt3 = cvPoint((i + 1)*scaleX, (64  -(nextValue / histMax)*64) * scaleY);
		CvPoint pt4 = cvPoint(i*scaleX, (64 - (histValue / histMax)*64) * scaleY);

		int numPts = 5;
		CvPoint pts[5];
		pts[0] = pt1;
		pts[1] = pt2;
		pts[2] = pt3;
		pts[3] = pt4;
		pts[4] = pt1;

		cvFillConvexPoly(imgHist, pts, numPts, cvScalar(255)); // 参数分别代表图像,点的个数,点的个数,
		
	}
	return imgHist; // 将函数返回到主函数里边去,
}

int main(int argc, char* argv[])
{
	IplImage* im;  // IplImage结构体默认的origin是0,(图像的初始位置)
	// widthStep 是表示一行的字节数,nChannels 表示通道数,彩色图像有三个通道(B,G,R),这三个通道的值,在OPenCV中的
	// 排列顺序是:B0G0R0B1G1R1B2G2R2.....BnGnRn,采用这种交排列的方式进行存储。

	im = cvLoadImage("F:\\2.jpg");
	cvNamedWindow("1");
	cvShowImage("1", im);
	//cvWaitKey(0);

	//CvArr* bins; 存放直方图在每一堆上的直方图的具体数据,由于存放多个直方图,如果是一维直方图,那么bins就是一个
	// 一个一维矩阵,如果是二维直方图,那么bins就是一个二维的矩阵等。dims:表示直方图的维度,sizes:每一维上直方柱(bin)的数据,
	// type:直方图存储数据的方式,CV_HIST_ARRAY意味着直方图数据表示为多维密集数组CvMatND,CV_HIST_TREE意味着直方图为
	// 多维稀疏数组CvSparseMat  ranges:直方图在每一维上的范围。uniform:该值是0时,表示bin的范围是程序员自由设定的,
	// 该值为非零时,表示bin的划分是均等划分。DrawHistogram:直方图的显示,
	int dims = 1;
	int size = 256;
	float range[] = { 0, 255 };
	float* ranges[] = { range };
	CvHistogram* hist;
	hist = cvCreateHist(dims, &size, CV_HIST_ARRAY, ranges, 1);
	cvClearHist(hist); // 清除里边的随机值,

	IplImage* imgRed = cvCreateImage(cvGetSize(im), 8, 1);  
	IplImage* imgGreen = cvCreateImage(cvGetSize(im), 8, 1);
	IplImage* imgBlue = cvCreateImage(cvGetSize(im), 8, 1);
	cvSplit(im, imgBlue, imgGreen, imgRed, NULL);  // 将im 图像分解成后边的四个通道。BGR顺序不能错,
	cvCalcHist(&imgBlue, hist, 0, 0); // 这个就是计算B通道的直方图,
	IplImage* histBlue = DrawHistogram(hist); // 返回的是B通道的直方图,
	cvClearHist(hist); // 清除直方图里边的数据,
	
	cvCalcHist(&imgGreen, hist, 0, 0); // 这个就是计算G通道的直方图,
	IplImage* histGreen = DrawHistogram(hist);// 返回的是G通道的直方图,
	cvClearHist(hist); // 清除直方图里边的数据,

	cvCalcHist(&imgRed, hist, 0, 0); // 这个就是计算R通道的直方图,
	IplImage* histRed = DrawHistogram(hist);// 返回的是R通道的直方图,
	cvClearHist(hist); // 清除直方图里边的数据,

	cvNamedWindow("B");
	cvNamedWindow("G");
	cvNamedWindow("R");

	cvShowImage("B", histBlue);
	cvShowImage("G", histGreen);
	cvShowImage("R", histRed);
	
	cvWaitKey(0);

	cvReleaseImage(&im);
	cvReleaseImage(&histBlue);
	cvReleaseImage(&histGreen);
	cvReleaseImage(&histRed);


	cvDestroyWindow("1");
	cvDestroyWindow("B");
	cvDestroyWindow("G");
	cvDestroyWindow("R");
	
	return 0;

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值