【MFC】07.MFC第三大机制:消息映射-笔记

这篇具有很好参考价值的文章主要介绍了【MFC】07.MFC第三大机制:消息映射-笔记。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

本专栏上两篇文章分别介绍了【MFC】05.MFC第一大机制:程序启动机制和【MFC】06.MFC第二大机制:窗口创建机制,这篇文章来为大家介绍MFC的第三大机制:消息映射

  • typfd要实现消息映射,必须满足的三个条件:

    类必须继承于CmdTargert

    类必须声明重定义 DECLARE_MESSAGE_MAP

    类外必须实现DEGIN_MESSINGE_MAP()

    END_MESSAGE_MAP()

    自己的窗口类{
      LERESULT onCreate(WPARAM wParam,LPARAM lParam){
      AfxMessageBox("WM_CREATE");
      }
      
      //定义宏:
      DECLARE_MESSAGE_MAP()
    }
    
    //类外实现消息映射:
    BEGIN_MESSAGE_MAP(cMyFrameWnd,CFrameWnd)
      ON_MESSAGE(WM_CREATE,onCreate);
    END_MESSAGE_MAP()
    
  • 在Win32程序中封装消息:

    我们定义一张映射表,当进入WndProc的时候,通过查找这张表的映射关系,来执行对应的函数:

    typedef struct MESSAGE_ENTRY{
      int message;
      int (*pFun)(HWND hWnd,UINT message,WPARAM wParam,LPARAM lParam);
    }
    struct MESSAGE_ENTRY MessageMap[]{
      映射容器:
      WM_PAINT,函数地址
    }
    

MFC的消息映射机制:

  • 宏展开:
    DECLARE_MESSAGE_MAP(){
      //静态函数
      static const AFX_MSGMAP* PASCAL GetThisMessageMap();
      //虚函数
        virtual const AFX_MSGMAP* GetMessageMap() const;
    }
    
    实现宏展开:
    DECLARE_MESSAGE_MAP(){
      //静态函数
      static const AFX_MSGMAP* PASCAL GetThisMessageMap();
      //虚函数
    	virtual const AFX_MSGMAP* GetMessageMap() const;
    }
    
    BEGIN_MESSAGE_MAP(CMFCApplication1App, CWinApp){
        //这里是实现虚函数,
      	const AFX_MSGMAP* theClass::GetMessageMap() const 
      		{ 
      		  return GetThisMessageMap();
      		} 
      		
      	const AFX_MSGMAP* PASCAL theClass::GetThisMessageMap() \
      	{ \
      		typedef theClass ThisClass;
      		typedef baseClass TheBaseClass;
      		static const AFX_MSGMAP_ENTRY _messageEntries[] = 
      		{
        		{0, 0, 0, 0, AfxSig_end, (AFX_PMSG)0 }
      	 }; 
      		static const AFX_MSGMAP messageMap = 
      		{ &TheBaseClass::GetThisMessageMap,//我们的弗雷德静态函数地址
      		&_messageEntries[0] };//本类消息结构体的数组首地址
      		return &messageMap;
      	}			
    }
    

我们来看看struct AFXmMSGMAP_ENTRY结构体:

struct AFX_MSGMAP_ENTRY
{
    UINT nMessage;   //消息ID
    UINT nCode;      //win32通知码 
    UINT nID;        //命令ID WM_COMMAND 菜单 按钮 快捷键 加速键  1000
    UINT nLastID;    //最后ID                                       1004
    UINT_PTR nSig;   //处理消息的类型
    AFX_PMSG pfn;    //我们的处理消息的函数地址
};

消息回调:文章来源地址https://www.toymoban.com/news/detail-634587.html

LRESULT CALLBACK AfxWndProc(HWND hWnd, UINT nMsg, WPARAM wParam, LPARAM lParam)
{
    CWnd* pWnd = CWnd::FromHandlePermanent(hWnd);
    AfxCallWndProc(pWnd, hWnd, nMsg, wParam, lParam);
    {
         pWnd->WindowProc(nMsg, wParam, lParam)
         {
            OnWndMsg(message, wParam, lParam, &lResult)
            {
                //函数签名 里面有函数指针
                union MessageMapFunctions mmf;
                //返回链表头节点
                const AFX_MSGMAP* pMessageMap; pMessageMap = this->GetMessageMap();
                
                const AFX_MSGMAP_ENTRY* lpEntry;
                
                for (/* pMessageMap already init'ed */; 
                        pMessageMap->pfnGetBaseMap != NULL;        //判断节点等不等于空
                        pMessageMap = (*pMessageMap->pfnGetBaseMap)()//找下一个节点
                    )
                {
                        lpEntry = AfxFindMessageEntry(pMessageMap->lpEntries,message, 0, 0)) != NULL)    
                        //消息函数的地址
                        mmf.pfn = lpEntry->pfn;
                        switch (lpEntry->nSig)
                        {
                            lResult = (this->*mmf.pfn_l_w_l)(wParam, lParam);
                        }
                }
            } 
         }
    }
}

