• <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 閱讀(381) 評論(0)  編輯 收藏 引用

            導航

            統計

            常用鏈接

            留言簿

            隨筆檔案(12)

            文章檔案(1)

            最新隨筆

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            亚洲精品午夜国产VA久久成人| 久久精品无码一区二区三区日韩| 2020国产成人久久精品| 久久亚洲欧美国产精品| 国产V亚洲V天堂无码久久久| 97久久综合精品久久久综合| 99久久国产综合精品五月天喷水| 久久无码AV中文出轨人妻| 久久久久久久久久久久久久| 国内精品久久久久久久97牛牛| 久久精品亚洲精品国产欧美| 久久久久久久女国产乱让韩 | 99久久精品国内| 久久精品国产福利国产琪琪| 国产精品中文久久久久久久| 国产成人精品白浆久久69| 欧洲性大片xxxxx久久久| 精品久久久久久国产潘金莲| 久久国产视屏| 91精品国产综合久久婷婷| 久久天天躁狠狠躁夜夜avapp| 国产91色综合久久免费分享| 久久久久久精品久久久久| 国产一区二区三区久久| 亚洲AV日韩AV永久无码久久| 四虎影视久久久免费| 色综合久久精品中文字幕首页| 久久精品国产色蜜蜜麻豆| 久久久久亚洲AV成人网人人软件| 久久久久国产精品熟女影院 | 久久人爽人人爽人人片AV | 国内精品九九久久精品| 人妻少妇精品久久| 国产精品伊人久久伊人电影| 国产午夜免费高清久久影院| 久久久久久国产精品无码下载| 久久天天躁狠狠躁夜夜不卡 | 亚洲AV日韩AV天堂久久| 伊人久久大香线蕉综合热线| 久久天天躁狠狠躁夜夜2020| 久久精品中文字幕第23页|