zoukankan      html  css  js  c++  java
  • BitBlt介绍

    设备上下文绘图有很多种方法。例如通过创建位图画刷,利用其填充一个区域来实现图像的绘制。此外,还可以使用CDC类的位图函数来输出位图到设备上下文中。

    BitBlt 用于从原设备中复制位图到目标设备,语法格式如下:

    BOOLBitBlt(int x,int y,int nWidth,int nHeight,CDC*pSrcDC,int xSrc,int ySrc,DWORDdwRop);

    x:目标矩形区域的左上角x轴坐标点。

    y:目标矩形区域的左上角y轴坐标点。

    nWidth:在目标设备中绘制位图的宽度。

    nHight:在目标设备中绘制位图的高度。

    pSrcDC:源设备上下文对象指针。

    xSrc:源设备上下文的起点x轴坐标,函数从该起点复制位图到目标设备。

    ySrc:源设备上下文的起点y轴坐标,函数从该起点复制位图到目标设备。

    dwRop:光栅操作代码

     

    dwRop有如下选择:

    BLACKNESS           使用黑色填充目标区域

    DSTINVERT              目标矩阵区域颜色取反

    MERGECOPY            使用与运算组合原设备矩形区域的颜色和目标设备的画刷

    MERGEPAINT           使用或运算将反向的源矩形区域的颜色和目标矩形区域的颜色合并

    NOTSRCCOPY          复制源设备区域的反色到目标设备中

    NOTSRCERASE        使用或运算组合源设备区域与目标设备区域的颜色,然后对结果颜色取反

    PATCOPY                  复制源设备当前选中的画刷到目标设备

    PATINVERT               使用异或运算组合目标设备选中的画刷和目标设备区域的颜色

    PATPAINT                 通过或运算组合目标区域当前选中的画刷和源设备区域反转的颜色

    SRCAND                   使用与运算组合源设备和目标设备区域的颜色

    SRCCOPY                 直接复制源设备区域到目标设备中

    SRCERASE               使用与运算组合目标设备区域的反色与源设备区域的颜色

    SRCINVERT              使用异或运算组合源设备区域颜色和目标设备区域颜色

    SRCPAINT                 使用或运算组合源设备区域颜色和目标设备区域颜色

    WHITENESS             使用白色填充目标区域

    StretchBlt与BitBlt不同在于StretchBlt方法能够延伸或收缩位图以适应目标区域的大小。格式如下:

    BOOLStrevhBlt(int x,int y,int nWidth,int nHeight,CDC* pSrcDC,int xSrc,int ySrc,intnSrcWidth,int nSrcHeight,DWORD dwRop);

     

    x:目标矩形区域的左上角x轴坐标点。

    y:目标矩形区域的左上角y轴坐标点。

    nWidth:在目标设备中绘制位图的宽度。

    nHight:在目标设备中绘制位图的高度。

    pSrcDC:源设备上下文对象指针。

    xSrc:源设备上下文的起点x轴坐标,函数从该起点复制位图到目标设备。

    ySrc:源设备上下文的起点y轴坐标,函数从该起点复制位图到目标设备。

    nSrcWidth;需要复制的位图宽度。

    nSrcHeight;需要复制的位图高度。

    dwRop:光栅操作代码。


    下面是两种方法对比程序,程序代码如下:

    void CoutoutBmpView::OnDraw(CDC* pDC)

    {

         COutputBmpDoc* pDoc =GetDocument();//获取文档对象

         ASSERT_VALID(pDoc);//验证文档对象

         CDC memDC;//定义一个设备上下文

         memDC.CreateCompatibleDC(pDC);//创建兼容的设备上下文

         CBitmap bmp;//定义位图对象

         bmp.LoadBitmap(IDB_BKBITMAP);//加载位图

         memDC.SelectObject(&bmp);//选中位图对象

         pDC->BitBlt(30,20,180,180,&memDC,1,1,SRCCOPY);//绘制位图

         //以上是利用BitBlt来绘制位图

         CRect rc(30,20,210,200);//定义一个区域

         CBrush brush(RGB(0,0,0));//定义一个黑色的画刷

         pDC->FrameRect(rc,&brush);//绘制矩形边框

         //只是用来观察两者区别的,绘制一个矩形框

         rc.OffsetRect(220,0);//移动区域

    //下边是利用StretchBlt绘制的位图

         BITMAP BitInfo;//定义位图结构

         bmp.GetBitmap(&BitInfo);//获取位图信息

         int x = BitInfo.bmWidth;//获取位图宽度

         int y = BitInfo.bmHeight;获取位图高度

         pDC->StretchBlt(rc.left,rc.top,rc.Width(),rc.Height(),&memDC,0,0,x,y,SRCCOPY);//绘制位图

         pDC->FrameRect(rc,&brush);//绘制边框

         brush.DeleteObject();//释放画刷

         memDC.DeleteDC();//释放设备上下文

         bmp.DeleteObject();//释放位图对象

    }

  • 相关阅读:
    Pivotal tc Server
    深入剖析jsonp跨域原理
    IE11 el-menu鼠标滑过报错:Error in v-on handler: "TypeError: 对象不支持此操作"
    细嚼JS闭包知识点及案例分析
    关于解决Chrome新版本中cookie跨域携带和samesite的问题处理 ——Ngnix篇
    解决vue本地环境跨域请求正常,版本打包后跨域代理不起作用,请求不到数据的方法——针对vue2.0
    element-ui 的 el-table 上使用无限滚动加载(与自带的 infinite-scroll 结合)——vue2.0
    vue+element-ui table实现滚动加载 ——vue2.0版本
    websocket(一)封装使用
    JS和jQuery将类数组对象转化成数组对象的几种方法
  • 原文地址:https://www.cnblogs.com/zhaoxinshanwei/p/4051415.html
Copyright © 2011-2022 走看看