码迷,mamicode.com
首页 > 其他好文 > 详细

树形控件简单样例

时间:2017-05-14 10:31:03      阅读:363      评论:0      收藏:0      [点我收藏+]

标签:插入   target   add   padding   initial   blank   字符   article   控件   


       此实例实现的功能:在一个树形控件中显示鸡啄米站点的简单结构分层,共同拥有三层。分别为鸡啄米站点、各个分类和文章。用鼠标左键单击改变选中节点后。将选中节点的文本显示到编辑框中。以下是详细实现步骤:

       1. 创建一个基于对话框的MFCproject,名称设置为“Example31”。

       2. 在自己主动生成的对话框模板IDD_EXAMPLE31_DIALOG中,删除“TODO: Place dialog controls here.”静态文本框、“OK”button和“Cancel”button。

加入一个Tree Control控件。ID设置为IDC_WEB_TREE,属性Has Buttons、Has Lines和Lines At Root都设为True,为了在鼠标划过某个节点时显示提示信息还须要将Info Tip属性设为True。

       3. 为树形控件IDC_WEB_TREE加入CTreeCtrl类型的控件变量m_webTree。

       4. 在对话框初始化时,我们在树形控件中加入鸡啄米站点的树形结构,那么须要改动CExample31Dlg::OnInitDialog()函数为:

