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

             

              一、在應(yīng)用程序自定義消息方法:

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

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


            #define WM_MSG  (WM_USER+101)

             

                    接下來的工作其實(shí)很簡單,我們在前面說了,消息正常工作有3個(gè)部分必須協(xié)調(diào):消息聲明、消息映射、消息體。我們就一次進(jìn)行手工加入。

                    (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)添加消息函數(shù)體:


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

                      {

                


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

                         return 0;

                      }

             

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

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

                   PostMessage:不用等消息返回。

                SendMessage:需要等消息返回。

              二、從DLL中傳遞消息到EXE

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

              1、  在DLL和應(yīng)用程序中兩個(gè)地方定義相同的消息。

              2、  應(yīng)用程序調(diào)用DLL程序之后,需要將應(yīng)用程序的窗口句柄傳遞給DLL,以便DLL中的消息返回。

              在DLL工程中:

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


             #define WM_MSG WM_USER + 102

                   

              (2)       添加啟動(dòng)消息的輸出函數(shù):


                   CMessageDLLApp theApp;

              //發(fā)送消息

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

            {

                             theApp.SendMessage(hwnd);

            }     

             

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

              (3)       添加啟動(dòng)消息的實(shí)現(xiàn)函數(shù):

            在頭文件中添加函數(shù)聲明:


              void SendMessage(HWND hwnd);

             

              在CPP文件中添加函數(shù)實(shí)現(xiàn)

              //啟動(dòng)發(fā)送消息


            void CMessageDLLApp::SendMessage(HWND hwnd)

            {

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

            }

              在應(yīng)

            用程序中:

              (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)       添加消息函數(shù)體:


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

             {

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

                             return 0;

                 }

             (5)       在對(duì)話框上添加一個(gè)按鈕,在按鈕事件中,先調(diào)用DLL文件,然后發(fā)送一個(gè)測試消息響應(yīng)的命令:


            void CTestMessageDLLDlg::OnBnClickedButton1()

            {

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

                //定義函數(shù)

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

                HMODULE hmessage = NULL;

                STARTSENDMESSAGE StartSendMessage = NULL;

              //導(dǎo)入DLL庫文件

                hmessage = LoadLibrary("MessageDLL.dll");

                if(hmessage==NULL)

                {

                    FreeLibrary(hmessage);

                    exit(0);

                }

              //導(dǎo)入DLL中測試消息函數(shù)

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

                if(StartSendMessage==NULL)

                {

                    FreeLibrary(hmessage);

                    exit(1);

                }

                //獲取對(duì)話框的窗口句柄

                HWND hwnd = this->GetSafeHwnd();

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

                (*StartSendMessage)(hwnd);

            }

             

            運(yùn)行應(yīng)用程序,就可以看到測試結(jié)果了。
             









            Posted on 2007-11-20 12:18 艾凡赫 閱讀(4388) 評(píng)論(0)  編輯 收藏 引用 所屬分類: MFC技術(shù)DLL 技術(shù)
            国内精品久久久久久久久电影网| 亚洲精品无码久久一线| 波多野结衣久久| 久久无码AV一区二区三区| 热re99久久精品国99热| 国产精品一区二区久久精品无码 | 久久精品无码专区免费东京热| 亚洲国产精品久久久天堂 | 91精品国产91热久久久久福利| 精品一区二区久久| 久久午夜无码鲁丝片秋霞| 久久96国产精品久久久| 四虎国产精品成人免费久久| 国产福利电影一区二区三区久久老子无码午夜伦不 | 青青草原精品99久久精品66| 四虎国产永久免费久久| 久久国产精品99精品国产| 久久国产AVJUST麻豆| 久久一区二区免费播放| 久久伊人精品青青草原日本| 久久亚洲国产精品一区二区| 77777亚洲午夜久久多喷| 人妻无码αv中文字幕久久琪琪布| 婷婷久久香蕉五月综合加勒比| 亚洲第一极品精品无码久久| 久久亚洲AV成人出白浆无码国产| 人妻精品久久无码专区精东影业 | 东方aⅴ免费观看久久av| 久久久无码精品亚洲日韩按摩| 国产精久久一区二区三区| 亚洲人成无码www久久久| jizzjizz国产精品久久| 日产久久强奸免费的看| 国产成人无码久久久精品一| 久久久久久精品免费看SSS | 漂亮人妻被中出中文字幕久久| 大美女久久久久久j久久| 久久99精品久久久大学生| 一本色道久久综合狠狠躁篇| 久久伊人五月丁香狠狠色| 久久婷婷五月综合成人D啪|