MFC如何显示位图

void CBitmapView::wtj_paint()
{
  CDC *pDC;
  pDC=GetDC();
  CBitmap wtj_bitmap;
  CDC dcMemory;
  //?CDC *pDC;
  wtj_bitmap.LoadBitmap(IDB_BITMAP1);
  BITMAP bmInfo;
  wtj_bitmap.GetObject(sizeof(bmInfo),&bmInfo);
  dcMemory.CreateCompatibleDC(pDC);
  dcMemory.SelectObject(&wtj_bitmap);
  pDC->BitBlt(100,100,
 bmInfo.bmWidth,??bmInfo.bmHeight,
  &dcMemory,0,0,SRCCOPY);
 ReleaseDC(pDC);
}
其中我还是不大明白,为什么wtj_bitmap.GetObject()函数可以这样用,可以说是把wtj_bitmap的信息copy到了bmInfo中。昨天我都还在想,怎样才能把位图的长和宽的信息取出来!哦解决了!

简单的记一下如何显示位图:

1、声明一个CBitmap对象,并从资源中加位图。

2、创建一个兼容的DC,用CDC的成员函数CreateCompatibleDC。

3、用CDC的成员函数SelectObject将位图选入到兼容DC中。

4、用CDC的成员函数BitBlt来输出位图。

就这样了,一个完整的位图说显示了!

/

如下的改动可以使位图在窗口中全部显示,自动拉伸!

void CBitmapView::wtj_paint()
{
  CDC *pDC;
  CRect rect;
  GetWindowRect(rect);
//GetClientRect(rect);

  pDC=GetDC();
  
CBitmap wtj_bitmap;
  CDC dcMemory;
//CDC *pDC;
  wtj_bitmap.LoadBitmap(IDB_BITMAP1);
  BITMAP bmInfo;
  wtj_bitmap.GetObject(sizeof(bmInfo),&bmInfo);
  dcMemory.CreateCompatibleDC(pDC);
  dcMemory.SelectObject(&wtj_bitmap);
  pDC->StretchBlt(0,0,
  rect.Width(),rect.Height(),
  &dcMemory,
  0,0,
  bmInfo.bmWidth,bmInfo.bmHeight,
  SRCCOPY);
//pDC->
/*
  pDC->BitBlt(100,100,
  bmInfo.bmWidth,??bmInfo.bmHeight,
  &dcMemory,0,0,SRCCOPY);
*/
ReleaseDC(pDC);
}

其中红色部份,书上说的很清楚,一个是取得窗口客户区,一个是取得窗口活动区域!两者有什么区别呢?在实际的应用中没有体现出来!

**一点小的问题,我看到书上说明,在Windows中显示位图,与计算机的硬件是相关的,因为不同的显示器,不同的显示卡会有不同的结果,更头疼的可能是要在打印机上实现,都会有一些问题!希望在以后的学习中自己总结一下,也参考一些别人成功的例子!就MFC这一些,技术还是比较成熟的!

如何打开一个BMP文件呢?

再来改进这断代码:

void CBitmapView::wtj_paint()
{
  CDC *pDC;
  CRect rect;
  GetWindowRect(rect);
//GetClientRect(rect);
  pDC=GetDC();
  CBitmap wtj_bitmap;
  CDC dcMemory;
//CDC *pDC;

//wtj_bitmap.LoadBitmap(IDB_BITMAP1);

  HBITMAP hbitmap=(HBITMAP)LoadImage(NULL,
  m_bmPath,
  IMAGE_BITMAP,
  0,0,
  LR_LOADFROMFILE);
  wtj_bitmap.Attach(hbitmap);
  BITMAP bmInfo;
  wtj_bitmap.GetObject(sizeof(bmInfo),&bmInfo);
  dcMemory.CreateCompatibleDC(pDC);
  dcMemory.SelectObject(&wtj_bitmap);
  pDC->StretchBlt(0,0,
  rect.Width(),rect.Height(),
  &dcMemory,
  0,0,
  bmInfo.bmWidth,bmInfo.bmHeight,
  SRCCOPY);
//pDC->
/*
  pDC->BitBlt(100,100,
  bmInfo.bmWidth,??bmInfo.bmHeight,
  &dcMemory,0,0,SRCCOPY);
*/?
 ReleaseDC(pDC);
}

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是将MFC 24位转换为单色位的示例代码: CBitmap bmp24; bmp24.LoadBitmap(IDB_BITMAP24); //加载24位 BITMAPINFO bmi24; ZeroMemory(&bmi24, sizeof(BITMAPINFO)); //清空结构体 bmi24.bmiHeader.biSize = sizeof(BITMAPINFOHEADER); bmp24.GetBitmap(&bmi24.bmiHeader, sizeof(BITMAPINFOHEADER)); //获取24位像素信息 //创建单色位 BITMAPINFO bmi1; ZeroMemory(&bmi1, sizeof(BITMAPINFO)); bmi1.bmiHeader.biSize = sizeof(BITMAPINFOHEADER); bmi1.bmiHeader.biWidth = bmi24.bmiHeader.biWidth; bmi1.bmiHeader.biHeight = bmi24.bmiHeader.biHeight; bmi1.bmiHeader.biPlanes = 1; bmi1.bmiHeader.biBitCount = 1; bmi1.bmiHeader.biCompression = BI_RGB; //计算单色位像素信息 BYTE* pBits24 = new BYTE[bmi24.bmiHeader.biSizeImage]; bmp24.GetBitmapBits(bmi24.bmiHeader.biSizeImage, pBits24); BYTE* pBits1 = new BYTE[bmi1.bmiHeader.biSizeImage]; int rowWidth24 = ((bmi24.bmiHeader.biWidth * 24 + 31) / 32) * 4; int rowWidth1 = ((bmi1.bmiHeader.biWidth * 1 + 31) / 32) * 4; for (int y = 0; y < bmi24.bmiHeader.biHeight; y++) { for (int x = 0; x < bmi24.bmiHeader.biWidth; x++) { int index24 = y * rowWidth24 + x * 3; int index1 = y * rowWidth1 + x / 8; BYTE gray = (BYTE)(0.299 * pBits24[index24 + 2] + 0.587 * pBits24[index24 + 1] + 0.114 * pBits24[index24]); //计算灰度值 BYTE bit = gray > 128 ? 0 : 1; //将灰度值转为二值像 pBits1[index1] |= (bit << (7 - x % 8)); //将二值像写入单色位 } } //创建单色位 CBitmap bmp1; bmp1.CreateBitmapIndirect(&bmi1, pBits1); //释放内存 delete[] pBits24; delete[] pBits1; //显示单色位 CDC* pDC = GetDC(); CDC memDC; memDC.CreateCompatibleDC(pDC); CBitmap* pOldBmp = memDC.SelectObject(&bmp1); pDC->BitBlt(0, 0, bmi1.bmiHeader.biWidth, bmi1.bmiHeader.biHeight, &memDC, 0, 0, SRCCOPY); memDC.SelectObject(pOldBmp); ReleaseDC(pDC);

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值