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