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

            導航

            統計

            常用鏈接

            留言簿

            隨筆檔案(12)

            文章檔案(1)

            最新隨筆

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            久久久久人妻精品一区二区三区| 久久99热这里只频精品6| 亚洲∧v久久久无码精品| 久久成人小视频| 久久精品人人做人人爽电影蜜月| 久久久久人妻一区精品性色av| 丰满少妇高潮惨叫久久久| 久久国产精品-国产精品| 欧美麻豆久久久久久中文| 久久国产AVJUST麻豆| 成人午夜精品无码区久久| 日韩人妻无码一区二区三区久久 | 精品久久久久久国产牛牛app| 国产农村妇女毛片精品久久| 亚洲日韩欧美一区久久久久我| 久久精品国产亚洲AV影院| 久久发布国产伦子伦精品| 久久国产成人精品国产成人亚洲| 久久久精品久久久久久| 久久人人爽人人爽人人片AV不 | 亚洲日本久久久午夜精品| 久久综合九色综合网站 | 99久久精品毛片免费播放| 久久er国产精品免费观看8| 精品国产日韩久久亚洲| 丰满少妇高潮惨叫久久久| 中文字幕亚洲综合久久菠萝蜜| 久久青青草原国产精品免费 | 日韩va亚洲va欧美va久久| 一本色道久久88—综合亚洲精品| 青青青伊人色综合久久| 中文无码久久精品| 欧美精品丝袜久久久中文字幕 | 99久久国产综合精品网成人影院| 亚洲人AV永久一区二区三区久久| 青青青伊人色综合久久| 久久久久久国产精品免费无码| 久久久亚洲AV波多野结衣| 久久国产成人| 久久久久香蕉视频| 精品国产婷婷久久久|