• <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>
             在進行DLL開發(fā)過程中,尤其在進行底層硬件開發(fā)過程中,比如實時接收數據,進程需要和應用程序進行交互,而DLL和應用程序最好的交互就是發(fā)消息了,在DLL中定義消息的方式和在應用程序中定義消息的方式非常相似。下面談談這兩種定義的方法:

             

              一、在應用程序自定義消息方法:

                    一般自定義消息有一定的范圍,雖然說自定義消息從WM_USER開始,但是由于我們的工程里面一般還有很多其他的控件,他們也要占用一部分WM_USER消息范圍,所以我們必須為他們留出一部分范圍,這里,我們保留100個消息,一般情況下,這可以滿足我們的要求。

              (1)    定義消息的值。在我們要發(fā)生消息的地方(例如CMyView.cpp的開始部分)或者stdafx..h文件,進行如下定義:


            #define WM_MSG  (WM_USER+101)

             

                    接下來的工作其實很簡單,我們在前面說了,消息正常工作有3個部分必須協調:消息聲明、消息映射、消息體。我們就一次進行手工加入。

                    (2)首先在AFX_MSG塊中加入消息聲明:在CMyView.h中,找到如下部分,并加入消息聲明:


                     protected:       

                        // {{AFX_MSG(CMyView)

                        ......

                        afx_msg LRESULT OnMyMsg(WPARAM wParam,LPARAM lParam);

                        file://}}AFX_MSG

             

                    (3)在MESSAGE_MAP塊中添加ON_MESSAGE宏指令:


                       BEGIN_MESSAGE_MAP(CMyView, CView)

                          file://{{AFX_MSG_MAP(CMyView)

                           .....

                          ON_MESSAGE(WM_MSG, OnMyMsg)

                         file://}}AFX_MSG_MAP

                       END_MESSAGE_MAP()

             

                    (4)添加消息函數體:


                  LPESULT CMyView::OnMyMsg(WPARAM wParam, LPARAM lParam)

                      {

                


                         AfxMessageBox("消息已經收到!");

                         return 0;

                      }

             

                    消息至此就已經定義完畢,接下來我們就可以激活消息了,就可以用我們前面所說的PostMessage/SendMessage來發(fā)送消息了。

                如:::PostMessage(hwnd,WM_MSG,0,1);

                   PostMessage:不用等消息返回。

                SendMessage:需要等消息返回。

              二、從DLL中傳遞消息到EXE

               在DLL中定義消息和上面的方法很相似,有兩點不同的地方:

              1、  在DLL和應用程序中兩個地方定義相同的消息。

              2、  應用程序調用DLL程序之后,需要將應用程序的窗口句柄傳遞給DLL,以便DLL中的消息返回。

              在DLL工程中:

              (1)       在stdafx.h頭文件中添加消息定義:


             #define WM_MSG WM_USER + 102

                   

              (2)       添加啟動消息的輸出函數:


                   CMessageDLLApp theApp;

              //發(fā)送消息

            extern "C" _declspec(dllexport) void StartSendMessage(HWND hwnd)

            {

                             theApp.SendMessage(hwnd);

            }     

             

                        其中hwnd是接收消息的窗口句柄。

              (3)       添加啟動消息的實現函數:

            在頭文件中添加函數聲明:


              void SendMessage(HWND hwnd);

             

              在CPP文件中添加函數實現

              //啟動發(fā)送消息


            void CMessageDLLApp::SendMessage(HWND hwnd)

            {

                               ::PostMessage(hwnd,WM_MSG,0,1);

            }

              在應

            用程序中:

              (1)       在stdafx.h頭文件中添加消息定義:


            #define WM_MSG WM_USER + 102

                   

              (2)       首先在AFX_MSG塊中加入消息聲明:在CTestMessageDLLDlg.h中,找到如下部分,并加入消息聲明:

            。。。。。。


                    afx_msg LRESULT OnMyMsg(WPARAM wParam,LPARAM lParam);

                             DECLARE_MESSAGE_MAP()

             

              (3)       在MESSAGE_MAP塊中添加ON_MESSAGE宏指令:


                    BEGIN_MESSAGE_MAP(CTestMessageDLLDlg, CDialog)

                      。。。。。。

                      ON_MESSAGE(WM_MSG, OnMyMsg)

                      //}}AFX_MSG_MAP

                      END_MESSAGE_MAP()

             

              (4)       添加消息函數體:


                   LRESULT CTestMessageDLLDlg::OnMyMsg(WPARAM wParam, LPARAM lParam)

             {

                            AfxMessageBox("消息已經收到!");

                             return 0;

                 }

             (5)       在對話框上添加一個按鈕,在按鈕事件中,先調用DLL文件,然后發(fā)送一個測試消息響應的命令:


            void CTestMessageDLLDlg::OnBnClickedButton1()

            {

                // TODO: 在此添加控件通知處理程序代碼

                //定義函數

                typedef void (_cdecl*STARTSENDMESSAGE)(HWND hwnd);

                HMODULE hmessage = NULL;

                STARTSENDMESSAGE StartSendMessage = NULL;

              //導入DLL庫文件

                hmessage = LoadLibrary("MessageDLL.dll");

                if(hmessage==NULL)

                {

                    FreeLibrary(hmessage);

                    exit(0);

                }

              //導入DLL中測試消息函數

                StartSendMessage = (STARTSENDMESSAGE)GetProcAddress(hmessage,"StartSendMessage");

                if(StartSendMessage==NULL)

                {

                    FreeLibrary(hmessage);

                    exit(1);

                }

                //獲取對話框的窗口句柄

                HWND hwnd = this->GetSafeHwnd();

                //發(fā)送測試消息函數

                (*StartSendMessage)(hwnd);

            }

             

            運行應用程序,就可以看到測試結果了。
             









            Posted on 2007-11-20 12:18 艾凡赫 閱讀(4381) 評論(0)  編輯 收藏 引用 所屬分類: MFC技術DLL 技術
            久久频这里精品99香蕉久| 久久精品亚洲AV久久久无码| 久久久久久久久无码精品亚洲日韩 | 久久精品免费大片国产大片| 久久久精品视频免费观看| 久久人人爽人人人人爽AV| 日本三级久久网| 2021国产精品久久精品| 久久精品水蜜桃av综合天堂| 久久精品国产一区二区三区 | 国产成人精品久久免费动漫 | 青青青伊人色综合久久| 一本一本久久aa综合精品| 久久国产V一级毛多内射| 97久久国产露脸精品国产| 国产精品久久久99| 久久久久99精品成人片欧美| 久久性生大片免费观看性| 久久精品国产精品青草app| 熟妇人妻久久中文字幕| 色综合久久天天综线观看| 91久久精品国产成人久久| 色欲久久久天天天综合网精品| 久久久久综合中文字幕| 日韩亚洲欧美久久久www综合网| 色88久久久久高潮综合影院| 久久久91人妻无码精品蜜桃HD| 99久久免费国产精品热| 久久婷婷五月综合色高清| 亚洲愉拍99热成人精品热久久| 亚洲国产成人精品无码久久久久久综合| 好久久免费视频高清| 国产精品毛片久久久久久久| 久久久久久毛片免费播放| 2021少妇久久久久久久久久| 久久精品亚洲精品国产色婷| 久久99精品久久久久久hb无码| 久久综合给合久久国产免费| 国内精品久久久久久99蜜桃| 久久精品无码午夜福利理论片 | 久久久久亚洲精品无码蜜桃|