• <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 技術
            91麻精品国产91久久久久| 色天使久久综合网天天| 久久综合狠狠综合久久综合88 | 亚洲а∨天堂久久精品| 伊人久久大香线蕉av不卡| 久久久久久国产精品无码下载 | 99久久国产精品免费一区二区 | 中文字幕成人精品久久不卡| 久久香蕉一级毛片| 久久久久综合国产欧美一区二区| 久久高潮一级毛片免费| 伊人久久大香线蕉精品不卡| 伊人久久无码中文字幕| 久久综合给合久久狠狠狠97色| 精品久久久久久中文字幕| 国产成人精品综合久久久| 人妻无码精品久久亚瑟影视| 国产精品久久久天天影视| 亚洲国产成人久久综合野外 | 国产农村妇女毛片精品久久 | 波多野结衣中文字幕久久| 久久香蕉一级毛片| 久久久这里有精品| 久久无码人妻精品一区二区三区| 久久久久久亚洲精品成人| 久久国产三级无码一区二区| 久久久一本精品99久久精品66| 久久久久18| 夜夜亚洲天天久久| 色婷婷综合久久久中文字幕| 日本WV一本一道久久香蕉| 亚洲国产精品一区二区三区久久| 久久精品国产亚洲欧美| 久久精品久久久久观看99水蜜桃| 久久国产精品国语对白| 久久国产精品77777| 亚洲va中文字幕无码久久 | 一本久久a久久精品vr综合| 久久免费香蕉视频| 久久久久亚洲AV成人网人人软件| 91精品国产色综合久久|