到了这里,关于【MFC】07.MFC第三大机制:消息映射-笔记的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【MFC】05.MFC六大机制:程序启动机制-笔记

    MFC程序开发所谓是非常简单,但是对于我们逆向人员来说,如果想要逆向MFC程序,那么我们就必须了解它背后的机制,这样我们才能够清晰地逆向出MFC程序,今天这篇文章就来带领大家了解MFC的第一大机制:程序启动机制: 首先,我们创建一个单文档架构程序,我们来观察一

    2024年02月13日
    浏览(34)
  • 【MFC】06.MFC六大机制:窗口创建机制-笔记

    接上文【MFC】05.MFC第一大机制:程序启动机制-笔记,这一篇文章来带领大家逆向分析MFC第二大机制:窗口创建机制的源码。 我们知道,在Win32编程中,如果我们要创建一个窗口,基本步骤为: 注册窗口 创建一个窗口,必须要给一个类名称 消息处理回调函数 那么MFC的窗口创建

    2024年02月13日
    浏览(31)
  • 【MFC】05.MFC第一大机制:程序启动机制-笔记

    MFC程序开发所谓是非常简单,但是对于我们逆向人员来说,如果想要逆向MFC程序,那么我们就必须了解它背后的机制,这样我们才能够清晰地逆向出MFC程序,今天这篇文章就来带领大家了解MFC的第一大机制:程序启动机制: 首先,我们创建一个单文档架构程序,我们来观察一

    2024年02月14日
    浏览(35)
  • 【MFC】06.MFC第二大机制:窗口创建机制-笔记

    接上文【MFC】05.MFC第一大机制:程序启动机制-笔记,这一篇文章来带领大家逆向分析MFC第二大机制:窗口创建机制的源码。 我们知道,在Win32编程中,如果我们要创建一个窗口,基本步骤为: 注册窗口 创建一个窗口,必须要给一个类名称 消息处理回调函数 那么MFC的窗口创建

    2024年02月14日
    浏览(37)
  • 【MFC】10.MFC六大机制:RTTI(运行时类型识别),动态创建机制,窗口切分,子类化-笔记

    C++: ##是拼接 #是替换成字符串 这是MFC提供的运行时类信息的使用,如果我们自己创建一个类,如果想用这些方法,必须要满足三个条件: 这个类必须继承于CObject类 类内必须声明DECLARE_DYNAMIC 类外必须实现IMPLENENT_DYNAMIC 我们来看看是如何实现的: 这里给出RTTI的图,每一个类中

    2024年02月13日
    浏览(37)
  • 微软MFC技术运行机制

    我是荔园微风,作为一名在IT界整整25年的老兵,今天总结一下微软MFC技术运行机制。 很多初学者误以为VC++开发必须使用MFC,其实不一定的。MFC的使用只能是提高程序在某些情况下的开发效率,而不能替代整个Win32程序设计。我认为我们有必要再来好好讲讲MFC的本质、MFC中的

    2024年02月08日
    浏览(40)
  • MFC 序列化机制

    目录 文件操作相关类 序列化机制相关类 序列化机制使用 序列化机制执行过程 序列化类对象 CFile:文件操作类,封装了关于文件读写等操作,常见的方法: CFile::Open:打开或者创建文件 CFile::Write/Read:写/读文件 CFile::Close:关闭文件 CFile::SeekToBegin/SeekToEnd/Seek:从 开始/结束

    2024年01月20日
    浏览(32)
  • MFC新建内部消息

    提示:记录一下MFC新建内部消息的成功过程 文章目录 前言 一、第一阶段 二、第二阶段 三、第三阶段 总结 先说一下基本情况,因为要在mapview上增加一个显示加载时间的功能。然后发现是要等加载完再显示时间,显示在主窗口。所以就是在子线程中发送消息给窗口的问题。

    2024年02月09日
    浏览(44)
  • windows MFC消息demo

    2024年02月11日
    浏览(41)
  • 微软MFC技术中消息的分类

     我是荔园微风,作为一名在IT界整整25年的老兵,今天来聊聊MFC技术中消息的分类。 微软Windows中的消息虽然很多,但是种类并不繁杂,大体上有3种:窗口消息、命令消息和控件通知消息。 窗口消息是系统中最为常见的消息,它是指由操作系统和控制其他窗口所使用的消息。

    2024年02月13日
    浏览(34)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包