菜单命令的路由

一、windows消息分类

 

标准消息:除了WM_COMMAND之外,所以以WM_开头的消息都是标准消息。从CWnd派生的类都可以接收到这类消息

命令消息:来自菜单或者工具栏按钮的消息。这类消息都是以WM_COMMAND形式呈现。在MFC中,通过菜单项的标识(ID)来区

分不同的命令消息;在SDK中,通过消息的wParam参数识别。从CCmdTarget派生的类,都可以接收到这类消息;

通告消息:由控件产生的消息,例如按钮的单击、列表框的选择都会产生这类消息,目的是为了向其父窗口(通常是对话框)通知事件的发

生。这类消息也是以WM_COMMAND形式呈现的。从CCmdTarget派生的类都能响应这类消息。


从MSDN提供的MFC层次结构图中可以发现,CWnd类实际上派生于CCmdTarget类,即CMnd是子类,CCmdTarget是父类。父类能接受命令消息和通告消息。CWnd类除了能接受命令消息外还能接受标准消息。

二、各种消息路由的差别

菜单命令的路由_第1张图片

 仔细对比在OnWndMsg这一步骤之前,都和标准消息的映射是一样的。只是命令消息适用的ON_COMMAND宏。

详细的,首先由AfxWndProc函数接收操作系统发出的消息,由这个消息对所有的消息进行处理;然后函数AfxWndProc调用函数

AfxCallWndProc进行消息处理,这里一个进步是把对句柄的操作转换成对CWnd对象的操作;函数又AfxCallWndProc调用CWnd类的方法

WindowProc进行消息处理;WindowProc调用OnWndMsg进行正式的消息处理,即把消息派送到相关的方法中去处理。这个函数会对到来的

消息进行一个类型判断,如果是标准消息,就利用MFC消息映射机制来查找时哪个类响应了当前这个小心,并调用相应的消息映射函数,完

成对消息的处理;如果是命令消息,它就会交由OnCommand这个函数来处理,在这个函数中完成这个消息的路由;如果是通告消息,它将

交由OnNotify这个函数来处理,该函数完成通告消息的路由。二者最后都会调用OnCmdMsg函数。


三、菜单消息命令路由

具体过程:当点击某个菜单项时,最先接收到这个菜单命令消息的是框架类。框架类将把接收到的这个消息交给它的子窗口,即视类,由视类首先进行处理。视类根据命令消息映射机制查找自身是否对此消息进行了响应,如果响应了,就调用响应响应函数对这个消息进行处理,消息路由过程结束。如果视类没有对此命令响应,就交由文档类,文档类同样查找自己是否对此消息进行了响应,如果响应了,就调用响应响应函数对这个消息进行处理,消息路由过程结束。如果文档类没有做出响应,再把这个命令消息交还给视类,后者又把该消息交还给框架类。框架类再查找.....如果框架类也没有响应,则交给应用程序类,由后者进行处理。


可知,父类先接受消息,子类先处理响应。


你可能感兴趣的:(C++,菜单)