Traversing an Entire Tree View's Hierarchy
Posted
by Vinayak Tadas
on December 11th, 1999
In a tree control it often becomes necessary to display the complete path in the tree from the selected item to the root. The path can be displayed as a string comprising of the labels of the tree items and starting from the root node to the selected item or from the selected item to the root item. The following function traverses the tree and retrieves the path from the selected item to the root.
// GetTreeHeirarchy - Retrieves the tree heirarchy as a string comprising of item labels from root node to selected node // hTItem - The HTREEITEM of selected item // cstrTreeHierarchy - String to store the Tree heirarchy // bTopToBottom - TRUE if the path should be from root to selected item FALSE if the path should be from the selected item to the root
void CMyTreeCtrl::GetTreeHierarchy(HTREEITEM hTItem, CString &cstrTreeHierarchy, const BOOL bTopToBottom)
{
HTREEITEM hTRootItem = GetParentItem(hTItem);
if ( hTRootItem == NULL ){
cstrTreeHierarchy += (GetItemText(hTItem)+"\\");
return;
}
if (!bTopToBottom)
cstrTreeHierarchy += (GetItemText(hTItem)+"\\");
GetTreeHierarchy(hTRootItem, cstrTreeHierarchy);
if (bTopToBottom)
cstrTreeHierarchy += (GetItemText(hTItem)+"\\");
}
To get the tree heirarchy, this function can be called as follows:
CString csTreeHeirarchy; m_pcMyTreeCtrl->GetTreeHierarchy(m_pcMyTreeCtrl->GetSelectedItem(), csTreeHeirarchy, TRUE);

Comments
Non-recursive way to traverse a TreeView ...
Posted by Legacy on 11/27/2001 12:00amOriginally posted by: Marco F
ReplyVery Nice.. It is recursive function.
Posted by Legacy on 05/04/2000 12:00amOriginally posted by: Kim mingu
It is recursive function..
Idea is good
ReplyGood one
Posted by Legacy on 03/04/2000 12:00amOriginally posted by: Siva
A very neat one.The only string operation that could be taken care of is the leading '\' symbol. Trivial.
ReplyThis is cool man, great job!!
Posted by Legacy on 12/14/1999 12:00amOriginally posted by: Jacob C Joseph
Great
Reply