直方图均衡化.docxVIP

  • 2
  • 0
  • 约7.76千字
  • 约 9页
  • 2021-07-10 发布于湖南
  • 举报
直方图均衡化 用VC++实现位图直方图均衡化和显示 1、首先建立一个工程。打开VC++6.0,单击 文件【files 】→新建【new 】→工程【projects 】在打开的projects 下选择MFC App Wizard [exe]→在project name 下输入自己的工程名例如(Zhifangtujunhenghua )→单击【ok 】→在打开的对话框中选择基于单文档【single document】→在第四步 “MFC App Wizard step 4 of 6”面板中删掉【隐藏工具栏】和【打印和打印预览】两个选项,之后的全部选择默认,单击finish ,出现一个“New Project Information”窗口,单击【ok 】。一个简单的工程框架就建好了。 2、现在我们正式开始在新建工程Zhifangtujunhenghua 中进行编程实现bmp 位图的直方图均衡化。点击左边框中的【ResourceView 】框找到【Menu 】点开,双击Menu 下的图标,在右面的显示框中创建两个菜单: 打开 ID: ID_FILE_OPEN 直方图均衡化 ID : ID_ZHIFANGTU 3、给这两个菜单建立类向导。在右边的窗口中右击“打开”,选择“建立类向导”,然后在打开的对话框中按下图1操作,“Class name”选择“CZhifangtujunhenghuaView ” →”Object IDs”中选择 “ID_FILE_OPEN” →“Message ”中选择“COMMAND ”, 点击“Add Function ”键就会在“Member functions”中如下图1显示,然后点击“Edit Code”,在自动生成的OnFileOpen 函数中编写代码: void CZhifangtujunhenghuaView::OnFileOpen() // TODO: Add your command handler code here CFileDialog fileDlg(true); fileDlg.m_ofn.lpstrTitle=图片打开对话框; fileDlg.m_ofn.lpstrFilter=BMP Files(*.bmp)\0*.bmp\0\0; if(IDOK==fileDlg.DoModal()) m_fileName.Format (%s,fileDlg.GetPathName()); m_Dib.LoadFile(m_fileName); Invalidate(); 同理,操作“直方图均衡化” ,如下图2显示 选择“CZhifangtujunhenghuaView ”。点击“Edit Code”,在自动生成的“OnZhifangtu ” 函数中编写代码: void CZhifangtujunhenghuaView::OnZhifangtu() // TODO: Add your command handler code here if (m_Dib.IsValid()) m_Dib.fenbujunhenghua(); Invalidate(); }4、创建一个处理位图的类CDib ,且CDib 类是由CObject 类派生出来的。点击工程菜单栏中的插入【insert 】→【insert class】→类类型选“Generic Class”, →类名称填“CDib ” →【ok 】。可以看见工程窗口的Class View 中多了一个 CDib 类;点开CDib 类的头文件,输 入以下代码,注意变量可以直接复制,声明的函数不要直接复制(在CDib 类右击选择“Add member function”,输入函数类型和函数名)。 class CDib: public CObject public: RGBQUAD * m_pRGB; BYTE * m_pData; UINT m_numberOfColors; bool m_valid; BITMAPFILEHEADER bitmapFileHeader;//定义了一个文件头结构体的对象 BITMAPINFOHEADER * m_pBitmapInfoHeader;//定义了一个指向信息头的结构体指针 BITMAPINFO * m_pBitmapInfo;//定义了一个结构体指针,BITMAPINFO 是一个包含有信息头,和调色板的 BYTE * pDib; DWORD

文档评论(0)

1亿VIP精品文档

相关文档