项目需要做一个关于目录树节点的搜索功能
先讲一下大概思路,大部分人都会从根节点一步一步地往下展开,不断地迭代搜索,但是这个方法比较麻烦,因为要不断地记录父节点,一层一层往下,有几层就要记录几个父节点。
建议树节点是通过map来存储。
当搜索到指定树节点后,打开指定树节点的父节点,发现虽然上面几层没有展开,但是最里面的是展开的。
那么就有了这么一个思路,从下往上展开。
TreeItemMap::iterator connIter = PointItemMap.begin();
for (; connIter != PointItemMap.end(); connIter++)
{
if (strcmp(connIter->second.c_str(), W2A(strId.GetBuffer())) == 0)//对比找到所需要的节点
{
HTREEITEM hParent = connIter->first;
HTREEITEM hRoot = TreeView_GetNextItem(TreeCtrl, connIter->first, TVGN_ROOT);
while (hParent!=hRoot)//如果父节点不是根节点,就继续往上展开节点。
{
hParent = TreeView_GetNextItem(TreeCtrl, hParent, TVGN_PARENT);//获取其父节点
TreeCtrl.Expand(hParent, TVE_EXPAND);//展开其父节点
}
TreeCtrl.Select(connIter->first, TVGN_FIRSTVISIBLE);//高亮其搜索选中节点
TreeCtrl.Select(connIter->first, TVGN_DROPHILITE);
break;
}
}
//TreeCtrl是树形控件
这里之后有个小问题,就是因为在高亮选中节点之后,是被固定住的,则我们搜索选中后,点击其他节点却无法取消高亮。这里可以为树形控件增加一个选择改变函数来取消固定。
void CSipClientSdkTestDlg::OnSelchangedTreeDev(NMHDR *pNMHDR, LRESULT *pResult)//选中高亮后可以点击其他节点切换其他高亮
{
LPNMTREEVIEW pNMTreeView = reinterpret_cast<LPNMTREEVIEW>(pNMHDR);
TreeCtrl.Select(0, TVGN_DROPHILITE);//取消固定
*pResult = 0;
}
或者也可以做一个清空输入栏的按钮,同时取消固定
void CSipClientSdkTestDlg::OnBnClickedButtonClear()
{
GetDlgItem(IDC_EDIT)->SetWindowText(_T(""));
TreeCtrl.Select(0, TVGN_DROPHILITE);
}