使用openCV画出一幅图像的直方图
2012-10-26 16:23
316 查看
// 对单通道图像做直方图 // #include "cv.h" #include "highgui.h" #include <stdio.h> #include <ctype.h> int main( int argc, char** argv ) { IplImage *src = 0; IplImage *histimg = 0; CvHistogram *hist = 0; int hdims = 50; // 划分HIST的个数,越高越精确 float hranges_arr[] = {0,255}; float* hranges = hranges_arr; int bin_w; float max_val; int i; if( argc != 2 || (src=cvLoadImage(argv[1], 0)) == NULL) // force to gray image return -1; cvNamedWindow( "Histogram", 1 ); hist = cvCreateHist( 1, &hdims, CV_HIST_ARRAY, &hranges, 1 ); // 计算直方图 histimg = cvCreateImage( cvSize(320,200), 8, 3 ); cvZero( histimg ); cvCalcHist( &src, hist, 0, 0 ); // 计算直方图 cvGetMinMaxHistValue( hist, 0, &max_val, 0, 0 ); // 只找最大值 cvConvertScale( hist->bins, hist->bins, max_val ? 255. / max_val : 0., 0 ); // 缩放 bin 到区间 [0,255] cvZero( histimg ); bin_w = histimg->width / hdims; // hdims: 条的个数,则 bin_w 为条的宽度 // 画直方图 for( i = 0; i < hdims; i++ ) { double val = ( cvGetReal1D(hist->bins,i)*histimg->height/255 ); CvScalar color = CV_RGB(255,255,0); //(hsv2rgb(i*180.f/hdims); cvRectangle( histimg, cvPoint(i*bin_w,histimg->height), cvPoint((i+1)*bin_w,(int)(histimg->height - val)), color, 1, 8, 0 ); } cvShowImage( "Histogram", histimg ); cvWaitKey(0); cvDestroyWindow("Histogram"); cvReleaseImage( &src ); cvReleaseImage( &histimg ); cvReleaseHist ( &hist ); return 0; }
相关文章推荐
- 使用openCV画出一幅图像的直方图
- 一.使用OpenCv加载一幅图像
- Python语言opencv使用笔记(九)(图像直方图)
- OpenCV 使用方向梯度直方图估计图像旋转角度
- OpenCV学习之六: 使用方向梯度直方图估计图像旋转角度
- 题目:Visual Studio 2015在opencv 3.1.0下,使用OpenCV函数 HoughCircles 在一幅图像中检测圆
- OpenCV 2 学习笔记(21): 使用直方图比较检索相似图像
- Python下opencv使用笔记(九)(图像直方图)
- OpenCV学习之六: 使用方向梯度直方图估计图像旋转角度
- 二.使用OpenCv操纵摄像头采集一幅图像
- OpenCV中,在图像上覆盖绘制另一幅图圆形图像
- Python下opencv使用笔记(六)(图像的形态学转换)
- Python下opencv使用笔记(七)(图像梯度与边缘检测)
- Android Studio使用Opencv实现图像的实时处理
- 【OpenCV】图像变换(六)对数极坐标变换LogPolar&直方图均衡EqualizeHist
- 学习opencv,使用反向块投影搜索图像中物体的位置cvCalcBackProjectPatch
- OpenCV深入学习(5)--直方图之calcHist使用
- 图像灰度直方图绘制——使用QT实现一个图像处理软件2
- opencv2反投影直方图以检測特定的图像内容
- [OPENCV learning] 获取图像的灰度和一维RGB彩色直方图