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

            最新隨筆

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            久久99国产精品一区二区| 97精品依人久久久大香线蕉97| 久久亚洲精品人成综合网| 欧美黑人激情性久久| 久久99精品国产99久久| 91麻精品国产91久久久久| 久久精品国产第一区二区| 久久精品国产亚洲AV影院| 成人亚洲欧美久久久久| 亚洲色大成网站WWW久久九九| 7777久久亚洲中文字幕| 少妇熟女久久综合网色欲| 久久精品国产亚洲一区二区| 久久久亚洲欧洲日产国码是AV| 久久香蕉国产线看观看乱码| 日韩va亚洲va欧美va久久| 情人伊人久久综合亚洲| 亚洲AV无一区二区三区久久| 亚洲精品无码专区久久同性男| 久久se精品一区二区| 97久久婷婷五月综合色d啪蜜芽 | 久久国产成人| 蜜臀av性久久久久蜜臀aⅴ| 久久亚洲国产最新网站| 国産精品久久久久久久| 精品久久久久久综合日本| 午夜欧美精品久久久久久久| 热综合一本伊人久久精品| 亚洲综合久久综合激情久久| 久久精品aⅴ无码中文字字幕重口 久久精品a亚洲国产v高清不卡 | 久久中文字幕人妻丝袜| 久久国产成人亚洲精品影院| 久久最新精品国产| 91精品久久久久久无码| 久久99精品国产99久久6男男| 国产欧美久久一区二区| 69SEX久久精品国产麻豆| 97精品伊人久久大香线蕉app | 久久亚洲国产成人影院网站| 欧美久久精品一级c片片| 国产精品无码久久综合网|