如何用Vc实现灰度直方图,越详细越好?
3个回答
展开全部
//用VC读取以下数据:
//图像高
int m_imgHeight;
//图像宽
int m_imgWidth;
//输入图像缓冲区
unsigned char * m_pImgData;
//图像每像素位数
int m_nBitCount;
//直方图数组
int m_histArray[256];
//然后调用computeHistGray()
void computeHistGray()
{
if(m_nBitCount!=8)
return;
int i,j;
for(i=0;i<256;i++)
m_histArray[i]=0;
int lineByte=(m_imgWidth*m_nBitCount/8+3)/4*4;
int temp;
for(i=0;i<m_imgHeight;i++){
for(j=0;j<m_imgWidth;j++){
temp=*(m_pImgData+i*lineByte+j);
m_histArray[temp]++;
}
}
}
m_histArray[256]存放了直方图数据。至于显示直方图,那就是MFC控件的事了
//图像高
int m_imgHeight;
//图像宽
int m_imgWidth;
//输入图像缓冲区
unsigned char * m_pImgData;
//图像每像素位数
int m_nBitCount;
//直方图数组
int m_histArray[256];
//然后调用computeHistGray()
void computeHistGray()
{
if(m_nBitCount!=8)
return;
int i,j;
for(i=0;i<256;i++)
m_histArray[i]=0;
int lineByte=(m_imgWidth*m_nBitCount/8+3)/4*4;
int temp;
for(i=0;i<m_imgHeight;i++){
for(j=0;j<m_imgWidth;j++){
temp=*(m_pImgData+i*lineByte+j);
m_histArray[temp]++;
}
}
}
m_histArray[256]存放了直方图数据。至于显示直方图,那就是MFC控件的事了
追问
非常感谢,我想知道显示的时候该怎么做,新手,对MFC不熟悉···
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2011-04-17
展开全部
这个简单
对于灰度图像
设置一个数组int a[255],把每个值都设为0
遍历图像的数据区,对a[*pData]++
数组中就得到了要的灰度统计值
下面就是自己去绘制直方图的事了
对于灰度图像
设置一个数组int a[255],把每个值都设为0
遍历图像的数据区,对a[*pData]++
数组中就得到了要的灰度统计值
下面就是自己去绘制直方图的事了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐于2016-11-06
展开全部
typedef int (WINAPI ICEPUB_IMGTOBMP)(char *strImgFilename,char *strBmpFilename,int huiFlag);
ICEPUB_IMGTOBMP *icePub_imgToBmp = 0;
HINSTANCE hDLLDrv = LoadLibrary("icePubDll.dll");
if(hDLLDrv)
{
icePub_imgToBmp = (ICEPUB_IMGTOBMP *)GetProcAddress(hDLLDrv, "icePub_imgToBmp");
}
icePub_imgToBmp("a.png","hui.bmp",1);
//可得到256灰度bmp文件
http://dl.icese.net/dev.php?f=icePubDll.rar
ICEPUB_IMGTOBMP *icePub_imgToBmp = 0;
HINSTANCE hDLLDrv = LoadLibrary("icePubDll.dll");
if(hDLLDrv)
{
icePub_imgToBmp = (ICEPUB_IMGTOBMP *)GetProcAddress(hDLLDrv, "icePub_imgToBmp");
}
icePub_imgToBmp("a.png","hui.bmp",1);
//可得到256灰度bmp文件
http://dl.icese.net/dev.php?f=icePubDll.rar
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询