MFC中的位图操作

简介:

MFC中的位图操作,涉及三个概念:CBitmap,HBitmap,BITMAP.

1.BITMAP是位图的基本数据结构,封装位图信息,包括颜色,大小,位值,数据等

1
2
3
4
5
6
7
8
9
10
typedef  struct  tagBITMAP
      int       bmType;
      int       bmWidth;    //宽
      int       bmHeight;   //高
      int       bmWidthBytes;
      BYTE      bmPlanes;
      BYTE      bmBitsPixel;
      LPVOID    bmBits;
}  BITMAP;

2.HBitmap是位图句柄,可以通过API函数LoadImage加载文件得到,LoadImage得到的句柄为通用类型即,HANDLE.需要转换成具体的资源类型后,才能给绘图CDC类实例使用,如:

1
2
3
4
5
6
7
8
HBITMAP  hBitmap = ( HBITMAP )::LoadImage(NULL, 
         _T( "1.bmp" ), 
         IMAGE_BITMAP, 
         0, 0,  //原始大小
         LR_DEFAULTCOLOR | LR_CREATEDIBSECTION | LR_LOADFROMFILE);
//或者另外一个API函数,此函数仅从资源中加载位图
HBITMAP  hBitmap = ::LoadBitmap(AfxGetApp()->m_hInstance,
MAKETRESOURCE(IDB_BITMAP1);

3.CBitmap是对BITMAP实现类的封装.

CBitmap有两个重载的成员函数:

BOOL LoadBitmap( LPCTSTR lpszResourceName ); //从文件加载位图

BOOL LoadBitmap( UINT nIDResource );         //从资源加载位图

调用方法如下:

1
2
CBitmap  m_bitmap;
m_bitmap.LoadBitmap(_T( "1.bmp" )); //从文件加载

三者之间的转换关系:

1
2
3
4
5
6
7
HBITMAP  hBitmap;
CBitmap m_bitmap;
BITMAP  bm;
//下面是三者之间的联系:
m_bitmap.Attach(hBitmap); //HBITMAP句柄关联到CBitmap
hBitmap=( HBITMAP )m_bitmap.GetSafeHandle(); //由CBitmap得到相关的HBITMAP句柄
m_bitmap.GetBitmap(&bm);  //由CBitmap得到相应的BITMAP信息

要显示位图,这三者都会用到。但无论是HBITMAP还是CBitmap还是BITMAP,都不能直接显示其对应的位图,需要借助一个内存DC,来完成画图,并将这个绘图后的DC复制到窗口DC中,才能显示。如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
CClientDC dc( this ); //若在OnPaint处理函数中,可用CPaintDC
 
CBitmap  m_Bitmap; //位图类加载
//m_Bitmap.LoadBitmap(_T("1.bmp"));这个函数加载位图文件无效,只能加载资源ID
//要加载位图文件,可用LoadImage函数,如下
HBITMAP  hBitmap = ( HBITMAP )LoadImage(AfxGetInstanceHandle(),
         _T( "1.bmp" ), IMAGE_BITMAP, 0, 0, 0x10);
m_Bitmap.Attach(hBitmap); //将位图对象与位图资源关联
 
//①如果不想加载位图,只想在内存中绘图,可以如下:
//m_Bitmap.CreateCompatibleBitmap(&dc,800,103);//创建DC兼容的位图,须指定大小
 
CDC MemDC; //借助内存DC来显示位图        
MemDC.CreateCompatibleDC(NULL); //创建内存DC 
 
//将内存DC和位图关联,才能在内存中画图
CBitmap *pOldBmp = MemDC.SelectObject(&m_Bitmap);
 
BITMAP BM;         //位图信息
m_Bitmap.GetObject( sizeof (BM), &BM);
 
//复制到窗口DC中
dc.BitBlt(0, 0,                     //目标设备逻辑横、纵坐标 
       BM.bmWidth, BM.bmHeight,  //显示位图的像素宽、高度 
       &MemDC,                   //待显示位图数据的设备情境对象 
       0, 0,                     //源数据中的横、纵坐标
       SRCCOPY);                 //位操作方式
 
MemDC.SelectObject(pOldBmp); //注意这一句,否则加载的位图不能释放,即资源泄漏
//m_Bitmap.DeleteObject();//有的网上资料说需要以下两句,经过测试,不需要,
//MemDC.DeleteDC();       //类在析构时会自动调用

上面这个过程,也就是常说的双缓冲绘图.如果不想显示位图,可以创建一个空白的内存DC,然后在其上绘图.(见①处注释的代码)










本文转自Chinayu201451CTO博客,原文链接: http://blog.51cto.com/9233403/1974474  ,如需转载请自行联系原作者
相关文章
|
6月前
MFC绘图操作
MFC绘图操作
37 0
|
6月前
win32编程 -- GDI绘图操作
win32编程 -- GDI绘图操作
54 0
MFC多线程进行图片的显示
在MFC编程中开始学习都是只利用一个主线程,比较蛋疼的是,当你只用一个主线程进行如播放,查询时,MFC的界面会卡死,你无法进行其他的操作,这时需要进行多线程的编程,在操作时生成一个子线程来进行一些如播放,查询等的费时的操作。 多线程,经常会与对实时性要求比较高的并行运算结合,用来隐藏数据传输过程中用到的等待时间。 基于MFC的多线程在上一篇博客的基础上进行改进: 1.简
2095 0