C++ MFC打开图片并进行二值化和灰度处理

C++ MFC打开图片并进行二值化和灰度处理

一、新建一个MFC工程,添加两个picture控件和一个按钮控件。
C++ MFC打开图片并进行二值化和灰度处理_第1张图片
二、添加变量
1、为两个picture控件添加control变量,类型为CStatic,变量名分别为m_picture1和m_picture2.
2、两个picture空间的ID修改成不一样的
3、添加保存图片路径和名称变量,CString类型,变量名strFilePath,strFileName

三、打开图片
1、双击“打开图片”按钮进入消息映射函数,添加以下代码:
CFileDialog fileDlg(TRUE, _T(“png”), NULL, 0, _T(“image Files(.bmp; .jpg;.png)|.JPG;.PNG;.BMP|All Files (.) |.|”), this);
fileDlg.DoModal();
strFilePath=fileDlg.GetPathName(); //文件路径
strFileName = fileDlg.GetFileName(); //文件名
if (strFilePath == _T(""))
{
return;
}
CImage image;
image.Load(strFilePath);
CRect rectControl; //控件矩形对象
m_picture1.GetClientRect(rectControl);
CDC *pDc = m_picture1.GetDC(); //设备上下文对象的类
rectControl = CRect(rectControl.TopLeft(), CSize((int)rectControl.Width(), (int)rectControl.Height()));
m_picture1.SetBitmap(NULL); //清空picture
image.Draw(pDc->m_hDC, rectControl); //将图片绘制到Picture控件表示的矩形区域
image.Destroy();
m_picture1.ReleaseDC(pDc);
2、由于图片内存没有分配所以进行// image.Destroy();

四、对图片二值化处理。使用前先在.cpp文件中添加 #include “vector”
C++ MFC打开图片并进行二值化和灰度处理_第2张图片
1、二值化程序
byte* pRealData;
pRealData = (byte*)image.GetBits(); //获取到图片内存点的位置
int width = image.GetWidth();
int height = image.GetHeight();
int pit = image.GetPitch(); //图像每行字节数
int bitCount = image.GetBPP() / 8; //获取每像素的位数~~/8得到字节数
vector gray(256); //初始化时自动存0,用来存放256种颜色出现的次数
for (int i = 0; i < height; i++)
{
for (int j = 0; j < width; j++)
{
gray.at((int)((pRealData + piti + j*bitCount))) += 1; //像素被用到的次数加一
}
}
//进行二值化处理
int max = 0;
int sec = 0;
int locamax = 0;
int locasec = 0;
for (int i = 0; i < 256; i++)
{
if (gray[i] > max)
{
max = gray[i]; //得到被使用次数最多的像素
locamax = i;
}
}
for (int i = 0; i < 256; i++)
{

if (gray[i] > sec&&abs(i-locamax)>10) //得到被使用次数第二多的像素
{
sec = gray[i];
locasec = i;

}
}
int min = (locamax + locasec) / 2; //取中间值,大于中间值的变成黑色,小于中间值的变成白色
for (int i = 0; i < height; i++)
{
for (int j = 0; j < width; j++)
{
if ((int)((pRealData + piti + jbitCount)) < min)
{
(pRealData + piti + j
bitCount) = 0;
(pRealData + piti + jbitCount+1) = 0;
(pRealData + piti + j
bitCount+2) = 0;
}
else
{
(pRealData + piti + jbitCount) = 255;
(pRealData + piti + j
bitCount + 1) = 255;
(pRealData + piti + jbitCount + 2) = 255;
}
}
}
//处理完的图片显示在picture2上
m_picture2.GetClientRect(rectControl);
pDc = m_picture2.GetDC();
rectControl = CRect(rectControl.TopLeft(), CSize((int)rectControl.Width(), (int)rectControl.Height()));
m_picture2.SetBitmap(NULL);
image.Draw(pDc->m_hDC, rectControl); //将图片绘制到Picture控件表示的矩形区域
image.Save(_T(“D:\图片.png”)); //将图片保存到D盘中
image.Destroy(); //释放
m_picture2.ReleaseDC(pDc); //释放
C++ MFC打开图片并进行二值化和灰度处理_第3张图片
五、图片灰度值处理函数
灰度处理程序取代二值化处理:
for (int i = 0; i < height; i++)
{
for (int j = 0; j < width; j++)
{
(pRealData + piti + j
bitCount) =0.114 ;
(pRealData + piti + j
bitCount+1) =0.587 ;
(pRealData + piti + j
bitCount+2) *=0.299 ;
}
}
C++ MFC打开图片并进行二值化和灰度处理_第4张图片

你可能感兴趣的:(C++ MFC打开图片并进行二值化和灰度处理)