//直方图均衡化 https://github.com/scutlzk
#include <opencv2\highgui\highgui.hpp>
#include <iostream>
#include<vector>
using namespace cv;
using namespace std;
void Histogram_Equalization(const char *srcfilename, Mat *&dst)
{
double gray[256];
Mat src = imread(srcfilename, 0);
vector<uchar> array(src.rows*src.cols);
if (src.isContinuous()) { array.assign(src.datastart, src.dataend); }
for (int i = 0; i < src.rows*src.cols; i++)++gray[array[i]];
for (int i = 0; i < 256; i++) {
gray[i] /= (src.rows*src.cols);
gray[i] = int(255 * gray[i] + 0.5);
if (i > 0)gray[i] = (gray[i] + gray[i - 1]);
}
for (int i = 0; i < src.rows*src.cols; i++)array[i] = gray[array[i]];
dst=new Mat((int)src.rows, (int)src.cols, 0);
for (int i = 0; i < src.ro
vs2015+opencv3.3.1 实现 c++ 直方图均衡化
最新推荐文章于 2022-10-29 15:45:57 发布
本文详细介绍了如何在Visual Studio 2015环境下,利用OpenCV 3.3.1库进行C++编程,实现图像的直方图均衡化。通过步骤分解,读者将学习到如何配置项目设置,引入OpenCV库,以及编写和理解直方图均衡化的关键代码。
摘要由CSDN通过智能技术生成