资源描述
XXX大学实验报告
二0一二 年 四 月 十 六 日
课程名称: 数字图象处理 实验名称:实现bmp位图打开和显示
班级: 姓名: 同组人:
指导教师评定: 签名:
一、实验目的:
用VC++实现bmp位图打开和显示。
二、实验步骤:
1、首先建立一个工程。打开VC++6.0,单击 文件【files】→新建【new】→工程【projects】在打开的projects 下选择MFC App Wizard [exe]→在project name 下输入自己的工程名例如(Showpicture)→单击【ok】→【single document】→在第四步 “MFC App Wizard step 4 of 6”面板中删掉【隐藏工具栏】和【打印和打印预览】两个选项,之后的全部选择默认—>finish,出现一个“New Project Information”窗口,单击【ok】。
2、现在我们正式开始在新建工程Showpicture中进行编程实现bmp位图的打开和显示。点击左边框中的【ResourceView】框找到【Menu】点开,双击Menu下的图标,在右面的显示框中创建两个菜单:打开,显示原图。分别双击这两个菜单修改属性:
打开 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函数中编写代码:
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());
CDib.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;
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 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 LoadFile(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::GetNumberOfColors()
{
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
numberOfColors = (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)
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.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();
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;
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;
AfxMessageBox("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 hBitmap=(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 (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” 。编译运行 应该就可以了。
三、 实验效果
四、 实验小结:
本次实验通过对图像的规格化处理,了解了图像规格化增强图像对比度的特性,但其对图像增强效果不易控制的缺点。
展开阅读全文