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

            積木

            No sub title

              C++博客 :: 首頁(yè) :: 聯(lián)系 :: 聚合  :: 管理
              140 Posts :: 1 Stories :: 11 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(1)

            我參與的團(tuán)隊(duì)

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            MFC 之樹(shù)控件篇

            CTreeCtrl m_wndMyTree;

            1) 取得樹(shù)的當(dāng)前選中節(jié)點(diǎn):
            HTREEITEM hSelectedItem = m_wndMyTree.GetSelectedItem();

            2) 取得指定節(jié)點(diǎn)的標(biāo)簽值(也就是Caption):
            CString strCaption = m_wndMyTree.GetItemText(hSelectedItem);

            3) 記住:MFC中的樹(shù)的節(jié)點(diǎn),是沒(méi)有索引這一概念的。一棵樹(shù)的唯一辨別方法是通過(guò)樹(shù)節(jié)點(diǎn)
            的句柄(HTREEITEM)區(qū)別的。(這一點(diǎn)不同于Delphi中的樹(shù)).Delphi中的樹(shù)是的每個(gè)節(jié)點(diǎn)都
            有以下兩個(gè)屬性:a) 節(jié)點(diǎn)的層次 b) 節(jié)點(diǎn)的在當(dāng)前層次中其父節(jié)點(diǎn)下的第幾個(gè)索引號(hào)。

            4) 可以通過(guò)如下方法,對(duì)樹(shù)節(jié)點(diǎn)進(jìn)行額外數(shù)據(jù)的存儲(chǔ)。
            CMyClass *pObj = new CMyClass;
            m_wndMyTree.SetItemData(hSelectedItem, (DWORD_PTR)pObj);
            上面這兩句,等同于Delphi的:
            hSelectedItem.Data := Pointer(pObj);//或 hSelectedItem := pObj;
            另外,需要注意的一點(diǎn):為樹(shù)節(jié)點(diǎn)設(shè)置了Data值后,在刪除節(jié)點(diǎn)時(shí),需要釋放掉它。(這在
            Delphi中是必須要做的一件事。在MFC中,本人相信也是必須要做的。因本人也初學(xué)MFC,故
            未經(jīng)驗(yàn)證。待有機(jī)會(huì),再行驗(yàn)證)

            有了上面的SetItemData()。固然也會(huì)有GetItemData()

            CMyClass *pMyObj = (CMyClass *)m_wndMyTree.GetItemData(hSelectedItem);
            ...


            5) 取得樹(shù)的根節(jié)點(diǎn):
            HTREEITEM hRoot = m_wndMyTree.GetRootItem();

            6) 取得指定節(jié)點(diǎn)的下一個(gè)兄弟節(jié)點(diǎn)
            HTREEITEM hCurrItem = xxx;
            HTREEITEM hNextItem = m_wndMyTree.GetNextItem(hCurrItem, TVGN_NEXT);

            7) 取得指定節(jié)點(diǎn)的第一個(gè)子節(jié)點(diǎn):
            HTREEITEM hFirstChildItem = m_wndMyTree.GetNextItem(hCurrItem, TVGN_CHILD);

            有了上面的5、6、7,我們就可以對(duì)樹(shù)進(jìn)行遍歷。參考示例如下:

            void CViewTree::RecursiveTree(HTREEITEM hItem/* = NULL*/)
            {
             if (NULL == hItem)
              return ;
             AfxMessageBox(GetItemText(hItem));
             HTREEITEM hFirstChild = GetNextItem(hItem, TVGN_CHILD);

             if (NULL != hFirstChild)
              RecursiveTree(hFirstChild);

             HTREEITEM hNextItem = GetNextItem(hItem, TVGN_NEXT);
             if (NULL != hNextItem)
              RecursiveTree(hNextItem);
            }

            調(diào)用方法如下:

             HTREEITEM hRoot = GetRootItem();
             if (NULL == hRoot)
             {
              AfxMessageBox(_T("對(duì)不起,當(dāng)前這棵樹(shù)沒(méi)有任何節(jié)點(diǎn)。"));
             }
             else
             {
              this->RecursiveTree(hRoot);
             }

            8) 判斷指定節(jié)點(diǎn)下是否有子節(jié)點(diǎn)
            方法一:
            HTREEITEM hCurrItem = xxx;
            HTREEITEM hFirstChild = GetNextItem(hCurrItem, TVGN_CHILD);
            if (NULL != hFirstChild)
                  //有子節(jié)點(diǎn)
            else
                  //沒(méi)有子節(jié)點(diǎn)
            方法二:
            if (ItemHasChildren(hCurrItem))
                  //有子節(jié)點(diǎn)
            else
                  //沒(méi)有子節(jié)點(diǎn)
            9) 清除所有節(jié)點(diǎn):
            m_wndMyTree.DeleteAllItems();

            以上為常用的一些方法總結(jié)。詳細(xì)的,可查看CTreeCtrl類(lèi)接口聲明。。或詳查MSDN

            posted on 2011-10-01 19:19 Jacc.Kim 閱讀(4032) 評(píng)論(2)  編輯 收藏 引用 所屬分類(lèi): VC / C++

            Feedback

            # re: MFC 之樹(shù)控件篇[未登錄](méi) 2012-03-02 16:27 1
            大家搜知道  回復(fù)  更多評(píng)論
              

            # re: MFC 之樹(shù)控件篇[未登錄](méi) 2012-03-02 16:28 1
            可以來(lái)點(diǎn)難點(diǎn)的嗎 如設(shè)置某一條目不可用 但可見(jiàn)   回復(fù)  更多評(píng)論
              

            色综合久久精品中文字幕首页 | 久久久久久久综合日本| 久久久久亚洲AV片无码下载蜜桃| 四虎国产精品成人免费久久| 99久久做夜夜爱天天做精品| 国产精品女同久久久久电影院| 国产精品久久久久乳精品爆| 久久亚洲精品国产亚洲老地址| 亚洲精品99久久久久中文字幕| 少妇内射兰兰久久| 2020久久精品国产免费| 久久亚洲国产精品123区| 亚洲精品无码久久久久sm| 久久99精品久久久久久野外| 一本久久a久久精品vr综合| 久久久艹| 99久久精品费精品国产| 久久久久亚洲AV无码网站| 三级三级久久三级久久| 国产午夜福利精品久久| 精品永久久福利一区二区| 久久亚洲日韩看片无码| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 久久免费高清视频| 老男人久久青草av高清| 亚洲嫩草影院久久精品| 亚洲AV无码久久精品成人 | 国产A三级久久精品| 麻豆久久久9性大片| 久久久久亚洲AV无码专区网站| 久久精品这里热有精品| 国产高潮国产高潮久久久| 人妻无码久久一区二区三区免费 | 久久精品中文无码资源站| 四虎国产精品免费久久| 亚洲国产精品成人AV无码久久综合影院| 精品国产91久久久久久久a| 国产精品伊人久久伊人电影 | 久久亚洲春色中文字幕久久久| 久久久久久亚洲精品影院| 色偷偷91久久综合噜噜噜噜|