- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
bmp位图的二值化与反色
一.实验目的:
理解图像的象素操作。理解二值化,挖空,线性变换,直方图与反色的本质。
二.实验内容及步骤:
1.根据实验一的结果,VC6.0开发环境下的资源编辑器中,在主菜单下添加一名为“点运算”的菜单。并添加两个分别名为“二值化”与“反色”的子菜单项。分别给它们名为“IDM_ERZH”、“IDM_FANCE”的ID。2.打开classwizard,分别为下述两菜单项加入相应的消息映射函数。
3.在函数体中加入二值化和反色的实现代码。
4.在两函数体最后加入更新视图的函数:Invalidate。
5. 同理,对挖空,线性变换,直方图进行操作。
三. 实验结果及代码:
原图像:
二值化及反色后图像:
直方图:
二值化及反色的代码:
void CYdcView::OnErzh()
{
// TODO: Add your command handler code here
long w,h,i,j;
w=m_DibHead-biWidth;
h=m_DibHead-biHeight;
unsigned char temp(0);
for(i=0;i3*h;i++)
for(j=0;jw;j++)
{
temp=*(m_Image+i*w+j);
if(temp20)
*(m_Image+i*w+j)=255;
else *(m_Image+i*w+j)=0;
}
Invalidate();
}
void CYdcView::OnFance()
{
// TODO: Add your command handler code here
long w,h,i,j;
w=m_DibHead-biWidth;
h=m_DibHead-biHeight;
for(i=0;i3*h;i++)
for(j=0;jw;j++)
{
*(m_Image+i*w+j)=255-*(m_Image+i*w+j);
}
Invalidate();
}
挖空,线性变换,直方图的代码:
void CYdcView::OnWakong()
{
// TODO: Add your command handler code here
//控空(即挖空):
long w,h,i,j;
w=m_DibHead-biWidth;
h=m_DibHead-biHeight;
for(i=0;ih;i++)
for(j=0;jw;j++)
{
if((i-h/2)*(i-h/2)+(j-w/2)*(j-w/2)10000)
*(m_Image+i*w+j)=255;
}
Invalidate();
}
void CYdcView::OnLinechange()
{
// TODO: Add your command handler code here
//线性变换:
long w,h,i,j;
w=m_DibHead-biWidth;
h=m_DibHead-biHeight;
unsigned char temp(0);
for(i=0;i3*h;i++)
for(j=0;jw;j++)
{
temp=*(m_Image+i*w+j);
if(temp100)
*(m_Image+i*w+j)=255;
*(m_Image+i*w+j)= *(m_Image+i*w+j)*1.5;
}
Invalidate();
}
void CYdcView::OnZft()
{
// TODO: Add your command handler code here
//1.统计
long w,h,i,j;
long a[256];
long max=0;
for(i=0;i256;i++)
a[i]=0;
w=m_DibHead-biWidth;
h=m_DibHead-biHeight;
for(i=0;ih;i++)
for(j=0;jw;j++)
{
a[*(m_Image+i*w+j)]+=1;
}
//2.归一化
for(i=0;i256;i++)
if(a[i]max)
max=a[i];
for(i=0;i256;i++)
{
a[i]=a[i]*200/max;
}
//3.量化
int y=300;
CDC *Pdc=GetDC();
for(i=0;i256;i++)
{
Pdc-MoveTo(i+300,y);
Pdc-LineTo(i+300,y-a[i]);
}
}
思考与练习:
1.说明影响二值化效果的参数是什么?
图像的二值化处理就是讲图像上的点的灰度置为0或255,也就是讲整个图像呈现出明显的黑白效果。即将256个亮度等级的灰度图像通过适当的阀值选取而获得仍然可以反映图像整体和局部特征的二值化图像。要进行二值图
您可能关注的文档
- 3……线性代数方程组的解法.ppt
- 3人教版四年级数学下册《营养午餐》PPT课件.ppt
- 3讲:8088寻址方式、指令系统.ppt
- 3月12日天天练.doc
- 3《数豆子》.ppt
- 3_几何光学-1.ppt
- 4-汽车喷涂检验标准.doc
- 4-1自然条件对交通线路的影响xg.ppt
- 3专题三离子反应.ppt
- 3月份宏观经济指标预测及分析.doc
- 福莱特玻璃集团股份有限公司海外监管公告 - 福莱特玻璃集团股份有限公司2024年度环境、社会及管治报告.pdf
- 广哈通信:2024年度环境、社会及治理(ESG)报告.pdf
- 招商证券股份有限公司招商证券2024年度环境、社会及管治报告.pdf
- 宏信建设发展有限公司2024 可持续发展暨环境、社会及管治(ESG)报告.pdf
- 品创控股有限公司环境、社会及管治报告 2024.pdf
- 中信建投证券股份有限公司2024可持续发展暨环境、社会及管治报告.pdf
- 洛阳栾川钼业集团股份有限公司环境、社会及管治报告.pdf
- 361度国际有限公司二零二四年环境、社会及管治报告.pdf
- 中国神华能源股份有限公司2024年度环境、社会及管治报告.pdf
- 广西能源:2024年环境、社会及治理(ESG)报告.pdf
文档评论(0)