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

             

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

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

              (1)    定義消息的值。在我們要發生消息的地方(例如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來發送消息了。

                如:::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;

              //發送消息

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

            {

                             theApp.SendMessage(hwnd);

            }     

             

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

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

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


              void SendMessage(HWND hwnd);

             

              在CPP文件中添加函數實現

              //啟動發送消息


            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文件,然后發送一個測試消息響應的命令:


            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();

                //發送測試消息函數

                (*StartSendMessage)(hwnd);

            }

             

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









            Posted on 2007-11-20 12:18 艾凡赫 閱讀(4372) 評論(0)  編輯 收藏 引用 所屬分類: MFC技術DLL 技術
            久久久久久a亚洲欧洲aⅴ| 欧美与黑人午夜性猛交久久久| 无码久久精品国产亚洲Av影片 | 久久成人影院精品777| 色成年激情久久综合| 久久精品国产色蜜蜜麻豆| 麻豆精品久久久久久久99蜜桃| 色妞色综合久久夜夜| 亚洲狠狠综合久久| 亚洲性久久久影院| 久久成人精品视频| 热99RE久久精品这里都是精品免费| 久久精品人人做人人妻人人玩| 国产A级毛片久久久精品毛片| 精品久久久中文字幕人妻| 国产香蕉97碰碰久久人人| 午夜精品久久久久久久| 欧美精品丝袜久久久中文字幕| AV狠狠色丁香婷婷综合久久| 麻豆精品久久久久久久99蜜桃| 97精品伊人久久久大香线蕉| 久久夜色精品国产噜噜麻豆| 亚洲va久久久久| 亚洲国产精品无码久久久久久曰| 久久婷婷五月综合97色一本一本| 中文字幕久久亚洲一区| 久久无码国产| 热RE99久久精品国产66热| 国产亚洲色婷婷久久99精品91| 久久精品草草草| 成人精品一区二区久久久| www.久久精品| 岛国搬运www久久| 伊人久久免费视频| 久久激情五月丁香伊人| 久久久久国产精品三级网| 国产午夜精品理论片久久| 久久无码一区二区三区少妇| 欧洲性大片xxxxx久久久| 欧美日韩久久中文字幕| 久久亚洲精品无码VA大香大香|