BeginPaint 和 GetDC 的一个区别
这个问题是在做9*9乘法表这个课后习题发现的~~
先给出我的结论:注意在 WM_PAINT 下不要使用hdc = GetDC(hwnd)的方式,因为这样会不停的触发WM_PAINT消息!
东西看上去就会闪烁!!
LRESULT CALLBACK WndProc(HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam) { HDC hdc; PAINTSTRUCT ps; RECT rect; int i,j=1,x,y = 0; TCHAR szBuffer[20]; int xpos=100,ypos=100; switch (message) { case WM_PAINT://写在WM_PAINT里九九乘法表会闪烁,貌似一直都会有重绘消息产生!!!! hdc = BeginPaint(hwnd, &ps); wsprintf(szBuffer,TEXT("九九乘法表")); TextOut(hdc,xpos,ypos,szBuffer,lstrlen(szBuffer)); ypos += 20; GetClientRect(hwnd,&rect); for (i = 1; i <= 9; i++) { x = i; for (j = 1; j <= i; j++) { y = j; wsprintf(szBuffer,TEXT("%d * %d = %d"),x,y,x*y); TextOut(hdc,xpos,ypos,szBuffer,lstrlen(szBuffer)); xpos += 100; } xpos = 100; ypos += 20; } EndPaint(hwnd,&ps); return 0; case WM_LBUTTONDOWN: return 0; case WM_DESTROY: PostQuitMessage(0); return 0; } return DefWindowProc(hwnd, message, wParam, lParam); }
2、采用 GetDC 的方式,“九九乘法表”会闪烁,貌似一直都会有重绘消息产生!!!!
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 | //显示9*9乘法表,写在WM_PAINT里九九乘法表会闪烁,貌似一直都会有重绘消息产生!!!! LRESULT CALLBACK WndProc( HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam) { HDC hdc; PAINTSTRUCT ps; RECT rect; int i,j=1,x,y = 0; TCHAR szBuffer[20]; int xpos=100,ypos=100; switch (message) { case WM_PAINT: hdc = GetDC(hwnd); wsprintf(szBuffer,TEXT( "九九乘法表" )); TextOut(hdc,xpos,ypos,szBuffer,lstrlen(szBuffer)); ypos += 20; GetClientRect(hwnd,&rect); for (i = 1; i <= 9; i++) { x = i; for (j = 1; j <= i; j++) { y = j; wsprintf(szBuffer,TEXT( "%d * %d = %d" ),x,y,x*y); TextOut(hdc,xpos,ypos,szBuffer,lstrlen(szBuffer)); xpos += 100; } xpos = 100; ypos += 20; } ReleaseDC(hwnd,hdc); return 0; case WM_LBUTTONDOWN: return 0; case WM_DESTROY: PostQuitMessage(0); return 0; } return DefWindowProc(hwnd, message, wParam, lParam); } |
总结:
1、所谓的无效区域就是Update Region (需要跟新的区域),有效区域就是不需要跟新的区域。 如果存在无效区域,系统就会产生WM_PAINT 消息。
2、无效区域是可以被累加的,当队列中其他消息都被带走时,只剩下WM_PAINT 消息时,无效区域 统一重绘。
3、并不是重绘了,无效区域就消失了,使无效区域消失的方法就是调用BeginPaint 。所以如果不在 WM_PAINT消息处理函数中调用BeginPaint ,那么无效区域总是存在,从而会不停的产生WM_PAINT 消息。所以就会不停进入WM_PAINT 消息处理函数~~
作者:宋桓公
出处:http://www.cnblogs.com/douzi2/
如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!欢迎各位转载,但是未经作者本人同意,转载文章之后必须在文章页面明显位置给出作者和原文连接,否则保留追究法律责任的权利。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现