1、XXX大学实验报告 二0一二 年 四 月 十 六 日 课程名称: 数字图象处理 实验名称:实现bmp位图打开和显示 班级: 姓名: 同组人: 指导教师评定: 签名: 一、实验目的: 用VC++实现bmp位图打开和显示。 二、实验步骤: 1、首先建立一个工程。打开VC++6.0,单击 文件【files】→新建【new】→工程【projects】在打开的projects 下选择MFC App Wizard [exe]→在project
2、name 下输入自己的工程名例如(Showpicture)→单击【ok】→【single document】→在第四步 “MFC App Wizard step 4 of 6”面板中删掉【隐藏工具栏】和【打印和打印预览】两个选项,之后的全部选择默认—>finish,出现一个“New Project Information”窗口,单击【ok】。 2、现在我们正式开始在新建工程Showpicture中进行编程实现bmp位图的打开和显示。点击左边框中的【ResourceView】框找到【Menu】点开,双击Menu下的图标,在右面的显示框中创建两个菜单:打开,显示原图。分别双击这两个菜单修改属性
3、 打开 ID: ID_FILE_OPEN 显示原图 ID: IDM_YUANTU 3、给这两个菜单建立类向导。在右边的窗口中右击“打开”,选择“建立类向导”,然后在打开的对话框中按下图1操作,“Class name”选择 “CShowpictureDoc” →”Object IDs”中选择“ID_FILE_OPEN” →“Message”中选择“COMMAND”,点击“Add Function”键就会在“Member functions”中如下显示: 图1 然后点击“Edit Code”,在自动生成的OnFileOpen函数中编
4、写代码: void CShowpictureDoc::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 ()) filename.Format ("%s",fileDlg.GetPathName()); CD
5、ib.LoadFile(filename); } 同理,操作“显示原图”,如下图2显示:注意这次的“Class name”选择“CShowpictureView”。点击“Edit Code”,在自动生成的“OnYuantu” 函数中编写代码: void CShowpictureView::OnYuantu() { // TODO: Add your command handler code here CShowpictureDoc* pDoc = GetDocument();ASSERT_VALID(pDoc); filename=pDoc->filename;
6、state1=1;Invalidate(); } 图2 4、创建一个处理位图的类CDib,且,CDib类是由CObject类派生出来的。点击工程菜单栏中的插入【insert】→【insert class】→类类型选“Generic Class”, →类名称填“CDib” →【ok】。可以看见工程窗口的Class View 中多了一个 CDib 类;点开CDib类的头文件,输入以下代码,注意变量可以直接复制,声明的函数最好不要直接复制(在CDib类右击选择“Add member function”,输入函数类型和函数名)。 #include "windowsx.h" class
7、CDib :public CObject { public: RGBQUAD* m_pRGB; BYTE* m_pData; UINT m_numberOfColors; BOOL m_valid; BITMAPFILEHEADER bitmapFileHeader; BITMAPINFOHEADER* m_pBitmapInfoHeader; BITMAPINFO* m_pBitmapInfo; BYTE* pDib; DWORD size; char m_fileName[256]; public: void LoadFi
8、le(const char* dibFileName); DWORD GetSize(); UINT GetWidth(); UINT GetHeight(); UINT GetNumberOfColors(); CDib(); virtual ~CDib(); }; 5、对CDib类中的函数定义,找到Dib.cpp 输入代码: CDib::CDib() { size=0; } CDib::~CDib() { GlobalFreePtr(m_pBitmapInfo); } UINT CDib::GetNumberOfColor
9、s() { int numberOfColors; if((m_pBitmapInfoHeader->biClrUsed==0)&& (m_pBitmapInfoHeader->biBitCount < 9)) { switch (m_pBitmapInfoHeader->biBitCount) { case 1: numberOfColors = 2; break; case 4: numberOfColors = 16; break; case 8: numberOfColors = 256; } } else numbe
10、rOfColors = (int) m_pBitmapInfoHeader->biClrUsed; return numberOfColors; } UINT CDib::GetHeight() { return (UINT) m_pBitmapInfoHeader->biHeight; } UINT CDib::GetWidth() {return (UINT) m_pBitmapInfoHeader->biWidth;} DWORD CDib::GetSize() { if (m_pBitmapInfoHeader->biSizeImage != 0)
11、 return m_pBitmapInfoHeader->biSizeImage; else { DWORD height = (DWORD) GetHeight(); DWORD width = (DWORD) GetWidth(); return height * width; } } void CDib::LoadFile(const char *dibFileName) { strcpy(m_fileName,dibFileName); CFile dibFile(m_fileName, CFile::modeRead); dibFile
12、Read((void*)&bitmapFileHeader,sizeof(BITMAPFILEHEADER)); if (bitmapFileHeader.bfType == 0x4d42) { DWORD fileLength = dibFile.GetLength(); size = fileLength -sizeof(BITMAPFILEHEADER); pDib =(BYTE*)GlobalAllocPtr(GMEM_MOVEABLE, size); dibFile.Read((void*)pDib, size); dibFile.Close
13、); m_pBitmapInfo = (BITMAPINFO*) pDib; m_pBitmapInfoHeader = (BITMAPINFOHEADER*) pDib; m_pRGB = (RGBQUAD*)(pDib +m_pBitmapInfoHeader->biSize); int m_numberOfColors = GetNumberOfColors(); if (m_pBitmapInfoHeader->biClrUsed == 0) m_pBitmapInfoHeader->biClrUsed = m_numberOfColors;
14、 DWORD colorTableSize = m_numberOfColors * sizeof(RGBQUAD); m_pData = pDib + m_pBitmapInfoHeader->biSize+ colorTableSize; if (m_pRGB == (RGBQUAD*)m_pData) m_pRGB = NULL; m_pBitmapInfoHeader->biSizeImage = GetSize(); m_valid = TRUE; } else { m_valid = FALSE; AfxMessageBo
15、x("This isn't a bitmap file!"); } } 6、找到类CShowpictureView 中的OnDraw(CDC* pDC)函数输入以下代码: void CShowpictureView::OnDraw(CDC* pDC) { CShowpictureDoc* pDoc = GetDocument(); ASSERT_VALID(pDoc); // TODO: add draw code for native data here if(state1==1) { CBitmap m_bitmap; HBITMAP hBi
16、tmap=(HBITMAP)LoadImage(NULL,_T(filename),IMAGE_BITMAP,0,0,LR_CREATEDIBSECTION|LR_DEFAULTSIZE|LR_LOADFROMFILE); m_bitmap.Attach (hBitmap);CDC dcImage; if(!dcImage.CreateCompatibleDC (pDC)) return; BITMAP bm; m_bitmap.GetBitmap (&bm); dcImage.SelectObject (&m_bitmap); pDC->BitBlt
17、 (0,0,bm.bmWidth ,bm.bmHeight ,&dcImage,0,0,SRCCOPY); } } 7、最后编译时。在类CShowpictureDoc上右击,选择“Add member variable”,添加CString类型的filename变量和CDib类型的CDib变量,在CShowpicture. h中 添加#include "string.h"和#include "Dib.h",在CShowpictureView 上右击,选择“Add member variable”,添加CString类型的filename变量和int 类型的state1 ,在Dib.h 中添加头文件#include “windowsx.h” 。编译运行 应该就可以了。 三、 实验效果 四、 实验小结: 本次实验通过对图像的规格化处理,了解了图像规格化增强图像对比度的特性,但其对图像增强效果不易控制的缺点。






