• <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>

            山寨:不是最好的,是最適合我們的!歡迎體驗山寨 中文版MSDN

            Blog @ Blog

            當華美的葉片落盡,生命的脈絡才歷歷可見。 -- 聶魯達

            常用鏈接

            統計

            積分與排名

            BBS

            Blog

            Web

            最新評論

            vc自定義消息的發送與接收的方法實現

            以下用一個自創的對話框類(MyMessageDlg)向視圖類(MessageTestView)
            發送自定義消息為例,說明這兩種不同方法的自定義消息的

            消息傳遞的方法一:使用ON_MESSAGE
            使用ON_MESSAGE響應消息,必須配合定義消息#define WM_MY_MESSAGE (WM_USER+100)

            對于發送消息者-MyMessageDlg,
            在其MyMessageDlg.h中,定義#define WM_MY_MESSAGE (WM_USER+100)
            在其MyMessageDlg.cpp中要先添加:#i nclude "MainFrm.h"
            因為使用了CMainFrame*定義對象。
            并且要有測試消息的函數:
            void MyMessageDlg::OnButtonMsg()
            {
                // TODO: Add your control notification handler code here
                CMainFrame* pMF=(CMainFrame*)AfxGetApp()->m_pMainWnd;  //先通過獲取當前框架指針
                CView * active = pMF->GetActiveView();//才能獲取當前視類指針
                if(active != NULL)  //獲取了當前視類指針才能發送消息
                active->PostMessage(WM_MY_MESSAGE,0,0);   //使用PostMessage發送消息
            }

            對于消息的接受者-MessageTestView,
            在其MessageTestView.h中,也要定義#define WM_MY_MESSAGE (WM_USER+100)
            并定義消息映射函數-OnMyMessage()
            protected:
             //{{AFX_MSG(CMessageTestView)
             afx_msg LRESULT OnMyMessage(WPARAM wParam, LPARAM lParam);
             //}}AFX_MSG
             DECLARE_MESSAGE_MAP()
            在其MessageTestView.cpp中,
            先要聲明響應消息:
            BEGIN_MESSAGE_MAP(CMessageTestView, CEditView)
             //{{AFX_MSG_MAP(CMessageTestView)
             ON_MESSAGE(WM_MY_MESSAGE, OnMyMessage)
             //}}AFX_MSG_MAP
            再添加消息響應的函數實現:
            LRESULT CMessageTestView::OnMyMessage(WPARAM wParam, LPARAM lParam)
            {
             MessageBox("OnMyMessage!");
             return 0;
            }


            消息傳遞的方法二:使用ON_REGISTERED_MESSAGE
            使用ON_REGISTERED_MESSAGE注冊消息,必須配合
            static UINT WM_MY_MESSAGE=RegisterWindowMessage("Message");

            對于消息的發送者-MyMessageDlg,
            在其MyMessageDlg.h中,只要
            定義static UINT WM_MY_MESSAGE=RegisterWindowMessage("Message");
            就可以了。
            在其MyMessageDlg.cpp中要先添加:#i nclude "MainFrm.h"
            因為使用了CMainFrame*定義對象。
            并且要有測試消息的函數:
            void MyMessageDlg::OnButtonMsg()
            {
                // TODO: Add your control notification handler code here
                CMainFrame* pMF=(CMainFrame*)AfxGetApp()->m_pMainWnd;  //先通過獲取當前框架指針
                CView * active = pMF->GetActiveView();//才能獲取當前視類指針
                if(active != NULL)  //獲取了當前視類指針才能發送消息
                active->PostMessage(WM_MY_MESSAGE,0,0);   //使用PostMessage發送消息
            }

            對于消息的接收者-MessageTestView,
            在其MessageTestView.h中不要定義
            static UINT WM_MY_MESSAGE=RegisterWindowMessage("Message");
            應該把這個定義放到MessageTestView.cpp中,要不會出現: redefinition
            在其MessageTestView.h中只要定義消息映射函數
            protected:
             //{{AFX_MSG(CMessageTestView)
             afx_msg LRESULT OnMyMessage(WPARAM wParam, LPARAM lParam);
             //}}AFX_MSG
             DECLARE_MESSAGE_MAP()
            在其MessageTestView.cpp中,先定義
            static UINT WM_MY_MESSAGE=RegisterWindowMessage("Message");
            接著注冊消息:
            BEGIN_MESSAGE_MAP(CMessageTestView, CEditView)
             //{{AFX_MSG_MAP(CMessageTestView)
                    ON_REGISTERED_MESSAGE(WM_MY_MESSAGE,OnMyMessage)
             //}}AFX_MSG_MAP
            最后添加消息響應的函數實現:
            LRESULT CMessageTestView::OnMyMessage(WPARAM wParam, LPARAM lParam)
            {
             MessageBox("OnMyMessage!");
             return 0;
            }
            ----------------------------------------------------------------
            比較兩種方法,只是略有不同。但也要小心謹慎,以免出現接收不到消息的情況。

            -------------------------------------------------------------------

            其他注意事項:

            發送消息的-MyMessageDlg.cpp前也要定義
            static UINT WM_MY_MESSAGE=RegisterWindowMessage("Message");

            接受消息的-MessageTestView.cpp前也要定義
            static UINT WM_MY_MESSAGE=RegisterWindowMessage("Message");

            RegisterWindowMessage("Message")中""的內容是什么不重要,寫什么都可以,但是
            發送者與接受者必須是一樣的內容,例如:"Message"

            posted on 2008-04-22 21:17 isabc 閱讀(3427) 評論(3)  編輯 收藏 引用 所屬分類: C++基礎

            評論

            # re: vc自定義消息的發送與接收的方法實現 2008-05-08 08:32 川菜

            我覺得你實現的有點問題,多此一舉了!!你通過:CMainFrame* pMF=(CMainFrame*)AfxGetApp()->m_pMainWnd; 取得了當前框架的指針,然后又通過 CView * active = pMF->GetActiveView();取得當前活動視類指針。注意,你用了active->PostMessage(WM_MY_MESSAGE,0,0);實際是通過視類指針給視類自己發了一個消息WM_MY_MESSAGE,然后通過消息傳遞調用了相應的函數OnMyMessage()。我覺得這里是不是多此一舉?直接這樣active->OnMyMessage()不就行了?
            你實際上在對話框里獲得的了視類的指針,然后通過視類指針給視類自己發了一條消息!!!!是不是有點多此一舉?
              回復  更多評論   

            # re: vc自定義消息的發送與接收的方法實現 2008-08-22 13:38 笑嘻嘻

            知其然而不知其所以然!  回復  更多評論   

            # re: vc自定義消息的發送與接收的方法實現 2009-11-09 16:54 sdff

            # re: vc自定義消息的發送與接收的方法實現 2008-05-08 08:32 川菜
            如果你這樣想,就沒必要用消息了  回復  更多評論   

            廣告信息(免費廣告聯系)

            中文版MSDN:
            歡迎體驗

            亚洲中文精品久久久久久不卡| 久久久久人妻精品一区| 国产午夜福利精品久久2021| 久久精品国产亚洲av水果派| 久久这里只精品国产99热| 久久97久久97精品免视看| 久久综合亚洲色HEZYO社区| 久久精品国产精品亚洲毛片| 国产精品一久久香蕉国产线看| 亚洲国产精品热久久| 国产精品久久久久久久app| 久久精品九九亚洲精品| 理论片午午伦夜理片久久| 亚洲AV无一区二区三区久久| 国产一区二区精品久久| 伊人久久国产免费观看视频| 99热成人精品热久久669| 无码8090精品久久一区| 2021久久国自产拍精品| 国产69精品久久久久观看软件 | 久久这里只有精品视频99| 婷婷久久久亚洲欧洲日产国码AV | 婷婷五月深深久久精品| 国产精品久久久99| 久久99精品国产自在现线小黄鸭| 国产一区二区三精品久久久无广告| 97久久国产综合精品女不卡 | 久久国产乱子伦精品免费强| 无码任你躁久久久久久老妇App| 久久精品国产影库免费看 | 国产精品久久久久久久午夜片| 久久精品中文字幕一区| 久久精品国产亚洲AV不卡| 久久久久亚洲av无码专区喷水 | 国产精品免费看久久久香蕉| 人妻无码中文久久久久专区 | 久久国产热精品波多野结衣AV| 久久无码专区国产精品发布| 中文字幕无码久久久| 日日狠狠久久偷偷色综合0| 亚洲欧美精品一区久久中文字幕 |