tree树形控件之循环遍历

本文介绍了如何在C++中使用CTreeCtrl类遍历树形控件,寻找包含特定文本的节点。通过递归方式,从根节点开始逐级检查每个节点的文本,如果找到匹配的节点,则返回该节点的句柄。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在写程序时需要对树形控件进行查询指定文本的内容,因此写了本函数。

 

//item:待遍历树的根节点,strtext:待查找节点名称
HTREEITEM  Ctest2Dlg::FindItem(CTreeCtrl &ctrlTree ,HTREEITEM  item, CString strtext) 

 HTREEITEM  hfind;

 //空树,直接返回NULL
 if(item ==  NULL) 
  return  NULL;

 //遍历查找
 while(item!=NULL) 
 { 
  //当前节点即所需查找节点
  if(ctrlTree.GetItemText(item) == strtext)
   return  item; 


  //查找当前节点的子节点
  if(ctrlTree.ItemHasChildren(item))
  { 
   item=ctrlTree.GetChildItem(item);
   //递归调用查找子节点下节点

   hfind  =  FindItem(ctrlTree,item,strtext); 
   if(hfind) 
   { 
    return  hfind; 
   } 
   else
   {
    //子节点中未发现所需节点,继续查找兄弟节点
    item = ctrlTree.GetNextSiblingItem(ctrlTree.GetParentItem(item));
   }
  }else
  { 
   //若无子节点,继续查找兄弟节点
   item = ctrlTree.GetNextSiblingItem(item);
  } 
 } 

 return item; 
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值