• <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狠狠久久蜜臀婷色中文网| 亚洲综合精品香蕉久久网| 99精品久久精品一区二区| 久久国产乱子伦精品免费强| 久久青青草原亚洲av无码app| 狠狠色狠狠色综合久久| 久久午夜福利电影| 久久久久九国产精品| 中文成人无码精品久久久不卡| 久久精品综合网| 久久精品国产亚洲av麻豆色欲| 国产精品99久久不卡| 久久精品国产亚洲AV影院| 久久精品这里热有精品| 亚洲国产一成久久精品国产成人综合| 久久精品国产99国产精品导航| 999久久久免费精品国产| 亚洲国产小视频精品久久久三级 | 日产精品久久久一区二区| 91精品国产乱码久久久久久| 亚洲欧美一区二区三区久久| 久久免费美女视频| 久久久久高潮综合影院| 久久久久久极精品久久久| 99久久久精品| 久久精品国产亚洲av麻豆小说 | 久久亚洲高清综合| 久久精品欧美日韩精品| 久久无码中文字幕东京热| 国产成人精品综合久久久| 久久精品无码专区免费东京热| 国产精品久久久久久久久久影院| 国产成人综合久久久久久| 国产精品久久一区二区三区| 色综合久久综合中文综合网| 欧美伊人久久大香线蕉综合 | 亚洲欧美国产日韩综合久久| 精品熟女少妇aⅴ免费久久| 亚洲国产成人久久精品影视 | 久久久久国产亚洲AV麻豆| 国产69精品久久久久9999|