CTreeCtrl利用TV_ITEM插入节点与遍历节点

插入树节点

TV_ITEM tvItem;
tvItem.mask = TVIF_TEXT | TVIF_PARAM | TVIF_IMAGE | TVIF_HANDLE | TVIF_SELECTEDIMAGE | TVIS_SELECTED | TVIS_EXPANDED; 
CString TmpStr = "文本内容"
tvItem.pszText =(LPWSTR)(LPCTSTR)TmpStr;
tvItem.cchTextMax = MAX_PATH;
tvItem.lParam  =nID;  // 额外参数
tvItem.iImage =0;      // 未被选中时显示的图片
tvItem.iSelectedImage = 1;   // 选中时显示的图片


TV_INSERTSTRUCT tvInsert;
tvInsert.hParent = ParentNode;  // 确定父节点
tvInsert.hInsertAfter = TVI_LAST;
tvInsert.item = tvItem;       

HTREEITEM RetItm = m_tree.InsertItem(&tvInsert);

 

 

// 遍历树节点,代码为获得树控件节点的item.lparam

GetChildItemID(CTreeCtrl* pCtrlTree,HTREEITEM& hNode)
{
    TVITEM item;
    item.mask = TVIF_PARAM;

    if (pCtrlTree->ItemHasChildren(hNode))//是否有孩子节点
    {
        HTREEITEM hNextItem;
        HTREEITEM hChildItem = pCtrlTree->GetChildItem(hNode); 

        while (hChildItem != NULL)
        {
            hNextItem = pCtrlTree->GetNextItem(hChildItem, TVGN_NEXT);
            item.hItem = hChildItem;
            pCtrlTree->GetItem(&item);
            //得到item.lParam
            GetChildOrgID(pCtrlTree,hChildItem);//遍历
            hChildItem = hNextItem;
        }

    }

}

 

 

 

// 遍历添加节点


AddTreeItem(CTreeCtrl* pCtrlTree,HTREEITEM& ParentNode,  const  int nParentID)
{
    int nCount=m_OrgArr.size();//m_OrgArr是一个vector<int>类型的数组
    HTREEITEM RetItm;

    for(int i=0;i<nCount;i++)
    {
        XXX*    pObj    =    (XXX*)(int)m_OrgArr.at(i);

        if(pObj->nParentID==nParentID)//满足要求就插入了
        {
            TV_ITEM tvItem;
            tvItem.mask = TVIF_TEXT | TVIF_PARAM | TVIF_IMAGE | TVIF_HANDLE | TVIF_SELECTEDIMAGE | TVIS_SELECTED | TVIS_EXPANDED; 
            CString TmpStr = pObj->sTest; //(LPSTR)
            tvItem.pszText =(LPWSTR)(LPCTSTR)TmpStr;
            tvItem.cchTextMax = MAX_PATH;
            tvItem.lParam  =pObj->nID;
            tvItem.iImage =0;
            tvItem.iSelectedImage = 1;
            
            TV_INSERTSTRUCT tvInsert;
            tvInsert.hParent = ParentNode;
            tvInsert.hInsertAfter = TVI_LAST;
            tvInsert.item = tvItem;

            HTREEITEM RetItm = pCtrlTree->InsertItem(&tvInsert);
             AddTreeItem(pCtrlTree,RetItm,pObj->nID);
        }

    }


}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现鼠标滑过节点显示图片,可以使用CTreeCtrl的NM_CUSTOMDRAW消息来自定义绘制节点。具体实现步骤如下: 1. 响应CTreeCtrl的NM_CUSTOMDRAW消息,并在OnCustomDraw函数中处理。 2. 判断绘制的节点是否是鼠标滑过的节点,可以使用CTreeCtrl的HitTest函数。 3. 如果是鼠标滑过的节点,就在该节点的位置显示图片,可以使用CImageList的Draw函数。 下面是代码示例: ``` void CMyTreeCtrl::OnCustomDraw(NMHDR* pNMHDR, LRESULT* pResult) { NMTVCUSTOMDRAW* pNMCD = reinterpret_cast<NMTVCUSTOMDRAW*>(pNMHDR); *pResult = CDRF_DODEFAULT; switch (pNMCD->nmcd.dwDrawStage) { case CDDS_PREPAINT: *pResult = CDRF_NOTIFYITEMDRAW; break; case CDDS_ITEMPREPAINT: *pResult = CDRF_NOTIFYITEMDRAW; break; case CDDS_ITEMPREPAINT | CDDS_SUBITEM: { HTREEITEM hItem = reinterpret_cast<HTREEITEM>(pNMCD->nmcd.dwItemSpec); if (hItem == GetHoverItem()) { CRect rect; GetItemRect(hItem, rect, TRUE); rect.left += m_nIndent + 2; rect.top += 1; rect.bottom -= 1; int nImage = GetItemImage(hItem, FALSE); if (nImage != -1) { CImageList* pImageList = GetImageList(TVSIL_NORMAL); if (pImageList != NULL) { pImageList->Draw(&pNMCD->nmcd.hdc, nImage, rect.TopLeft(), ILD_NORMAL); } } } } break; } *pResult |= CDRF_NOTIFYPOSTPAINT; } HTREEITEM CMyTreeCtrl::GetHoverItem() const { HTREEITEM hItem = NULL; CPoint pt; GetCursorPos(&pt); ScreenToClient(&pt); UINT uFlags; hItem = HitTest(pt, &uFlags); if ((uFlags & TVHT_ONITEM) == 0) { hItem = NULL; } return hItem; } ``` 在OnMouseMove函数中,可以调用RedrawWindow函数来刷新树形控件,以便及时显示鼠标滑过的节点的图片。 ``` void CMyTreeCtrl::OnMouseMove(UINT nFlags, CPoint point) { HTREEITEM hHoverItem = GetHoverItem(); if (hHoverItem != m_hHoverItem) { m_hHoverItem = hHoverItem; RedrawWindow(); } CTreeCtrl::OnMouseMove(nFlags, point); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值