• <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久久国产主播综合精品| 婷婷综合久久狠狠色99h| 久久精品国产亚洲网站| 久久久久国产一区二区三区| 精品永久久福利一区二区| 一级做a爰片久久毛片人呢| 久久免费视频6| 国产韩国精品一区二区三区久久| 91精品国产综合久久香蕉| 国产激情久久久久影院老熟女免费 | 2021久久精品国产99国产精品| 精品少妇人妻av无码久久| 亚洲精品国产成人99久久| 2021国产精品久久精品| 成人综合伊人五月婷久久| 日韩十八禁一区二区久久| 久久人妻少妇嫩草AV无码专区| 久久精品这里只有精99品| 久久w5ww成w人免费| 精品久久久久久久久免费影院| 国内精品久久九九国产精品| 成人精品一区二区久久久| 久久精品国产精品亚洲精品 | 久久久久亚洲AV无码永不| 久久国产精品免费一区| 久久精品国产亚洲77777| 热久久最新网站获取| 久久九色综合九色99伊人| www久久久天天com| 久久久久无码精品国产| 国产精品久久久久免费a∨| 久久久久久国产精品无码下载| 狠狠色婷婷综合天天久久丁香 | 国产人久久人人人人爽| 色播久久人人爽人人爽人人片AV| 精品久久久久久无码人妻热|