9. 对一幅对比度差的图像进行灰度均衡化。

#include <opencv2/opencv.hpp>

#include <highgui.h>

#include <cv.h>

IplImage* TO_junhenghua(IplImage *pImage);

int main(int argc, char** argv)

{

// 从文件中加载原图

IplImage *test = cvLoadImage("6013202130.jpg", CV_LOAD_IMAGE_UNCHANGED);

IplImage *test_1 = TO_junhenghua(test);

cvNamedWindow("原图", CV_WINDOW_AUTOSIZE);

cvNamedWindow("直方图均衡化后", CV_WINDOW_AUTOSIZE);

cvShowImage("原图", test);

cvShowImage("直方图均衡化后", test_1);

cvWaitKey(0);

cvDestroyWindow("原图");

cvDestroyWindow("直方图均衡化后");

cvReleaseImage(&test);

cvReleaseImage(&test_1);

return 0;

}

 

IplImage* TO_junhenghua(IplImage *pImage)

{

IplImage *pEquaImage = cvCreateImage(cvGetSize(pImage), pImage->depth, 3);

 

// 原图像分成各通道后再均衡化,最后合并即彩色图像的直方图均衡化

const int MAX_CHANNEL = 4;

IplImage *im_linshi[MAX_CHANNEL] = { NULL };

int i;

for (i = 0; i < pImage->nChannels; i++)

im_linshi[i] = cvCreateImage(cvGetSize(pImage), pImage->depth, 1);

cvSplit(pImage, im_linshi[0], im_linshi[1], im_linshi[2], im_linshi[3]);

for (i = 0; i < pImage->nChannels; i++)

cvEqualizeHist(im_linshi[i], im_linshi[i]);

cvMerge(im_linshi[0], im_linshi[1], im_linshi[2], im_linshi[3], pEquaImage);

for (i = 0; i < pImage->nChannels; i++)

cvReleaseImage(&im_linshi[i]);

return pEquaImage;

}

转载于:https://www.cnblogs.com/zhangfeionline/p/5465208.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值