WM_DRAWITEM是如何产生的
在自定义mfc控件,例如按钮时,网络上的博文都推荐重写DrawItem虚函数,它由WM_DRAWITEM驱动。
这当然没有问题,但是,我被一个问题深深的缠住了,WM_DRAWITEM究竟是怎么产生的呢?
Microsoft learn里的描述是这样的:
Sent to the parent window of an owner-drawn button, combo box, list box, or menu when a visual aspect of the button, combo box, list box, or menu has changed.
“外观发生变化时”,发生变化控件需要重绘,重绘不是由WM_PAINT消息引起的吗,难道重绘ui时操作系统会同时发出WM_PAINT和WM_DRAWITEM消息?
我注意到只有被标注为owner-drawn的按钮、复选框、列表框或菜单才会发出这个消息,所以,应该不是同时发出2个消息,而是WM_DRAWITEM消息是由WM_PAINT引起的。
我认为可能是如下流程:
假如存在一个MyButton类,WM_PAINT消息进入到该类的窗口事件处理函数中,该函数会检查owner-drawn标志,如果该标志存在,则发出WM_DRAWITEM消息给它的父窗口,再由父窗口调用MyButton的DrawItem虚函数。