C++代码
  1. BOOL CExample31Dlg::OnInitDialog()   
  2. {   
  3.     CDialogEx::OnInitDialog();   
  4.          ......略   
  5.   
  6.     // TODO: Add extra initialization here   
  7.     HTREEITEM hRoot;     // 树的根节点的句柄   
  8.     HTREEITEM hCataItem; // 可表示任一分类节点的句柄   
  9.     HTREEITEM hArtItem;  // 可表示任一文章节点的句柄    
  10.    
  11.     // 插入根节点   
  12.     hRoot = m_webTree.InsertItem(_T("鸡啄米"), 0, 0);   
  13.     // 在根节点下插入子节点   
  14.     hCataItem = m_webTree.InsertItem(_T("IT互联网"), 1, 1, hRoot, TVI_LAST);   
  15.     // 为“IT互联网”节点加入附加的编号数据,在鼠标划过该节点时显示   
  16.     m_webTree.SetItemData(hCataItem, 1);   
  17.     // 在“IT互联网”节点下插入子节点   
  18.     hArtItem = m_webTree.InsertItem(_T("百度文章1"), 2, 2, hCataItem, TVI_LAST);   
  19.     // 为“百度文章1”节点加入附加的编号数据,在鼠标划过该节点时显示   
  20.     m_webTree.SetItemData(hArtItem, 2);   
  21.     // 在“IT互联网”节点下插入还有一子节点   
  22.     hArtItem = m_webTree.InsertItem(_T("谷歌文章2"), 2, 2, hCataItem, TVI_LAST);   
  23.     // 为“谷歌文章2”节点加入附加的编号数据,在鼠标划过该节点时显示   
  24.     m_webTree.SetItemData(hArtItem, 3);   
  25.     // 在根节点下插入第二个子节点   
  26.     hCataItem = m_webTree.InsertItem(_T("数码生活"), 1, 1, hRoot, TVI_LAST);   
  27.     // 为“数码生活”节点加入附加的编号数据。在鼠标划过该节点时显示   
  28.     m_webTree.SetItemData(hCataItem, 4);   
  29.     // 在“数码生活”节点下插入子节点   
  30.     hArtItem = m_webTree.InsertItem(_T("智能手机文章1"), 2, 2, hCataItem, TVI_LAST);   
  31.     // 为“智能手机文章1”节点加入附加的编号数据,在鼠标划过该节点时显示   
  32.     m_webTree.SetItemData(hArtItem, 5);   
  33.     // 在“数码生活”节点下插入还有一子节点   
  34.     hArtItem = m_webTree.InsertItem(_T("平板电脑文章2"), 2, 2, hCataItem, TVI_LAST);   
  35.     // 为“平板电脑文章2”节点加入附加的编号数据。在鼠标划过该节点时显示   
  36.     m_webTree.SetItemData(hArtItem, 6);   
  37.     // 在根节点下插入第三个子节点   
  38.     hCataItem = m_webTree.InsertItem(_T("软件开发"), 1, 1, hRoot, TVI_LAST);   
  39.     // 为“软件开发”节点加入附加的编号数据,在鼠标划过该节点时显示   
  40.     m_webTree.SetItemData(hCataItem, 7);   
  41.     // 在“软件开发”节点下插入子节点   
  42.     hArtItem = m_webTree.InsertItem(_T("C++编程入门系列1"), 2, 2, hCataItem, TVI_LAST);   
  43.     // 为“C++编程入门系列1”节点加入附加的编号数据,在鼠标划过该节点时显示   
  44.     m_webTree.SetItemData(hArtItem, 8);   
  45.     // 在“软件开发”节点下插入还有一子节点   
  46.     hArtItem = m_webTree.InsertItem(_T("VS2010/MFC编程入门2"), 2, 2, hCataItem, TVI_LAST);   
  47.     // 为“VS2010/MFC编程入门2”节点加入附加的编号数据,在鼠标划过该节点时显示   
  48.     m_webTree.SetItemData(hArtItem, 9);   
  49.     // 在根节点下插入第四个子节点   
  50.     hCataItem = m_webTree.InsertItem(_T("娱乐休闲"), 1, 1, hRoot, TVI_LAST);   
  51.     // 为“娱乐休闲”节点加入附加的编号数据,在鼠标划过该节点时显示   
  52.     m_webTree.SetItemData(hCataItem, 10);   
  53.     // 在“娱乐休闲”节点下插入子节点   
  54.     hArtItem = m_webTree.InsertItem(_T("玛雅文明文章1"), 2, 2, hCataItem, TVI_LAST);   
  55.     // 为“玛雅文明文章1”节点加入附加的编号数据。在鼠标划过该节点时显示   
  56.     m_webTree.SetItemData(hArtItem, 11);   
  57.     // 在“娱乐休闲”节点下插入还有一子节点   
  58.     hArtItem = m_webTree.InsertItem(_T("IT笑话2"), 2, 2, hCataItem, TVI_LAST);   
  59.     // 为“IT笑话2”节点加入附加的编号数据,在鼠标划过该节点时显示   
  60.     m_webTree.SetItemData(hArtItem, 12);   
  61.   
  62.     return TRUE;  // return TRUE  unless you set the focus to a control   
  63. }  

       5. 我们希望在选中节点改变时,将最新的选择项实时显示到编辑框中,那么能够响应TVN_SELCHANGED通知消息。为树形控件IDC_WEB_TREE的通知消息TVN_SELCHANGED加入消息处理函数CExample31Dlg::OnTvnSelchangedWebTree,并改动函数体例如以下:

C++代码
  1. void CExample31Dlg::OnTvnSelchangedWebTree(NMHDR *pNMHDR, LRESULT *pResult)   
  2. {   
  3.     LPNMTREEVIEW pNMTreeView = reinterpret_cast<LPNMTREEVIEW>(pNMHDR);   
  4.     // TODO: Add your control notification handler code here   
  5.     *pResult = 0;   
  6.     CString strText; // 树节点的标签文本字符串   
  7.   
  8.     // 获取当前选中节点的句柄   
  9.     HTREEITEM hItem = m_webTree.GetSelectedItem();   

  10.     // 获取选中节点的标签文本字符串   
  11.     strText = m_webTree.GetItemText(hItem);   
  12. }  

    

树形控件简单样例

标签:插入   target   add   padding   initial   blank   字符   article   控件   

原文地址:http://www.cnblogs.com/llguanli/p/6851528.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!