一、概述:
消息机制是windows程序的典型运行机制,在MFC中有很多已经封装好了的消息,如WM_BTN**等。但是在有些特殊情况下我们需要自定义一些消息去完成一些我们所需要的功能,这时候MFC的向导不能帮助我们做到这一点。对此,我们可以通过添加相应的代码去完成这个功能。
二、实现方法:
添加自定义消息操作如下:
1. 建立MFC工程,如基于对话框的应用程序,Test。
2. 在资源中添加要处理的消息的值,即在CTestDlg.h中添加 如下代码。 (因为很多MFC的消息是在WM_USER内的,所以这里用比WM_USER大的消息)
#define WM_MyMessage (WM_USER+100)
3. 声明消息处理函数,在CTestDlg.h中添加如下代码:
class CTestDlg : public CDialog { protected: …… // 生成的消息映射函数 …… afx_msg LRESULT OnMyMessage(WPARAM wParam, LPARAM lParam); // add lyw DECLARE_MESSAGE_MAP() ……
4. 添加消息映射处理,在CTestDlg.cpp中人找到如下部分添加代码:
BEGIN_MESSAGE_MAP(CTestDlg, CDialog)
……
ON_MESSAGE(WM_MyMessage, OnMyMessage)
END_MESSAGE_MAP()
5. 实现自己的自定义消息处理:
LRESULT CTestDlg::OnMyMessage(WPARAM wParam, LPARAM lParam) { //MessageBox("recv msg success"); //添加自己的消息处理 …… return 0; }
6. 如果要发送一个自定义的消息,需要使用代码
SendMessage( WM_MyMessage, 0, 0); 或者 PostMessage(WM_MyMessage, 0, 0);
如果要定义系统唯一的消息让多个应用程序去处理,不同之处如下:
1. 把上面2步骤中的宏 #define WM_MyMessage (WM_USER+100) 使用如下代码代替: static UINT WM_MyMessage = RegisterWindowMessage("myMessage"); 2. 上面4步骤中的代码用如下代替: BEGIN_MESSAGE_MAP(CTestDlg, CDialog) …… ON_REGISTERED_MESSAGE(WM_MyMessage, OnMyMessage) END_MESSAGE_MAP() 3.测试消息时,如果要让多个应用程序都接收到这个消息,需要使用: ::SendMessage(HWND_BROADCAST, WM_MyMessage, 0, 0);
综合概述如下:
1. 在头文件stdafx.h中增加一个自定义消息宏 #define WM_USER_THREADEND WM_USER + 1 2. 在于增加新消息的窗口或对话框类的头文件中增加一个回调函数声明,注意要声明为public afx_msg LRESULT OnUserThreadend(WPARAM wParam, LPARAM lParam); 3. 在窗口或对话框的cpp文件的BEGIN_MESSAGE_MAP,END_MESSAGE_MAP 中增加一行 ON_MESSAGE(WM_USER_THREADEND, OnUserThreadend) 4. 在窗口或对话框的cpp文件中增加回调函数的实现,如: LRESULT ThreadDialog::OnUserThreadend(WPARAM wParam, LPARAM lParam) { TRACE("WM_USER_THREADEND message /n"); return 0; } 5. 自定义消息的触发 ::PostMessage(GetSafeHwnd(), WM_USER_THREADEND, 0, 0); 其中GetSafeHwnd()得到了一个当前窗口的句柄,此消息将发给当前窗口,如果想发送消息给其它窗口只需改变这个句柄,前提是目的窗口也实现了此消息的处理函数。