📄 ew_msgmap.h
字号:
/*--------------------------------------------------------------------------
EW_MsgMap.h - 消息映射表结构以及宏定义的头文件
本程序是FishGUI软件的一部分
版权所有 (C) 2003,2004 王咏武
http://www.contextfree.net/wangyw/
----------------------------------------------------------------------------
作者对 FishGUI 软件及其所有源代码授权如下:
允许任何个人、组织、机构、企业无偿获得、修改、使用、重新发布 FishGUI 软
件及其源代码,或按照有偿或者无偿的方式发行基于 FishGUI 源代码的全部或部
分内容开发的软件产品,——但行使以上权利时,须遵守以下约定:
1、重新发布 FishGUI 软件及其源代码时,不得隐去软件及其源代码中原有的版
权信息和开发者标识。
2、发行基于 FishGUI 源代码的全部或部分内容开发的软件产品时,必须在产品
的显著位置标明以下字样:
【本产品的一部分功能是基于王咏武在 FishGUI 软件中的工作完成的】
3、在正式出版物中引用 FishGUI 的文档、源代码或注释内容的,应注明软件的
原作者为王咏武。
--------------------------------------------------------------------------*/
/*! \addtogroup Framework
* @{
*/
/*! \file
* \brief 消息映射表结构以及宏定义的头文件
*/
#ifndef EW_MSGMAP_H_HEADER_INCLUDED_C0AD453B
#define EW_MSGMAP_H_HEADER_INCLUDED_C0AD453B
#include "../Utility/EW_Utility.h"
#include "../OSAdaptor/EW_OSAdaptor.h"
/*! \defgroup MsgMap_Define 消息映射表定义宏 */
/*! @{ */
/*! \brief 定义消息映射表的宏 */
#define DECLARE_MESSAGE_MAP() \
private: \
static const EW_MSGMAP_ENTRY m_MsgEntries[]; \
protected: \
static const EW_MSGMAP m_MsgMap; \
virtual const EW_MSGMAP * GetMessageMap() const; \
/*! \brief 为消息映射表赋初值的宏 */
#define BEGIN_MESSAGE_MAP(theClass, baseClass) \
const EW_MSGMAP * theClass::GetMessageMap() const \
{ return & theClass::m_MsgMap; } \
const EW_MSGMAP theClass::m_MsgMap = \
{ & baseClass::m_MsgMap, & theClass::m_MsgEntries[0] }; \
const EW_MSGMAP_ENTRY theClass::m_MsgEntries[] = \
{ \
/*! \brief 定义\ref EW_MSG_DRAW消息和处理函数的对应关系的宏 */
#define ON_DRAW(msgCallback) \
{ EW_MSG_DRAW, 0, 0, (EW_PMSG_vv)(EW_PMSG_vd)& msgCallback }, \
/*! \brief 定义\ref EW_MSG_DRAW_REQUEST消息和处理函数的对应关系的宏 */
#define ON_DRAWREQUEST(msgCallback) \
{ EW_MSG_DRAW_REQUEST, 0, 0, (EW_PMSG_vv)(EW_PMSG_vm)& msgCallback }, \
/*! \brief 定义\ref EW_MSG_KEY消息和处理函数的对应关系的宏 */
#define ON_KEY(msgCallback) \
{ EW_MSG_KEY, 0, 0, (EW_PMSG_vv)(EW_PMSG_bm)& msgCallback }, \
/*! \brief 定义\ref EW_MSG_KEY, \ref FKS_DOWN消息和处理函数的对应关系的宏 */
#define ON_KEYDOWN(msgCallback) \
{ EW_MSG_KEY, FKS_DOWN, 0, (EW_PMSG_vv)(EW_PMSG_bm)& msgCallback }, \
/*! \brief 定义\ref EW_MSG_KEY, \ref FKS_UP消息和处理函数的对应关系的宏 */
#define ON_KEYUP(msgCallback) \
{ EW_MSG_KEY, FKS_UP, 0, (EW_PMSG_vv)(EW_PMSG_bm)& msgCallback }, \
/*! \brief 定义\ref EW_MSG_MOUSE消息和处理函数的对应关系的宏 */
#define ON_MOUSE(msgCallback) \
{ EW_MSG_MOUSE, 0, 0, (EW_PMSG_vv)(EW_PMSG_bm)& msgCallback }, \
/*! \brief 定义\ref EW_MSG_MOUSE, \ref FMS_LBUTTONDOWN消息和处理函数的对应关系的宏 */
#define ON_LBUTTONDOWN(msgCallback) \
{ EW_MSG_MOUSE, FMS_LBUTTONDOWN, 0, (EW_PMSG_vv)(EW_PMSG_bm)& msgCallback }, \
/*! \brief 定义\ref EW_MSG_MOUSE, \ref FMS_LBUTTONUP消息和处理函数的对应关系的宏 */
#define ON_LBUTTONUP(msgCallback) \
{ EW_MSG_MOUSE, FMS_LBUTTONUP, 0, (EW_PMSG_vv)(EW_PMSG_bm)& msgCallback }, \
/*! \brief 定义\ref EW_MSG_MOUSE, \ref FMS_LBUTTONUP消息和处理函数的对应关系的宏 */
#define ON_RBUTTONUP(msgCallback) \
{ EW_MSG_MOUSE, FMS_RBUTTONUP, 0, (EW_PMSG_vv)(EW_PMSG_bm)& msgCallback }, \
/*! \brief 定义\ref EW_MSG_MOUSE, \ref FMS_LBUTTONUP消息和处理函数的对应关系的宏 */
#define ON_RBUTTONDOWN(msgCallback) \
{ EW_MSG_MOUSE, FMS_RBUTTONDOWN, 0, (EW_PMSG_vv)(EW_PMSG_bm)& msgCallback }, \
/*! \brief 定义\ref EW_MSG_MOUSE, \ref FMS_LBUTTONUP消息和处理函数的对应关系的宏 */
#define ON_MOUSEMOVE(msgCallback) \
{ EW_MSG_MOUSE, FMS_BUTTONMOVE, 0, (EW_PMSG_vv)(EW_PMSG_bm)& msgCallback }, \
/*! \brief 定义\ref EW_MSG_TIMER, timerID消息和处理函数的对应关系的宏
*
* 即标识为timerID的通知消息
*/
#define ON_TIMER(timerID, msgCallback) \
{ EW_MSG_TIMER, timerID, 0, (EW_PMSG_vv)& msgCallback }, \
/*! \brief 定义\ref EW_MSG_FOCUS消息和处理函数的对应关系的宏 */
#define ON_FOCUS(msgCallback) \
{ EW_MSG_FOCUS, 0, 0, (EW_PMSG_vv)(EW_PMSG_vm)& msgCallback }, \
/*! \brief 定义\ref EW_MSG_NOTIFY, \ref EW_NOTIFY_ID消息和处理函数的对应关系的宏
*
* 即ID为\ref EW_NOTIFY_ID的通知消息
*/
#define ON_NOTIFY(notifyID, msgCallback) \
{ EW_MSG_NOTIFY, notifyID, 0, (EW_PMSG_vv)(EW_PMSG_vm)& msgCallback }, \
/*! \brief 定义\ref EW_MSG_NOTIFY, \ref EW_NOTIFY_ID, id消息和处理函数的对应关系的宏
*
* 即ID为\ref EW_NOTIFY_ID的通知消息,发送通知消息的控件的唯一标识为为id
*/
#define ON_ID_NOTIFY(notifyID, id, msgCallback) \
{ EW_MSG_NOTIFY, notifyID, id, (EW_PMSG_vv)& msgCallback }, \
/*! \brief 定义\ref EW_MSG_UPDATE_VIEW消息和处理函数的对应关系的宏 */
#define ON_UPDATE_VIEW(msgCallback) \
{ EW_MSG_UPDATE_VIEW, 0, 0, (EW_PMSG_vv)& msgCallback }, \
/*! \brief 消息映射表结束项 */
#define END_MESSAGE_MAP() \
{ 0, 0, 0, (EW_PMSG_vv)NULL } \
}; \
/*! @} */
class EW_Object;
struct EW_Message;
/*! \defgroup MsgHandler_Type 消息处理函数类型 */
/*! @{ */
//##ModelId=3F58381F03A7
/*! \brief 参数为void,返回值为void的消息处理函数。\n
*
* 用于以下消息:
* - \ref EW_MSG_TIMER
* - \ref EW_MSG_NOTIFY, \ref EW_NOTIFY_ID, id
* - \ref EW_MSG_UPDATE_VIEW
*/
typedef void (EW_Object::* EW_PMSG_vv)(void);
//##ModelId=3F6193A7005C
/*! \brief 参数为\ref EW_OSAdaptor *,返回值为void的消息处理函数。\n
*
* 用于以下消息:
* - \ref EW_MSG_DRAW
*/
typedef void (EW_Object::* EW_PMSG_vd)(EW_OSAdaptor * pAdaptor);
//##ModelId=3F5B47040163
/*! \brief 参数为\ref EW_OSAdaptor *,返回值为void的消息处理函数。\n
*
* 用于以下消息:
* - \ref EW_MSG_DRAW_REQUEST
* - \ref EW_MSG_FOCUS
* - \ref EW_MSG_NOTIFY, notifyID
*/
typedef void (EW_Object::* EW_PMSG_vm)(EW_Message * pMsg);
//##ModelId=3F6167B501F0
/*! \brief 参数为\ref EW_OSAdaptor *,返回值为void的消息处理函数。\n
*
* 用于以下消息:
* - \ref EW_MSG_KEY
* - \ref EW_MSG_KEY, \ref FKS_DOWN
* - \ref EW_MSG_KEY, \ref FKS_UP
* - \ref EW_MSG_MOUSE
* - \ref EW_MSG_MOUSE, \ref FMS_LBUTTONDOWN
* - \ref EW_MSG_MOUSE, \ref FMS_LBUTTONUP
*/
typedef bool (EW_Object::* EW_PMSG_bm)(EW_Message * pMsg);
/*! @} */
//##ModelId=3F58381F0375
/*! \brief 消息映射表项结构
*
* 定义消息映射表中的每一个表项
*/
struct EW_MSGMAP_ENTRY
{
//##ModelId=3F6167B60012
WORD m_MsgType; /*!< \brief 消息类型\ref EW_MSG_TYPE */
//##ModelId=3F5B584A00E0
/*! \brief \ref WORD类型的数据
*
* 保存键盘状态\ref EW_KEY_STATUS、鼠标状态\ref EW_MOUSE_STATUS、定时器ID、通知消息ID
*/
WORD m_wData;
//##ModelId=3F6167B60026
WORD m_wID; /*!< \brief 发送通知消息的控件ID */
//##ModelId=3F5838210044
EW_PMSG_vv m_Callback; /*!< \brief 该消息对应的消息处理函数 */
};
//##ModelId=3F58381F0326
/*! \brief 消息映射表结构
*
* 包含消息映射表项的数组以及指向基类的消息映射表的指针
*/
struct EW_MSGMAP
{
//##ModelId=3F583820024A
const EW_MSGMAP * m_pBaseMsgMap; /*!< \brief 指向基类的消息映射表的指针 */
//##ModelId=3F583820027C
const EW_MSGMAP_ENTRY * m_pEntry; /*!< \brief 本类的消息映射表的指针 */
//##ModelId=3F584C9400FF
/*! \brief 在本类的消息映射表中查找消息
*
* 为0的参数表示该项不须查找
* \param type 要查找的消息类型\ref EW_MSG_TYPE
* \param data 要查找的消息的消息的\ref WORD型数据
* \param id 发送通知消息的控件ID
* \return EW_MSGMAP_ENTRY* 查找到的消息映射表项,\ref NULL表示没有找到
*/
const EW_MSGMAP_ENTRY * FindMsgCallback(const WORD type, const WORD data, const WORD id) const;
};
#endif /* EW_KEYMAP_H_HEADER_INCLUDED_C0AD453B */
/*! @} */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -