• <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++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              140 Posts :: 1 Stories :: 11 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(1)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            MFC 之樹控件篇

            CTreeCtrl m_wndMyTree;

            1) 取得樹的當前選中節點:
            HTREEITEM hSelectedItem = m_wndMyTree.GetSelectedItem();

            2) 取得指定節點的標簽值(也就是Caption):
            CString strCaption = m_wndMyTree.GetItemText(hSelectedItem);

            3) 記住:MFC中的樹的節點,是沒有索引這一概念的。一棵樹的唯一辨別方法是通過樹節點
            的句柄(HTREEITEM)區別的。(這一點不同于Delphi中的樹).Delphi中的樹是的每個節點都
            有以下兩個屬性:a) 節點的層次 b) 節點的在當前層次中其父節點下的第幾個索引號。

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

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

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


            5) 取得樹的根節點:
            HTREEITEM hRoot = m_wndMyTree.GetRootItem();

            6) 取得指定節點的下一個兄弟節點
            HTREEITEM hCurrItem = xxx;
            HTREEITEM hNextItem = m_wndMyTree.GetNextItem(hCurrItem, TVGN_NEXT);

            7) 取得指定節點的第一個子節點:
            HTREEITEM hFirstChildItem = m_wndMyTree.GetNextItem(hCurrItem, TVGN_CHILD);

            有了上面的5、6、7,我們就可以對樹進行遍歷。參考示例如下:

            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);
            }

            調用方法如下:

             HTREEITEM hRoot = GetRootItem();
             if (NULL == hRoot)
             {
              AfxMessageBox(_T("對不起,當前這棵樹沒有任何節點。"));
             }
             else
             {
              this->RecursiveTree(hRoot);
             }

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

            以上為常用的一些方法總結。詳細的,可查看CTreeCtrl類接口聲明。。或詳查MSDN

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

            Feedback

            # re: MFC 之樹控件篇[未登錄] 2012-03-02 16:27 1
            大家搜知道  回復  更多評論
              

            # re: MFC 之樹控件篇[未登錄] 2012-03-02 16:28 1
            可以來點難點的嗎 如設置某一條目不可用 但可見   回復  更多評論
              

            国产Av激情久久无码天堂| 久久A级毛片免费观看| 国产午夜福利精品久久2021| 亚洲一级Av无码毛片久久精品| 97久久久精品综合88久久| 色欲综合久久躁天天躁蜜桃| 午夜精品久久久久| 久久久久久久91精品免费观看| 国产午夜精品久久久久九九| 91精品国产乱码久久久久久| 久久久精品人妻一区二区三区四 | 伊人久久大香线蕉av不变影院| 国产精品成人久久久久久久| 久久亚洲高清观看| 亚洲精品国产成人99久久| 97久久综合精品久久久综合| 久久精品国产亚洲av麻豆色欲| 午夜精品久久久久久久| 色狠狠久久AV五月综合| 久久夜色精品国产噜噜亚洲AV| 亚洲午夜久久久久久久久久| 久久亚洲精精品中文字幕| 无码精品久久久久久人妻中字| 久久久久久国产精品免费无码| 久久精品欧美日韩精品| 久久这里只有精品18| 91精品国产高清久久久久久io| 久久中文娱乐网| 久久伊人亚洲AV无码网站| 亚洲午夜无码AV毛片久久| 久久久亚洲AV波多野结衣| 日本强好片久久久久久AAA| 97久久超碰成人精品网站| 97久久香蕉国产线看观看| 久久精品国产精品亚洲下载| 久久人妻少妇嫩草AV蜜桃| 久久精品亚洲一区二区三区浴池| 久久这里只精品国产99热| 久久久高清免费视频| 狠狠色丁香久久婷婷综合五月| 国产午夜精品理论片久久|