双缓冲技术绘图原理及简单的VC实现
2017-09-10 15:46
260 查看
1、Windows 绘图原理
我们在 Windows 环境下看到各种元素,如菜单、按钮、窗口、图像,从根本上说,都是“画”出来的。这时的屏幕,就相当于一块黑板,而 Windows 下的各种 GDI 要素,如画笔、画刷等,就相当于彩色粉笔了。我们在黑板上手工画图时,是一笔一划的,电脑亦然。只不过电脑的速度比手工快的太多,所以在我们看起来好像所有的图形文字都是同时出现的。
2、普通绘图方式的局限
上述绘图方式我们暂且称之为普通绘图方式吧。虽然这种方式能满足相当一部分的绘图需要,但是当要绘制的对象太复杂,尤其是含有位图时,电脑便力不从心了。这时的画面会显示的很慢,对于运动的画面,会给人“卡”住了的感觉,总之一个字:不爽。
3、解决之道:双缓冲
双缓冲的原理可以这样形象的理解:把电脑屏幕看作一块黑板。首先我们在内存环境中建立一个“虚拟“的黑板,然后在这块黑板上绘制复杂的图形,等图形全部绘制完毕的时候,再一次性的把内存中绘制好的图形“拷贝”到另一块黑板(屏幕)上。采取这种方法可以提高绘图速度,极大的改善绘图效果。下面是原理图:
实现过程如下:
1、在内存中创建与画布一致的缓冲区
2、在缓冲区画图
3、将缓冲区位图拷贝到当前画布上
4、释放内存缓冲区
相关的VC函数:
1)、为屏幕 DC 创建兼容的内存DC:CreateCompatibleDC()
if(!m_dcMemory.CreateCompatibleDC(NULL)) // CDC m_dcMemory; { ::PostQuitMessage(0); }
2)、创建位图:CreateCompatibleBitmap()
m_Bmp.CreateCompatibleBitmap(&m_dcMemory, rt.Width(), rt.Height()); // CBitmap m_Bmp;
3)、把位图选入设备环境:SelectObject(),可以理解为选择画布
::SelectObject(m_dcMemory.GetSafeHdc(), m_Bmp);
4)、把绘制好的内存图形“拷贝“到屏幕上:BitBlt()
pdcView->BitBlt(0, 0, rt.Width(), rt.Height(), &m_dcMemory, 0, 0, SRCCOPY);
相关文章推荐
- 双缓冲技术绘图原理及简单的VC实现
- 双缓冲技术绘图原理及简单的VC实现
- 单点登录原理与简单实现
- hrtimer的简单使用 + 原理和实现
- 简单实现验证码随机数(其实原理很简单就是一堆图片,然后点击随机改变图片的src属性)
- VC++实现位图显示透明效果--实现原理
- VC简单实现播放音乐
- VC++下命名管道编程的原理及实现
- 单点登录原理与简单实现
- dubbo学习过程、使用经验分享及实现原理简单介绍
- JSONP原理及简单实现
- VC++大数据量绘图时无闪烁刷屏技术实现
- 标签云 tagCloud 简单实现原理(还算好看)
- 哈希表原理及hashmap简单实现
- 单点登录原理与简单实现
- vc平台下的简单PID实现
- VC++大数据量绘图时无闪烁刷屏技术实现
- iOS最简单绘图实现
- 深入浅出话VC++(3)——VC++实现绘图操作
- VC按钮自绘的简单实现