zoukankan      html  css  js  c++  java
  • 双缓冲技术绘图

     当数据量很大时,绘图可能需要几秒钟甚至更长的时间,而且有时还会出现闪烁现象,为了解决这些问题,可采用双缓冲技术来绘图。
      双缓冲即在内存中创建一个与屏幕绘图区域一致的对象,先将图形绘制到内存中的这个对象上,再一次性将这个对象上的图形拷贝到屏幕上,这样能大大加快绘图的速度。双缓冲实现过程如下:
      1、在内存中创建与画布一致的缓冲区
      2、在缓冲区画图
      3、将缓冲区位图拷贝到当前画布上
      4、释放内存缓冲区
      在图形图象处理编程过程中,双缓冲是一种基本的技术。我们知道,如果窗体在响应WM_PAINT消息的时候要进行复杂的图形处理,那么窗体在重绘时由于过频的刷新而引起闪烁现象。解决这一问题的有效方法就是双缓冲技术。因为窗体在刷新时,总要有一个擦除原来图象的过程OnEraseBkgnd,它利用背景色填充窗体绘图区,然后在调用新的绘图代码进行重绘,这样一擦一写造成了图象颜色的反差。当WM_PAINT的响应很频繁的时候,这种反差也就越发明显。于是我们就看到了闪烁现象。 
      我们会很自然的想到,避免背景色的填充是最直接的办法。但是那样的话,窗体上会变的一团糟。因为每次绘制图象的时候都没有将原来的图象清除,造 成了图象的残留,于是窗体重绘时,画面往往会变的乱七八糟。所以单纯的禁止背景重绘是不够的。我们还要进行重新绘图,但要求速度很快,于是我们想到了使用 BitBlt函数。它可以支持图形块的复制,速度很快。我们可以先在内存中作图,然后用此函数将做好的图复制到前台,同时禁止背景刷新,这样就消除了闪 烁。以上也就是双缓冲绘图的基本的思路CreateCompatibleBitmap

    该函数创建与指定的设备环境相关的设备兼容的位图

    由CreateCompatibleBitmap函数创建的位图的颜色格式与CDC::m_hdc标识的设备的颜色格式匹配。该位图可以选入任意一个与原设备兼容的内存设备环境中

    GDI:

    CDC *pDC=GetDC();
    CDC memdc,tempdc;
    memdc.CreateCompatibleDC(pDC);
    tempdc.CreateCompatibleDC(pDC);
    CBitmap tembmp,MemBmp;
    tembmp.LoadBitmap(IDB_BITMAP1);
    MemBmp.CreateCompatibleBitmap(pDC,800,600);
    tempdc.SelectObject(&bmp);
    memdc.SelectObject(&bitmap);
    memdc.BitBlt(0,0,800,600,&tempdc,0,0,SRCCOPY);
    

    //......

    pDC->BitBlt(0,0,800,600,&memdc,0,0,SRCCOPY);

    GDI+:

    Bitmap bitmap(width, height);    // 创建图形对象,也就是缓冲区
    Graphics g_mem(&bitmap);         // 从图形对象中创建GDI+绘图对象
    Graphics g(pDC->GetSafeHdc());    // 从Device Context中创建另一GDI+绘图对象,作为前台显示
    
    // 开始在缓冲区中绘图
    g_mem.DrawLine(&pen, ....);
    ...
    // 显示----------------------------------------
    g.DrawImage(&bitmap, 0, 0, width, height);
    
    
    



     

  • 相关阅读:
    [二叉树算法]关于层次遍历二叉树的一些算法总结
    数据库事务并发访问产生的问题及四种事务隔离级别
    当relative遇上z-index,阻断事件捕获
    关于CAS操作
    LRU算法与LRUCache
    Hadoop2.x 关于日志文件位置
    推荐系统架构图——我的软件工程概论课设
    文件上传+解析漏洞
    命令执行漏洞
    SSRF漏洞
  • 原文地址:https://www.cnblogs.com/hgy413/p/3693620.html
Copyright © 2011-2022 走看看