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

            一步一步實現自己的模擬控件(4)——根控件

             

            窗口、控件驅動、根控件之間的關系

            前面我們已經說了,一個窗口只能關聯一個控件驅動,一個控件驅動也同樣對應一個根控件。為什么呢?因為我們的驅動需要作用于一個控件體系,一個控件體系具有一個根控件,這個根控件管理了整個窗口的客戶區。這樣我們才能在這個根控件下創建任意的控件,并活動在窗口客戶區。

            生命周期控制

            基于上面的關系,控件驅動和根控件的生命息息相關,那么我們讓其相互制約。既然是他們自身相互制約,那么用戶就不應該管理其生命周期,我們特意引入一個簡單的對象池來管理,并用訪問控制來避免外部直接構造。

            private:
            explicit Widget(widget::Driver* pDriver);
            ~Widget();
            Widget(
            const Widget&);
            Widget
            & operator =(const Widget&);

            // 讓對象池能夠創建Widget對象
            friend class ObjectPool<Widget>;
            #pragma warning(push)
            #pragma warning(disable:4396)
            friend
            void std::_Destroy(Widget _FARQ *);
            #pragma warning(pop)

            public:
            static Widget* Create(HWND hWnd); // 創建根控件
            void Destroy();

             

            我們提供了一個靜態接口Create用于創建根控件,可以注意到的一點是參數是窗口句柄。其實用戶對于什么驅動、什么過濾的都不關心,用戶只關心控件體系,所以說我們可以通過這個接口透明的創建根組件,實現中會自動的去驅動此窗口。

            Widget* Widget::Create(HWND hWnd)
            {
            return GetWidgetPool_().Construct(widget::Driver::Create(hWnd));
            }

             

            驅動構造時會創建根控件,析構時銷毀根控件

            Driver::Driver(HWND hWnd)
            : pImpl_(
            new DriverImpl(hWnd))
            {
            // 創建根控件
            pImpl_->SetRootWidget(Widget::Create_(this));
            }
            ~DriverImpl()
            {
            // 銷毀根控件
            Widget* pOldRootWidget = GetRootWidget();
            pRootWidget_
            = 0;
            if (pOldRootWidget)
            {
            pOldRootWidget
            ->Destroy();
            }
            }

             

            同樣,根控件析構時也銷毀控件驅動

            Widget::~Widget()
            {
            if (IsRoot())
            {
            pImpl_
            ->GetDriver()->Destroy();
            }
            delete pImpl_;
            }

             

            這樣,用戶其實有兩個入口可以進入到我們的控件系統,一個是通過控件驅動,一個是通過控件本身。我們提倡用戶不去關心控件驅動。那么甚至我們可以隱藏Driver這個類,目前我沒有這樣做。

            下載測試工程源碼

            作者: Evil.Ghost 發表于 2011-04-06 21:21 原文鏈接

            評論: 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-06 21:21 EvilGhost 閱讀(393) 評論(0)  編輯 收藏 引用

            導航

            統計

            常用鏈接

            留言簿

            隨筆檔案(12)

            文章檔案(1)

            最新隨筆

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            欧美国产成人久久精品| 久久国产精品国产自线拍免费| 精品免费久久久久国产一区| 久久99中文字幕久久| 久久青青草原国产精品免费| 99久久99久久| 久久久久久久免费视频| 丁香久久婷婷国产午夜视频| 久久国产精品无| 精品国产乱码久久久久久人妻| 亚洲色欲久久久久综合网| 久久久久久久久久久精品尤物| 国产V亚洲V天堂无码久久久| 伊人色综合久久| 久久久无码精品亚洲日韩蜜臀浪潮 | 狠狠色丁香久久综合五月| 亚洲国产精品无码久久久蜜芽| 合区精品久久久中文字幕一区| 一级女性全黄久久生活片免费 | 99久久精品国产一区二区三区 | 久久夜色精品国产噜噜麻豆| 久久精品欧美日韩精品| 国产福利电影一区二区三区久久老子无码午夜伦不 | 一本一本久久A久久综合精品| 亚洲欧美日韩久久精品第一区| 97精品久久天干天天天按摩| 99久久精品国产一区二区蜜芽| 亚洲AⅤ优女AV综合久久久| 国产综合久久久久久鬼色| 怡红院日本一道日本久久 | 国产福利电影一区二区三区久久老子无码午夜伦不 | 久久99国产精品久久99果冻传媒| 精品久久久久久久国产潘金莲| 国内精品欧美久久精品| 国产亚洲婷婷香蕉久久精品| 97久久久久人妻精品专区| 精品免费久久久久久久| 九九99精品久久久久久| 一本大道加勒比久久综合| 国产精品美女久久久免费| 久久性精品|