opencv绘制灰度直方图

代码之一

[cpp]  view plain copy
  1. #include <cv.h>  
  2. #include <highgui.h>  
  3. #pragma comment( lib, "cv.lib" )  
  4. #pragma comment( lib, "cxcore.lib" )  
  5. #pragma comment( lib, "highgui.lib" )  
  6. int main()  
  7. {  
  8.          IplImage* src=cvLoadImage("lena.jpg",0);  
  9.          int width=src->width;  
  10.          int height=src->height;  
  11.          int step=src->widthStep;  
  12.          uchar* data=(uchar *)src->imageData;  
  13.          int hist[256]={0};  
  14.          for(int i=0;i<height;i++)  
  15.          {  
  16.                    for(int j=0;j<width;j++)  
  17.                    {  
  18.                             hist[data[i*step+j]]++;  
  19.                    }  
  20.          }  
  21.          int max=0;  
  22.          for(i=0;i<256;i++)  
  23.          {  
  24.                    if(hist[i]>max)  
  25.                    {  
  26.                             max=hist[i];  
  27.                    }  
  28.          }  
  29.          IplImage* dst=cvCreateImage(cvSize(400,300),8,3);  
  30.          cvSet(dst,cvScalarAll(255),0);  
  31.          double bin_width=(double)dst->width/256;  
  32.          double bin_unith=(double)dst->height/max;  
  33.          for(i=0;i<256;i++)  
  34.          {  
  35.                    CvPoint p0=cvPoint(i*bin_width,dst->height);  
  36.                    CvPoint p1=cvPoint((i+1)*bin_width,dst->height-hist[i]*bin_unith);  
  37.                    cvRectangle(dst,p0,p1,cvScalar(0,255),-1,8,0);  
  38.          }  
  39.          cvNamedWindow("src",1);  
  40.          cvShowImage("src",src);  
  41.          cvNamedWindow("dst",1);  
  42.          cvShowImage("dst",dst);  
  43.          cvWaitKey(0);  
  44.          cvDestroyAllWindows();  
  45.          cvReleaseImage(&src);  
  46.          cvReleaseImage(&dst);  
  47.          return 0;  
  48. }  


[cpp]  view plain copy
  1. 代码之二  
[cpp]  view plain copy
  1. #include <cv.h>  
  2. #include <highgui.h>  
  3. #pragma comment( lib, "cv.lib" )  
  4. #pragma comment( lib, "cxcore.lib" )  
  5. #pragma comment( lib, "highgui.lib" )  
  6. int main()  
  7. {  
  8.          IplImage* src=cvLoadImage("lena.jpg",0);  
  9.          int size=256;  
  10.          float range[]={0,255};  
  11.          float* ranges[]={range};  
  12.          CvHistogram* hist=cvCreateHist(1,&size,CV_HIST_ARRAY,ranges,1);  
  13.          cvCalcHist(&src,hist,0,NULL);  
  14.          float max=0;  
  15.          cvGetMinMaxHistValue(hist,NULL,&max,NULL,NULL);  
  16.          IplImage* dst=cvCreateImage(cvSize(400,300),8,3);  
  17.          cvSet(dst,cvScalarAll(255),0);  
  18.          double bin_width=(double)dst->width/size;  
  19.          double bin_unith=(double)dst->height/max;  
  20.          for(int i=0;i<size;i++)  
  21.          {  
  22.                    CvPoint p0=cvPoint(i*bin_width,dst->height);  
  23.                    CvPoint p1=cvPoint((i+1)*bin_width,dst->height-cvGetReal1D(hist->bins,i)*bin_unith);  
  24.                    cvRectangle(dst,p0,p1,cvScalar(0,255),-1,8,0);  
  25.          }  
  26.          cvNamedWindow("src",1);  
  27.          cvShowImage("src",src);  
  28.          cvNamedWindow("dst",1);  
  29.          cvShowImage("dst",dst);  
  30.          cvWaitKey(0);  
  31.          cvDestroyAllWindows();  
  32.          cvReleaseImage(&src);  
  33.          cvReleaseImage(&dst);  
  34.          return 0;  
  35. }  

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值