C++中BitBlt的使用方法详解
BitBlt 该函数对指定的源设备环境区域中的像素进行位块(bit_block)转换,以传送到目标设备环境。 原型: BOOL BitBlt( HDC hdcDest,int nXDest,int nYDest,int nWidth,int nHeight,HDC hdcSrc,int nXSrc,int nYSrc,DWORD dwRop); 参数: hdcDest:指向目标设备环境的句柄。 nXDest、nYDest:指定目标矩形区域左上角的X轴和Y轴逻辑坐标 nWidth、nHeight:指定源和目标矩形区域的逻辑宽度和逻辑高度。 hdcSrc:指向源设备环境的句柄。 nXSrc、nYSrc:指定源矩形区域左上角的X轴和Y轴逻辑坐标。 dwRop:指定光栅操作代码。这些代码将定义源矩形区域的颜色数据,如何与目标矩形区域的颜色数据组合以完成最后的颜色。下面列出了一些常见的光栅操作代码:
完整的光栅操作(ROP)码,参见 Ternary Raster Operations. 返回值: 如果函数成功,那么返回值非零;如果函数失败,则返回值为零。调用GetLastError函数获取扩展错误信息。 说明: 如果在源设备环境中可以实行旋转或剪切变换,那么函数BitBlt返回一个错误。 如果存在其他变换(并且目标设备环境中匹配变换无效),那么目标设备环境中的矩形区域将在需要时进行拉伸、压缩或旋转。 如果源和目标设备环境的颜色格式不匹配,那么BitBlt函数将源场景的颜色格式转换成能与目标格式匹配的格式。 当正在记录一个增强型图元文件时,如果源设备环境标识为一个增强型图元文件设备环境,那么会出现错误。 并不是所有的设备都支持BitBlt函数。更多信息,调用GetDeviceCaps 函数,将第二个参数赋值为RC_BITBLT来查看设备是否支持。(For more information,see the RC_BITBLT raster capability entry in the GetDeviceCaps function,as well as the MaskBlt and StretchBlt functions. ) 如果源和目标设备环境代表不同的设备,那么BitBlt函数返回错误。 更多关于从右到左向位块传输显示信息(For information about blitting to displays with right-to-left orientations),参见 Creating Bitmaps。 在Windows CE 1.0和1.01版中,参数dwRop只可以指定为下列值:SRCCOPY、SRCAND、SRCPAINT、SRCINVERT。在Windows CE 2.0及以后版中,参数dwRop可以是任何ROP3代码值。 下面是MSDN上的例子: HBITMAP CopyBitmap( HBITMAP hbm) { HDC hdcSrc = CreateCompatibleDC(NULL); HDC hdcDst = CreateCompatibleDC(NULL); HBITMAP hbmOld,hbmOld2,hbmNew; BITMAP bm; GetObject(hbm,sizeof(bm),&bm); hbmOld = SelectObject(hdcSrc,hbm); hbmNew = CreateBitmap( bm.bmWidth,bm.bmHeight,bm.bmPlanes,bm.bmBitsPixel,NULL); hbmOld2 = SelectObject(hdcDst,hbmNew); BitBlt(hdcDst,bm.bmWidth,hdcSrc,SRCCOPY); SelectObject(hdcSrc,hbmOld); SelectObject(hdcDst,hbmOld2); DeleteDC(hdcSrc); DeleteDC(hdcDst); return hbmNew; } 如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |