• <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>

            一步一步實現自己的模擬控件(3)——Widget驅動

             

            前面我們利用現有的微軟ATL實現的thunk已經為我們截獲窗口消息做好了準備,此刻我們應該編寫我們的Widget驅動的初步實現了。

            利用thunk對窗口消息過程進行子類化,那么窗口消息就會先流入到我們的Widget驅動對象,Widget驅動對象負責將消息傳遞給消息過濾器。現在我們的消息過濾器還未實現,于是我們打印了進入消息過濾器的消息ID值以觀察消息的流動情況。

            以下是我們的Widget驅動類,我們將其放入了一個名為widget的名字空間中,以后我們widget相關的名字都會放入到這個名字空間中。

            class DriverImpl;

            class Driver{
            DriverImpl
            * pImpl_;

            public:
            explicit Driver(HWND hWnd);
            ~Driver();

            private:
            Driver(
            const Driver&);
            Driver
            & operator =(const Driver&);

            public:
            inline HWND GetContainerWindow()
            const;
            };

            因為Driver的實現我們并不關心,所以我們將其實現進行了一個隱藏,這樣也便于我們修改其實現方式。Driver類對象要求用于構造它的窗口句柄必須為有效的窗口句柄,并且每個窗口句柄只能被驅動一次,所以我們在調試版本中做了斷言來約束我們的編碼,在發布版本中不會做任何判斷。

            #ifdef _DEBUG
            assert(::IsWindow(hContainerWnd_));
            // 不能多次驅動同一窗口
            assert(GetContainerWindows_().insert(hContainerWnd_).second);
            #endif // _DEBUG
            此處有一個GetContainerWindows_()是一個只在調試版本中才有的實現,其返回一個std::set<HWND>&靜態對象引用,用于保存已經被驅動的窗口句柄,我們斷言窗口句柄未曾保存到這個set之中。

            現在我們實現的Driver接口非常簡單,只有一個構造接口和查詢其驅動的窗口句柄的接口,顯然沒有任何可以控制驅動或者解除驅動的機會,此處我們先放一放,因為這在以后會涉及到這個驅動所關聯的Widget體系的一些問題。

            通過thunk截獲的窗口消息將會進入到Driver實現中,Driver的功能僅僅是作為Widget的驅動(也就是消息驅動),它不負責任何消息的處理,所以這個窗口過程在截獲到窗口消息后立即交由消息過濾處理。

            LRESULT WndProc_(UINT message, WPARAM wParam, LPARAM lParam)
            {
            // 進行消息過濾
            MessageFilter::Param param;
            param.hWnd
            = hContainerWnd_;
            param.originalProc
            = originalProc_;
            param.message
            = message;
            param.wParam
            = wParam;
            param.lParam
            = lParam;
            return MessageFilter::Filter(param);
            }

            這里消息過濾器的實現不在這一段討論之中,所以我們簡單的以一個類靜態接口來作為過濾入口。

            好了,我們到這里已經開啟了Widget內核的運作系統的實現,從測試工程中感受得到一定的體驗了。

            下載測試工程源碼

            作者: Evil.Ghost 發表于 2011-04-03 13:56 原文鏈接

            評論: 0 查看評論 發表評論


            最新新聞:
            · 蘋果iPad 2通過3C認證 最晚5月國內上市(2011-04-10 09:18)
            · 盲目依賴iPhone等工具導航 英國驢友迷路多(2011-04-10 09:14)
            · 趣談:想擔任CEO的話,最好是去蘋果工作,其次是微軟,再才是Google(2011-04-10 08:26)
            · 騰訊將建立新數據中心,規模為蘋果的兩倍(2011-04-10 08:25)
            · 輕量化的微型博客Tumblr(2011-04-10 08:03)

            編輯推薦:非戰之罪,從永中Office談起

            網站導航:博客園首頁  我的園子  新聞  閃存  小組  博問  知識庫

            posted on 2011-04-03 13:56 EvilGhost 閱讀(331) 評論(0)  編輯 收藏 引用

            導航

            統計

            常用鏈接

            留言簿

            隨筆檔案(12)

            文章檔案(1)

            最新隨筆

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            日韩欧美亚洲综合久久影院Ds| 东方aⅴ免费观看久久av| jizzjizz国产精品久久| 久久久无码精品亚洲日韩按摩 | 久久久久亚洲av无码专区喷水| 久久99精品国产麻豆| 久久久久久国产精品美女| 久久人人爽人人爽人人爽| 99久久99久久久精品齐齐| 久久婷婷人人澡人人| 嫩草伊人久久精品少妇AV| 久久久精品久久久久久| 粉嫩小泬无遮挡久久久久久| 久久男人中文字幕资源站| 狠狠色丁香婷婷久久综合不卡| 伊人久久精品影院| 国产精品午夜久久| avtt天堂网久久精品| 久久香综合精品久久伊人| 久久精品二区| 伊人久久精品线影院| 久久久久亚洲AV无码麻豆| 老男人久久青草av高清| 午夜精品久久久久9999高清| 久久青青草原国产精品免费 | 久久夜色撩人精品国产小说| 三上悠亚久久精品| 亚洲欧洲精品成人久久曰影片| 国产一区二区精品久久| 日韩精品无码久久久久久| 精品熟女少妇AV免费久久| 亚洲国产成人久久精品99| 久久精品国产精品亚洲人人| 久久se精品一区精品二区| 91精品国产9l久久久久| 久久国产色AV免费观看| 日韩精品久久无码人妻中文字幕| 久久婷婷五月综合成人D啪| 亚洲欧洲久久av| 久久精品国产亚洲av麻豆蜜芽| 久久久久se色偷偷亚洲精品av|