版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、实验 直方图均衡化的计算机实现一、 实验目的: 1) 熟悉直方图均衡化处理的理论基础; 2) 掌握直方图均衡化处理的计算机实现方法; 3) 学习 Matlab 编程方法; 4) 学习 VC+6.0 编程方法; 5) 验证直方图均衡化处理理论; 6) 观察直方图均衡化处理的结果。 二、 实验要求: 1) 学习 Matlab 编程步骤及相关图像处理函数,利用 Matlab 实现图像直方图均衡化,并提交 Matlab 程序及说明文档。 2) 学习 VC+编程的步骤及流程,利用 VC+实现图像直方图均衡化; 3) 提交加注释的 VC+程序及程序说明文档; 4) 提交第三章学过的直方图及直方图相关算法的
2、处理步骤及作用; 5) 提交直方图均衡化处理的步骤及处理效果,附上实验效果图,写出本次实验的体会。 三、实验时间: 第九周,第十周两次实验课,共四个学时。 附件:VC+6.0 实现直方图均衡化处理编程指南 直方图均衡化处理编程指南本程序将在 Microsoft Visual C+6.0 开发环境下构建,所以,在开始之前,请确定您所使用的计算机已经正确安装了 Microsoft Visual C+6.0(具体的安装方法请详见 MicrosoftVisual C+6.0 用户手册,低于 6.0 的版本是否可以运行在此不做讨论)。下面,请用该指南构建一个直方图均衡化处理的程序。一、创建对话框资源利用
3、 Microsoft Visual Studio 的对话框编辑器来设计对话框并创建对话框资源。步骤如下:1、Visual C+6.0 启动步骤: 安装好 Visual C+6.0; 按路径开始程序Microsoft Visual Studio 6.0Microsoft Visual C+ 6.0启动 VC; 出现 VC 界面后,按路径“File-New”进入创建项目对话框;2、在弹出的对话框中单击 Projects 选项卡,并单击 MFC AppWizard (exe),在右侧的 Projectname 一栏中输入工程文件名,在此我们输入 HistDemoA(读者可以输入自己的工程文件名,但为
4、了统一起见,建议初学者输入和本文相同的名字,以便于后面的理解),如下图所示:图 1完成后,单击 OK 按钮。3、在弹出的 MFC AppWizard 中,选择 Dialog based,如下图所示,图 2其它各项均接受默认的设置。生成对话框应用程序界面如下所示:图 34、删除“取消”按钮及“TODO:在这里设置对话框”静态文本框。右键单击“确定”按钮,在弹出的菜单中选择 Properties,在弹出的按钮属性对话框中将“确定”按钮的 Caption改为“关闭”。5、改变对话框的大小。用鼠标直接拖拉就可以调整这个对话框的大小。在这里,我们通过鼠标的拖拉,将对话框的大小改为 500270(为了后面
5、能合适地显示图像。本程序在 1024768 的分辨率下调试,如果读者使用不同的分辨率,请根据具体情况做相应的调整),这个大小将在窗口右下侧的状态栏中显示出来。6、添加对话框控件。通过控件调色板来添加控件(如果控件调色板不可见的话,在工具栏上单击右键,从列表中选择 Controls 即可)。可以把控件直接从控件调色板上拖拉到新的对话框中,然后放到合适的位置,并且改变控件大小。在这里,我们添加两个静态文本框,右键单击 Properties,将它们的 Caption 分别设置为:“原始图像”和“直方图均衡化处理后的图像”。然后添加两个按钮,右键单击 Properties,在属性设置中分别将它们的 I
6、D 设置为“IDC_OPEN”和“IDC_HIST”,Caption 分别设置为“打开文件”和“直方图均衡化”。将新添加的这些控件拖拉到合适的位置后,对话框界面如下所示:图 4二、创建 CImageWnd 类1、单击菜单栏的 Insert,选择 New Class,在弹出的对话框中,将 Class type 选为 GenericClass,并在 Name 栏中输入 CImageWnd,然后点击 OK 按钮。如下图所示:图 52、通过工作区的 FileView 找到 ImageWnd.h 文件,打开它并将类定义部分的 classCImageWnd 修改为 class CImageWnd:publ
7、ic CWnd。3、为类 CImageWnd 添加成员变量。通过工作区的 ClassView,找到类 CImageWnd,单击右键,在弹出的菜单中选择 Add Member Variable,在弹出的对话框中输入要添加的成员变量的类型及名字,及选择访问限定语。在这里,我们依次加入访问限定语为 public 的下列int 型变量:HCurrentPosition,HScrollMax,HScrollPosition,VCurrentPosition,VScrollMax,VScrollPosition,nWidth,nHeight,nByteWidth。然后再添加访问限定语为 public,类型
8、为BYTE 的成员变量*lpBits。完成类 CimageWnd 的成员变量的添加。4、为类 CimageWnd 添加成员函数。通过工作区的 ClassView,找到类 CImageWnd,单击右键,在弹出的菜单中选择 Add Member Function,在弹出的对话框中输入要添加的成员函数的类型及声明,及选择访问限定语。在此我们添加以下的成员函数:访问限定语为public,类型为 void 的 SetImage(int cx,int cy,const void *bits),在函数的定义部分加入如下的代码:nWidth=cx;nHeight=cy;nByteWidth=nWidth*3;
9、if (nByteWidth%4) nByteWidth+=4-(nByteWidth%4);if (lpBits) delete lpBits;lpBits=new BYTEnByteWidth*nHeight;memcpy(lpBits,bits,nByteWidth*nHeight);if (cx>320 | cy>240) SetScroll(cx,cy);else SetScroll(0,0);Invalidate();然后添加访问限定语为 public,类型为 void 的 SetScroll(int cx,int cy),并在函数的定义部分加入如下代码:HScroll
10、Position=0;HCurrentPosition=0;VScrollPosition=0;VCurrentPosition=0;SetScrollPos(SB_HORZ,0);SetScrollPos(SB_VERT,0);SCROLLINFO sinfo;sinfo.cbSize=sizeof(SCROLLINFO);sinfo.fMask=SIF_PAGE|SIF_RANGE;sinfo.nMin=0;/HScrollsinfo.nMax=cx-1;sinfo.nPage=302;SetScrollInfo(SB_HORZ,&sinfo);HScrollMax=cx-302;
11、/VScrollsinfo.nMax=cy-1;sinfo.nPage=222;SetScrollInfo(SB_VERT,&sinfo);VScrollMax=cy-222;5、为类 CimageWnd 添加构造函数和析构函数。在构造函数 CImageWnd:CImageWnd()的定义体内加入下面的代码:HScrollPosition=0;HCurrentPosition=0;HScrollMax=0;VScrollPosition=0;VCurrentPosition=0;VScrollMax=0;lpBits=0;在析构函数 CImageWnd:CImageWnd()的定义体内
12、加入下面的代码:if (lpBits) delete lpBits;6、为类 CimageWnd 添加消息映射。打开文 ImageWnd.h,并添加如下代码:protected:/AFX_MSG(CImageWnd)afx_msg BOOL OnEraseBkgnd(CDC* pDC);afx_msg void OnHScroll(UINT nSBCode, UINT nPos, CScrollBar* pScrollBar);afx_msg void OnVScroll(UINT nSBCode, UINT nPos, CScrollBar* pScrollBar);afx_msg void
13、 OnPaint();afx_msg int OnCreate(LPCREATESTRUCT lpCreateStruct);/AFX_MSGDECLARE_MESSAGE_MAP()打开文件 ImageWnd.cpp,在析构函数 CImageWnd:CImageWnd()的定义后面,加入下面的代码:BEGIN_MESSAGE_MAP(CImageWnd, CWnd)/AFX_MSG_MAP(CImageWnd)ON_WM_ERASEBKGND()ON_WM_HSCROLL()ON_WM_VSCROLL()ON_WM_PAINT()ON_WM_CREATE()/AFX_MSG_MAPEND_M
14、ESSAGE_MAP()7、添加消息处理函数。打开文件 ImageWnd.cpp,加入下面的代码:#define BACKGROUND RGB(128,128,128)BOOL CImageWnd:OnEraseBkgnd(CDC* pDC)if (!lpBits) pDC->FillSolidRect(0,0,320,240,BACKGROUND);return TRUE;void CImageWnd:OnPaint()CPaintDC dc(this); / device context for paintingif (lpBits)int x,y;x=-HScrollPositio
15、n;y=-VScrollPosition;if (nWidth<320) x=(320-nWidth)/2;if (nHeight<240) y=(240-nHeight)/2;BITMAPINFOHEADER bmi;bmi.biSize=sizeof(BITMAPINFOHEADER);bmi.biWidth=nWidth;bmi.biHeight=nHeight;bmi.biPlanes=1;bmi.biBitCount=24;bmi.biCompression=BI_RGB;bmi.biSizeImage=0;bmi.biXPelsPerMeter=0;bmi.biYPel
16、sPerMeter=0;bmi.biClrUsed=0;bmi.biClrImportant=0;StretchDIBits(dc.m_hDC,x,y,nWidth,nHeight,0,0,nWidth,nHeight,lpBits,(BITMAPINFO *)&bmi,DIB_RGB_COLORS,SRCCOPY);void CImageWnd:OnHScroll(UINT nSBCode, UINT nPos, CScrollBar* pScrollBar)switch(nSBCode)case SB_LINEDOWN:HScrollPosition+=5;break;case S
17、B_LINEUP:HScrollPosition-=5;break;case SB_PAGEDOWN:HScrollPosition+=302;break;case SB_PAGEUP:HScrollPosition-=302;break;case SB_THUMBPOSITION:case SB_THUMBTRACK:HScrollPosition=nPos;break;if (HScrollPosition<0) HScrollPosition=0;if (HScrollPosition>HScrollMax) HScrollPosition=HScrollMax;SetScr
18、ollPos(SB_HORZ,HScrollPosition);if (HCurrentPosition!=HScrollPosition)ScrollWindow(HCurrentPosition-HScrollPosition),0);HCurrentPosition=HScrollPosition;CWnd:OnHScroll(nSBCode, nPos, pScrollBar);void CImageWnd:OnVScroll(UINT nSBCode, UINT nPos, CScrollBar* pScrollBar)switch(nSBCode)case SB_LINEDOWN:
19、VScrollPosition+=5;break;case SB_LINEUP:VScrollPosition-=5;break;case SB_PAGEDOWN:VScrollPosition+=222;break;case SB_PAGEUP:VScrollPosition-=222;break;case SB_THUMBPOSITION:case SB_THUMBTRACK:VScrollPosition=nPos;break;if (VScrollPosition<0) VScrollPosition=0;if (VScrollPosition>VScrollMax) VS
20、crollPosition=VScrollMax;SetScrollPos(SB_VERT,VScrollPosition);if (VCurrentPosition!=VScrollPosition)ScrollWindow(0,(VCurrentPosition-VScrollPosition);VCurrentPosition=VScrollPosition;CWnd:OnVScroll(nSBCode, nPos, pScrollBar);int CImageWnd:OnCreate(LPCREATESTRUCT lpCreateStruct)if (CWnd:OnCreate(lpC
21、reateStruct) = -1)return -1;return 0;三、为 CHistDemoADlg 添加代码1 、 找 到 并 双 击 打 开 文 件 HistDemoADlg.h ( 通 过 工 作 区 的 FileView ), 在 classCHistDemoADlg : public Cdialog 前添加#include "ImageWnd.h"2、在 HistDemoADlg.h 的 public 部分,CHistDemoADlg(CWnd* pParent = NULL);之后加入下面的语句:int nWidth;int nHeight;int nL
22、en;int nByteWidth;BYTE *lpBackup;BYTE *lpBitmap;BYTE *lpBits;CString FileName;CImageWnd source,dest;3、单击菜单栏的 View,在弹出的菜单中选择 ClassWizard,然后在弹出的对话框中选择Message Maps 选项卡,在 Class name 下拉列表框中选择 CHistDemoADlg,在 Object IDs中选择 CHistDemoADlg,在 Member functions 中选择双击 OnInitDialog, 如果没有的话,在 Messages 中 双 击 WM_INI
23、TDIALOG 添 加 ), 窗 口 将 跳 转 到 BOOLCHistDemoADlg:OnInitDialog()的定义部分。在“/ TODO: Add extra initialization here”(后面加入下面的代码:source.Create(0,"Source",WS_CHILD|WS_VISIBLE,CRect(40,40,360,280), this, 10000);dest.Create(0,"Destination",WS_CHILD|WS_VISIBLE,CRect(400,40,720,280), this,10001);至
24、此,编译我们的建立的程序,界面如下图所示: 如有任何错误不能正常编译通过,请读者仔细检查前面的编程步骤,笔者按此建立过程成功编译通过并显示出下面的界面)图 6单击按钮“打开文件”和“直方图均衡化”,没有任何反映,因为我们还没有给它们添加响应。单击“关闭”按钮,对话框关闭。四、为“打开文件”按钮添加响应。1、为类 CHistDemoADlg 添加成员函数 void LoadBitmap ( )。打开工作区的 ClassView,右键盘单击类 CHistDemoADlg,在弹出的菜单中选择 Add Member function,在弹出的对话框中加入访问限定语为 public,函数类型为 void
25、,函数声明为 LoadBitmap 的成员函数,点击“OK”按钮,编辑窗口将跳转到函数 void LoadBitmap ( )的定义部分。在函数 void LoadBitmap ( )的定义部分的定义部分加入下面的代码:BITMAPINFOHEADER *pInfo;pInfo=(BITMAPINFOHEADER *)(lpBitmap+sizeof(BITMAPFILEHEADER);nWidth=pInfo->biWidth;nByteWidth=nWidth*3;if (nByteWidth%4) nByteWidth+=4-(nByteWidth%4);nHeight=pInfo
26、->biHeight;if (pInfo->biBitCount!=24)if (pInfo->biBitCount!=8)AfxMessageBox("无效位图");delete lpBitmap;(lpBitmap=0;return;unsigned int PaletteSize=1<<pInfo->biBitCount;if (pInfo->biClrUsed!=0 && pInfo->biClrUsed<PaletteSize)PaletteSize=pInfo->biClrUsed;lp
27、Bits=lpBitmap+sizeof(BITMAPFILEHEADER)+sizeof(BITMAPINFOHEADER);RGBQUAD *pPalette=(RGBQUAD *)lpBits;lpBits+=sizeof(RGBQUAD)*PaletteSize;nLen=sizeof(BITMAPFILEHEADER)+sizeof(BITMAPINFOHEADER)+nByteWidth*nHeight;BYTE *lpTemp=lpBitmap;lpBitmap=new BYTEnLen;BITMAPFILEHEADER bmh;BITMAPINFOHEADER bmi;bmh.
28、bfType='B'+'M'*256;bmh.bfSize=nLen;bmh.bfReserved1=0;bmh.bfReserved2=0;bmh.bfOffBits=54;bmi.biSize=sizeof(BITMAPINFOHEADER);bmi.biWidth=nWidth;bmi.biHeight=nHeight;bmi.biPlanes=1;bmi.biBitCount=24;bmi.biCompression=BI_RGB;bmi.biSizeImage=0;bmi.biXPelsPerMeter=0;bmi.biYPelsPerMeter=0;
29、bmi.biClrUsed=0;bmi.biClrImportant=0;int nBWidth=pInfo->biWidth;if (nBWidth%4) nBWidth+=4-(nBWidth%4);memset(lpBitmap,0,nLen);memcpy(lpBitmap,&bmh,sizeof(BITMAPFILEHEADER);memcpy(lpBitmap+sizeof(BITMAPFILEHEADER),&bmi,sizeof(BITMAPINFOHEADER);BYTE*lpBits2=lpBitmap+sizeof(BITMAPFILEHEADER)
30、+sizeof(BITMAPINFOHEADER);int x,y,p1,p2,Palette;for(y=0;y<nHeight;y+)for(x=0;x<nWidth;x+)p1=y*nBWidth+x;p2=y*nByteWidth+x*3;if (lpBitsp1<PaletteSize) Palette=lpBitsp1;else Palette=0;lpBits2p2=pPalettePalette.rgbBlue;lpBits2p2+1=pPalettePalette.rgbGreen;lpBits2p2+2=pPalettePalette.rgbRed;del
31、ete lpTemp;lpBits=lpBitmap+sizeof(BITMAPFILEHEADER)+sizeof(BITMAPINFOHEADER);if (lpBackup) delete lpBackup;lpBackup=new BYTEnLen;memcpy(lpBackup,lpBitmap,nLen);2、单击菜单栏的 View,在弹出的菜单中选择 ClassWizard,然后在弹出的对话框中选择 Message Maps 选项卡,在 Class name 下拉列表框中选择 CHistDemoADlg,在 ObjectIDs 中选择 IDC_OPEN,在 Messages 中单
32、击 BN_CLICKED,然后再单击 ADD Function按钮,将弹出添加成员函数的对话框,如下图所示:图 7接受默认的函数名,单击“OK”按钮,就成功地添加了该成员函数。单击“Edit Code”按钮,窗口将跳转到该成员函数的定义部分,加入下面的代码:CFile File=0;CFileDialog dlg(TRUE,0,0,OFN_HIDEREADONLY," 位 图 文 件 |*.bmp| 所 有 文 件|*.*|",this);if (dlg.DoModal()=IDOK)FileName=dlg.GetPathName();if (!File.Open(Fil
33、eName,CFile:modeRead) return;/ TODO: add loading code hereif (lpBitmap) delete lpBitmap;nLen=File.GetLength();lpBitmap=new BYTEnLen;File.Read(lpBitmap,nLen);LoadBitmap();if (lpBitmap) source.SetImage(nWidth,nHeight,lpBits);3、在类 CHistDemoADlg 的构造函数 CHistDemoADlg(CWnd* pParent /*=NULL*/)中加入下面的代码:lpBit
34、map=0;lpBackup=0;到此为止,我们所构建的程序已经能实现对单击“打开文件”按钮的响应。编译程序,并打开 BMP 文件,如下图所示:图 8五、为“直方图均衡化”按钮添加响应1、单击菜单栏的 View,在弹出的菜单中选择 ClassWizard,然后在弹出的对话框中选择 Message Maps 选项卡,在 Class name 下拉列表框中选择 CHistDemoADlg,在 ObjectIDs 中选择 IDC_HIST,在 Messages 中单击 BN_CLICKED,然后再单击 ADD Function按钮,将弹出添加成员函数的对话框,如下图所示:图 9接受默认的函数名,单击
35、“OK”按钮,就成功地添加了该成员函数。单击“Edit Code”按钮,窗口将跳转到该成员函数的定义部分,加入下面的代码:HistogramEq();2、刚刚添加的 HistogramEq()实现直方图均衡化处理的算法。我们在 HistDemoADlg.cpp中加入下面的代码:#define Point(x,y) lpPoints(x)+(y)*nWidth#define Point1(x,y) lpPoints1(x)+(y)*nWidthvoid GetPoints(int nWidth,int nHeight,BYTE *lpBits,BYTE *lpPoints)int x,y,p;i
36、nt nByteWidth=nWidth*3;if (nByteWidth%4) nByteWidth+=4-(nByteWidth%4);for(y=0;y<nHeight;y+)for(x=0;x<nWidth;x+)p=x*3+y*nByteWidth;lpPointsx+y*nWidth=(BYTE)(0.299*(float)lpBitsp+2+0.587*(float)lpBitsp+1+0.114*(float)lpBitsp+0.1);void PutPoints(int nWidth,int nHeight,BYTE *lpBits,BYTE *lpPoints)
37、int nByteWidth=nWidth*3;if (nByteWidth%4) nByteWidth+=4-(nByteWidth%4);int x,y,p,p1;for(y=0;y<nHeight;y+)for(x=0;x<nWidth;x+)p=x*3+y*nByteWidth;p1=x+y*nWidth;lpBitsp=lpPointsp1;lpBitsp+1=lpPointsp1;lpBitsp+2=lpPointsp1;3、为类 CHistDemoADlg 添加成员函数 HistogramEq( )。打开工作区的 ClassView,右键盘单击类 CHistDemoA
38、Dlg,在弹出的菜单中选择 Add Member function,在弹出的对话框中加入访问限定语为 public,函数类型为 void,函数声明为 HistogramEq 的成员函数,点击“OK”按钮,编辑窗口将跳转到函数 void CHistDemoADlg:HistogramEq( )的定义部分。在函数 void CHistDemoADlg:HistogramEq()的定义部分加入下面的代码:if (lpBitmap=0) return;BYTE *lpOutput=new BYTEnByteWidth*nHeight;HistogramEq1(nWidth,nHeight,lpBits
39、,lpOutput);dest.SetImage(nWidth,nHeight,lpOutput);delete lpOutput;NoColor();4、为类 CHistDemoADlg 添加成员函数 HistogramEq1(int nWidth,int nHeight,BYTE*lpInput,BYTE *lpOutput)。打开工作区的 ClassView,右键盘单击类 CHistDemoADlg,在弹出的菜单中选择 Add Member function,在弹出的对话框中加入访问限定语为public,函数类型为 void,函数声明为 HistogramEq1(int nWidth,int nHeig
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024版个人私有房屋购买合同
- 2025年上外版八年级物理上册月考试卷含答案
- 2024版网络直播执行合作合同版B版
- 2024年益阳职业技术学院高职单招语文历年参考题库含答案解析
- 2025年人教A版一年级语文上册月考试卷含答案
- 2025年沪科版选择性必修3物理下册阶段测试试卷含答案
- 2024年炎黄职业技术学院高职单招语文历年参考题库含答案解析
- 二零二五年度货车驾驶员与物流公司雇佣协议3篇
- 2024版工程项目尾款支付合同书版B版
- 2024招标年度廉政承诺书与投标保证金退还管理协议3篇
- 2025年山东光明电力服务公司招聘笔试参考题库含答案解析
- 《神经发展障碍 儿童社交沟通障碍康复规范》
- 2025年中建六局二级子企业总经理岗位公开招聘高频重点提升(共500题)附带答案详解
- 2024年5月江苏省事业单位招聘考试【综合知识与能力素质】真题及答案解析(管理类和其他类)
- 注浆工安全技术措施
- 2024年世界职业院校技能大赛“食品安全与质量检测组”参考试题库(含答案)
- 2023上海高考英语词汇手册单词背诵默写表格(复习必背)
- 人民军队历史与优良传统(2024)学习通超星期末考试答案章节答案2024年
- DB11T 641-2018 住宅工程质量保修规程
- 幼儿园幼儿营养食谱手册
- 2024宏泰集团所属湖北省征信限公司招聘9人高频难、易错点500题模拟试题附带答案详解
评论
0/150
提交评论