织梦CMS - 轻松建站从此开始!

罗索

单通道图像的直方图(C/C++源代码)

jackyhwei 发布于 2010-04-19 11:17 点击:次 
计算并绘制单通道图像的直方图。在MATLAB中绘制直方图是一件非常简单的事情,可是到了C环境下,竟然变成了一个问题。各种实现方法都有,而且要自己动手重新编程。幸好有了OPENCV。下面的代码要求OPENCV4.0的支持,并在VC6中编译通过。
TAG:

计算并绘制单通道图像的直方图。在MATLAB中绘制直方图是一件非常简单的事情,可是到了C环境下,竟然变成了一个问题。各种实现方法都有,而且要自己动手重新编程。幸好有了OPENCV。下面的代码要求OPENCV4.0的支持,并在VC6中编译通过。

 

  1. // 
  2. // 对单通道图像做直方图 
  3. // 
  4.  
  5. #include "cv.h" 
  6. #include "highgui.h" 
  7. #include <stdio.h> 
  8. #include <ctype.h> 
  9.  
  10. int main( int argc, char** argv ) 
  11.     IplImage *src = 0; 
  12.     IplImage *histimg = 0; 
  13.     CvHistogram *hist = 0; 
  14.     
  15.     int hdims = 50;     // 划分HIST的个数,越高越精确 
  16.     float hranges_arr[] = {0,255}; 
  17.     float* hranges = hranges_arr; 
  18.     int bin_w;  
  19.     float max_val; 
  20.     int i; 
  21.     
  22.     if( argc != 2 || (src=cvLoadImage(argv[1], 0)) == NULL)  // force to gray image 
  23.         return -1; 
  24.     
  25.     cvNamedWindow( "Histogram", 1 ); 
  26.     hist = cvCreateHist( 1, &hdims, CV_HIST_ARRAY, &hranges, 1 );  // 计算直方图 
  27.     histimg = cvCreateImage( cvSize(320,200), 8, 3 ); 
  28.  
  29.     cvZero( histimg ); 
  30.     
  31.     cvCalcHist( &src, hist, 0, 0 ); // 计算直方图 
  32.     cvGetMinMaxHistValue( hist, 0, &max_val, 0, 0 );  // 只找最大值 
  33.     cvConvertScale( hist->bins, hist->bins, max_val ? 255. / max_val : 0., 0 ); // 缩放 bin 到区间 [0,255] 
  34.     
  35.     cvZero( histimg ); 
  36.     bin_w = histimg->width / hdims;  // hdims: 条的个数,则 bin_w 为条的宽度 
  37.     
  38.     // 画直方图 
  39.     for( i = 0; i < hdims; i++ ) 
  40.     { 
  41.         double val = ( cvGetReal1D(hist->bins,i)*histimg->height/255 ); 
  42.         CvScalar color = CV_RGB(255,255,0); //(hsv2rgb(i*180.f/hdims); 
  43.         cvRectangle( histimg, cvPoint(i*bin_w,histimg->height), 
  44.             cvPoint((i+1)*bin_w,(int)(histimg->height - val)), 
  45.             color, 1, 8, 0 ); 
  46.     } 
  47.     
  48.     cvShowImage( "Histogram", histimg ); 
  49.     cvWaitKey(0); 
  50.  
  51.     cvDestroyWindow("Histogram"); 
  52.     cvReleaseImage( &src ); 
  53.     cvReleaseImage( &histimg ); 
  54.     cvReleaseHist ( &hist ); 
  55.     
  56.     return 0; 
(hunnish)
本站文章除注明转载外,均为本站原创或编译欢迎任何形式的转载,但请务必注明出处,尊重他人劳动,同学习共成长。转载请注明:文章转载自:罗索实验室 [http://www.rosoo.net/a/201004/9174.html]
本文出处:CSDN博客 作者:hunnish
顶一下
(2)
66.7%
踩一下
(1)
33.3%
------分隔线----------------------------
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 验证码:点击我更换图片
栏目列表
将本文分享到微信
织梦二维码生成器
推荐内容