• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            MFC消息映射機制的剖析(孫鑫VC++講座筆記-(4)轉載并修改)

            一,消息映射機制

            1,消息響應函數:(例:在CDrawView類響應鼠標左鍵按下消息)
            1)在頭文件(DrawView.h)中聲明消息響應函數原型。
            //{{AFX_MSG(CDrawView) //注釋宏
            afx_msg void OnLButtonDown(UINT nFlags, CPoint point);
            //}}AFX_MSG //注釋宏
            說明:
            在注釋宏之間的聲明在VC中灰色顯示。afx_msg宏表示聲明的是一個消息響應函數。

            這個注釋宏為的是讓ClassWizard能夠分辨出哪些代碼是它生成的,哪些是你自己寫的。
            你自己寫的代碼要在這個注釋之外,這樣ClassWizard再修改消息映射的時候就不會管你的代碼了。
            限于以前的硬件速度,ClassWizard比較傻冒,所以需要這些注釋宏來定位。從7.0開始,就不再需
            要了。新的屬性頁能夠自動分析你的代碼,為你添加或者刪除代碼,而無需什么特殊標記的幫忙。
            因此注釋宏已經是歷史產物了。

            2)在源文件(DrawView.cpp)中進行消息映射。
            BEGIN_MESSAGE_MAP(CDrawView, CView)
            //}AFX_MSG_MAP
            // Standard printing commands
            ON_COMMAND(ID_FILE_PRINT, CView::OnFilePrint)
            ON_COMMAND(ID_FILE_PRINT_DIRECT, CView::OnFilePrint)
            ON_COMMAND(ID_FILE_PRINT_PREVIEW, CView::OnFilePrintPreview)
            END_MESSAGE_MAP()
            說明:
            在宏BEGIN_MESSAGE_MAP()與END_MESSAGE_MAP()之間進行消息映射。
            宏ON_WM_LBUTTONDOWN()把消息WM_LBUTTONDOWN與它的響應函數OnLButtonDown()相關聯。這樣一旦有消息的產生,就會自動調用相關聯的消息響應函數去處理。
            宏ON_WM_LBUTTONDOWN()定義如下:
            #define ON_WM_LBUTTONDOWN()
            { WM_LBUTTONDOWN, 0, 0, 0, AfxSig_vwp,
            (AFX_PMSG)(AFX_PMSGW)(void (AFX_MSG_CALL CWnd::*)(UINT, CPoint))&OnLButtonDown },
            3)源文件中進行消息響應函數處理。(DrawView.cpp中自動生成OnLButtonDown函數輪廓,如下)
            void CDrawView::OnLButtonDown(UINT nFlags, CPoint point)
            {
            // TODO: Add your message handler code here and/or call default
            CView::OnLButtonDown(nFlags, point);
            }
            說明:
            可見當增加一個消息響應處理,在以上三處進行了修改??稍谙㈨憫瘮道锾砑酉⑻幚泶a完成對消息的響應、處理。

            2,消息響應的方式:
            1) 在基類中針對每種消息做一個虛函數,當子類對消息響應時候,只要在子類中重寫這個虛函數即可。缺點:MFC類派生層次很多,如果在基類對每個消息進行虛函 數處理,那么從基類派生的每個子類都將背負一個龐大的虛表,這樣浪費內存,故MFC沒有采取這中方式而采取消息映射方式。
            2)消息映射方式: MFC在后臺維護了一個句柄和C++對象指針對照表,當收到一個消息后,通過消息結構里資源句柄(查對照表)就可找到與它對應的一個C++對象指針,然后 把這個指針傳給基類,基類利用這個指針調用WindowProc()函數對消息進行處理,WindowProc()函數中調用OnWndMsg()函數, 真正的消息路由及處理是由OnWndMsg()函數完成的。由于WindowProc()和OnWndMsg()都是虛函數,而且是用派生類對象指針調用 的,由多態性知最總終調用子類的。在OnWndMsg()函數處理的時候,根據消息種類去查找消息映射,判斷所發的消息有沒有響應函數,具體方式是到相關 的頭文件和源文件中尋找消息響應函數聲明(從注釋宏//}AFX_MSG之間尋找),消息映射(從宏BEGIN_MESSAGE_MAP(...)....END_MESSAGE_MAP()之間尋找),最終找到對應的消息處理函數。當然,如果子類中沒有對消息進行處理,則消息交由基類處理。
            說明:
            virtual LRESULT WindowProc(UINT message, WPARAM wParam, LPARAM lParam);
            virtual BOOL OnWndMsg(UINT message, WPARAM wParam, LPARAM lParam, LRESULT* pResult);

            posted on 2007-03-02 09:58 王光平 閱讀(932) 評論(0)  編輯 收藏 引用 所屬分類: 編程技術

            <2008年2月>
            272829303112
            3456789
            10111213141516
            17181920212223
            2425262728291
            2345678

            導航

            統計

            留言簿(4)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            91精品国产91久久| 久久久精品波多野结衣| 亚洲一级Av无码毛片久久精品| 青草久久久国产线免观| 亚洲精品蜜桃久久久久久| 久久99国产综合精品女同| 精品国产福利久久久| 一本综合久久国产二区| 久久午夜电影网| 久久精品国产亚洲αv忘忧草| 久久久久久午夜成人影院| 久久国产免费直播| 久久精品国产久精国产| 久久丫忘忧草产品| 99久久精品免费国产大片| 99久久精品免费看国产一区二区三区 | 国产精品久久久久久福利漫画| 丁香久久婷婷国产午夜视频| 国产成人精品久久| 欧美国产精品久久高清| 成人亚洲欧美久久久久| 国内精品伊人久久久久av一坑| 狠狠色丁香久久婷婷综合蜜芽五月| 9久久9久久精品| 久久中文骚妇内射| 久久精品国产亚洲AV久| 久久久久国产| 久久九九久精品国产免费直播| 久久国产精品-国产精品| 久久精品人人做人人爽97| 久久精品国产亚洲av麻豆图片 | 亚洲国产精品无码久久98| 午夜精品久久久久久| 久久久久一级精品亚洲国产成人综合AV区 | 欧美亚洲另类久久综合婷婷| 夜夜亚洲天天久久| 国产AⅤ精品一区二区三区久久| 精品久久久无码人妻中文字幕豆芽| 日韩精品久久久久久久电影蜜臀| 久久亚洲精品国产亚洲老地址 | 久久99精品久久久久久动态图|