Invalidate(TRUE)与Invalidate(FALSE)区别

Invalidate(TRUE)与Invalidate(FALSE)区别篇一 Invalidate false 不擦除背景 直接画 Invalidate true 擦除背景 InvalidateRe 只是增加重绘区域 在下次 WM PAINT 的时候才生效 InvalidateRe 函数中的参数 TRUE 表示系统会在你画之前用背景色将所选区域覆盖一次 默认背景色为白色 可以通过设置 BRUSH 来改变背景色 Invalidate 之后 MFC 的 顺便了 OnPa

篇一:

篇二:

使用Invalidate(TRUE)函数时,它会向消息队列中添加了WM_ERASEBKGND和WM_PAINT两个消息。

使用Invalidate(FALSE)函数时,它只会向消息队列中添加了WM_PAINT消息。

WM_ERASEBKGND消息的作用以背景色填充客户区,因此他会将之前绘制的图像情况,然后响应WM_PAINT消息后,会调用OnPaint函数,进行响应图像绘制工作。故Invalidate(TRUE)相当于将原来画的内容清空后,重新绘制。

而Invalidate(TRUE)只发送WM_PAINT消息,会调用OnPaint函数,进行响应图像绘制工作。故Invalidate(TRUE)的作用相当于在原来绘图的基础上继续画图。

打个比方:小明准备在黑板上画画,他准备画一只鸡和一只鸭

情形一:当画完小鸡后,小明觉得画的不像,于是将黑板擦擦除所画的小鸡,重新画。这相对于Invalidate(TRUE)函数的处理过程。

情形二:当画完小鸡后,小明觉得画得想当逼真,于是在此基础上继续画另一只鸭。这相对于Invalidate(FALSE)处理过程。

实验源码(对话框工程,在OnPaint函数中添加代码):

CPaintDC dc(this); int x = rand()%200; int y = rand() % 200; dc.Ellipse(CRect(CPoint(x, y), CSize(100, 100))); x = rand() % 200; y = rand() % 200; CBrush brush(RGB(0, 0, 255)); dc.FillRect(CRect(CPoint(x, y), CSize(100, 100)), &brush); 
CPaintDC dc(this); int x = rand()%200; int y = rand() % 200; dc.Ellipse(CRect(CPoint(x, y), CSize(100, 100))); x = rand() % 200; y = rand() % 200; CBrush brush(RGB(0, 0, 255)); dc.FillRect(CRect(CPoint(x, y), CSize(100, 100)), &brush); 

在OnInitDialog函数中设置定时器:

 

SetTimer(1, 1000, NULL);

添加WM_TIME消息响应,在OnTimer函数中添加:

Invalidate(TRUE);

运行结果:

 

在OnInitDialog函数中设置定时器:

 

SetTimer(1, 1000, NULL);

添加WM_TIME消息响应,在OnTimer函数中添加:

Invalidate(TRUE);

运行结果:

Invalidate(TRUE)与Invalidate(FALSE)区别

而将Invalidate(TRUE)改为:

Invalidate(FALSE);

运行结果为:

Invalidate(TRUE)与Invalidate(FALSE)区别

可见:Invalidate(FALSE)不会清空之前所画图像。

如果你想用Invalidate(TRUE)来实现Invalidate(FALSE)一样的效果,你可以添加对WM_ERASEBKGND消息响应的函数,修改OnEraseBkgnd函数为:

BOOL CaaDlg::OnEraseBkgnd(CDC* pDC) { return TRUE; } 
 BOOL CaaDlg::OnEraseBkgnd(CDC* pDC) { return TRUE; }

此时Invalidate(TRUE)与Invalidate(FALSE)的效果是一样的。

实际应用:

/*Invalidate(); 整个界面刷新 Invalidate(TRUE); 整个界面背景刷新 Invalidate(FALSE); 整个界面背景局部刷新 InvalidateRect(CRect,TRUE); 选定区域刷新 UpDataWindows()*/ //实际操作相关代码如下 ITrainViewSizeStategy *pStategy = m_pMainFrame->m_cControlSizeStrategy.Get_ITrainViewSizeStategyPtr(); //面板显示控件 CRect rtModularBar = pStategy->Get_Modular1ContainWndRegion(); //脚本 CRect rtScriptSelBtn = pStategy->Get_ScripSelectButtonRegion(); CRect rtModularScriptSel; rtModularScriptSel.UnionRect(&rtModularBar,&rtScriptSelBtn); InvalidateRect(rtModularScriptSel,TRUE); //控件区域大小函数如下: //返回脚本选择按钮的位置区域 CRect C1280X768TVSizeStrategy::Get_ScripSelectButtonRegion() { return CRect( CPoint(5,505), CSize(156,27) ); } //返回面板1容器控件的位置区域 CRect C1280X768TVSizeStrategy::Get_Modular1ContainWndRegion() { return CRect( CPoint(0,539), CSize(165,107) ); }

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/225291.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月17日 上午9:38
下一篇 2026年3月17日 上午9:38


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号