⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 0501004.htm

📁 VC知识库5_chm_decompile_20040520_210715
💻 HTM
字号:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<!-- saved from url=(0066)http://person.zj.cninfo.net/~vcpark/study/common_ctrl/treectrl.htm -->
<HTML><HEAD><TITLE>四、PWIN98/95下演练CTree</TITLE>
<META content="text/html; charset=gb_2312-80" http-equiv=Content-Type>
<META content="Microsoft FrontPage 4.0" name=GENERATOR>
<STYLE>BIG {
	COLOR: #000000; FONT-SIZE: 14px
}
A {
	COLOR: #000000; FONT-SIZE: 14px
}
SMALL {
	COLOR: #000000; FONT-SIZE: 9pt
}
.h16 {
	LINE-HEIGHT: 16px
}
A:link {
	COLOR: #000000; TEXT-DECORATION: none
}
A:visited {
	COLOR: #7e704e; TEXT-DECORATION: none
}
A:hover {
	COLOR: #ff8000; TEXT-DECORATION: underline
}
</STYLE>
</HEAD>
<BODY><BIG>
<P align=center><FONT 
color=#0080c0><STRONG>四、PWIN98/95下演练CTree</STRONG></FONT></P>
<P align=justify>(一)树控制的主要功能</P>
<P align=justify>树控制和视(Tree   
Control&amp;View)主要用来显示具有一定层次结构的数据项,如资源管理器中的磁盘目录等,以供用户在其中进行各种选择。树控制中的每个数据项包括数据项名称的文本字符串和用于表示该数据项的图像,每个数据项下面均可包含各种子项,整个结构就象目录树一样。对于包含各种子项的数据项,可通过鼠标双击来展开或合拢,这可以通过控制树的不同风格来实现树控制的不同显示形态。这些风格主要包括:</P>  
<P   
align=justify>TVS_HASLINES表示用连线来连接父项和它下面的各个子项,这可以使树的显示层次结构更加清晰,但在无父项的各子项之间并没有连线;</P>  
<P align=justify>TVS_LINESATROOT表示在无父项的各子项即根下面的各子项之间存在连线;</P>  
<P   
align=justify>TVS_HASBUTTONS表示在带有子项的父项前面增加一个带“+”或“-”的按钮,这使得用户也可以通过单击这个小按钮来实现子项的展开和合拢,当存在子项时,按钮的初始状态为“+”,当子项被展开时,按小按钮由“+”变为“-”号,当子项合拢时,小按钮由“-”变为“+”号,这一风格同样对于根项无效,如果需要可通过组合TVS_LINESATROOT风格来实现;</P>  
<P align=justify>TVS_EDITLABELS表示允许让用户单击具有输入焦点的数据项来修改其名称。</P>  
<P   
align=justify>对于树控制,MFC中也以两种形式来封装,即树控制(CTREECTRL)和树视(CTREEVIEW),来满足用户的不同需求,对于一般要求的用户如在对话框中应用,使用树控制比较方便,而对于具有较高要求的用户,在使用树视时还具有视窗口的各种方便特性,可以更好地满足文档/视结构的要求。当在窗口中使用树视时,树视会占满两个窗口的客户区域并自动随窗口的框架结构的调整而调整,并能够很好地处理诸如菜单、加速键和工具条中的各种命令消息。在使用树视时只要利用其成员函数CtreeView取得其一个引用,就可以象树控制一样方便地应用:CtreeCtrl   
&amp;treeCtrl = GetTreeCtrl()。</P>  
<P align=justify>(二)树控制的对象结构</P>  
<P align=justify>1、树控制的建立方法</P>  
<P align=justify>CtreeCtrl&treeCtrl 建立树控制对象结构</P>  
<P align=justify>Create 建立树控制并绑定对象</P>  
<P align=justify>树控制CTreeCtrl::Create的调用格式如下:</P>  
<P align=justify>BOOL Create( DWORD dwStyle, const RECT&amp; rect, CWnd*   
pParentWnd, UINT nID );</P>  
<P   
align=justify>其中参数dwStyle用来确定树控制的类型;rect用来确定树控制的大小和位置;pParentWnd用来确定树控制的父窗口,通用是一个对话框并且不能为NULL;nID用来确定树控制的标识。树控制的风格可以是下列值的组合:</P>  
<P align=justify>TVS_HASLINES 表示树控制在各子项之间存在连线;</P>  
<P align=justify>TVS_LINESATROOT 表示树控制在根项之间存在连线;</P>  
<P align=justify>TVS_HASBUTTONS 表示树控制视在父项左侧存在展开合拢控制按钮;</P>  
<P align=justify>TVS_EDITLABELS 表示可以控制鼠标单击修改树项的名称;</P>  
<P align=justify>TVS_SHOWSELALWAYS 表示选中项即使在窗口失去输入焦点时仍然保持选中状态;</P>  
<P align=justify>TVS_DISABLEDRAGDROP表示禁止树控制发送TVN_BEGINDRAG消息</P>  
<P align=justify>2、树控制的属性类</P>  
<P   
align=justify>树控制属性类包括取得树控制中项数GetCount、取得树控制中项相对于父项的偏移值GetIndent、取得树控制图像列表控制句柄GetImageList、设置树控制图像列表控制句柄SetImageList、取得匹配下一个树项GetNextItem、判断给定树项是否包含子项ItemHasChildren、取得树项子项GetChildItem、取得下一个同属树项GetNextSiblingItem、取得前一个同属树项GetPrevSiblingItem、取得父树项GetParentItem、取得第一个可视树项GetFirstVisibleItem、取得下一个可视树项GetNextVisible   
Item、取得前一个可视的树项GetPrevVisibleItem、取得被选中的树项GetSelectedItem、取得根树项GetRootItem、取得树项的属性GetItem、设置树项的属性SetItem、取得树项的状态GetItemState、设置树项的状态SetItemState、取得与树项关联图像GetItemImage、设置与树项关联图像SetItemImage、取得树项文本GetItemText、设置树项文本SetItemText和取得树项编辑控制句柄GetEditControl等。</P>  
<P align=justify>3、树控制的操作方法</P>  
<P   
align=justify>树控制的操作方法包括插入一个树项InsertItem、删除一个树项DeleteItem、删除所有树项DeleteAllItems、展开或合拢树项的子项Expand、选中特定树项SelectItem、选择一个树项作为第一个可视树项SelectSetFirstVisible、编辑一个可视的树项EditLabel和排序给定父树项的子树项SortChildren等。</P>  
<P align=justify>(三)树控制的数据结构</P>  
<P   
align=justify>在使用树控制时需要了解两个个非常重要的数据结构TV_ITEM和TV_INSERTSTRUCT,前一个数据结构是用来表示树控制的树项信息,后一个数据结构是用来定义将树项增加到数据控制中所需要的数据内容。另外,还需要NM_TREEVIEW、TV_DISPINFO和TV_HITTESTINFO三个数据结构,这几个数据结构的定义方法如下:</P>  
<P align=justify>①基本数据项结构</P>  
<P align=justify>typedef struct _TV_ITEM {</P>  
<P align=justify>UINT mask; //结构成员有效性屏蔽位</P>  
<P align=justify>HTREEITEM hItem; //数据项控制句柄</P>  
<P align=justify>UINT state; //数据项状态</P>  
<P align=justify>UINT stateMask; //状态有效性屏蔽位</P>  
<P align=justify>LPSTR pszText; //数据项名称字符串</P>  
<P align=justify>int cchTextMax; //数据项名称的最大长度</P>  
<P align=justify>int iImage; //数据项图标索引号</P>  
<P align=justify>int iSelectedImage;//选中数据项图标索引号</P>  
<P align=justify>int cChildren; //子项标识</P>  
<P align=justify>LPARAM lParam; //程序定义的32位数据</P>  
<P align=justify>} TV_ITEM, FAR *LPTV_ITEM; </P>  
<P align=justify>②插入树项结构</P>  
<P align=justify>typedef struct _TV_INSER TSTRUCT {</P>  
<P align=justify>HTREEITEM hParent; //父项控制句柄</P>  
<P align=justify>HTREEITEM hInsertAfter; //插入树项的位置</P>  
<P align=justify>TV_ITEM item; //数据项的结构</P>  
<P align=justify>} TV_INSERTSTRUCT, FAR *LPTV_INSERTSTRUCT; </P>  
<P align=justify>其中插入的位置如果是TVI_FIRST 或TVI_LAST ,则分别插入到树控制的最前面或最后面,如果是TVI_SORT   
,则插入的树项自动插入到合适的位置。</P>  
<P align=justify>③树控制通知消息结构</P>  
<P align=justify>typedef struct _NM_TREEVIEW {</P>  
<P align=justify>NMHDR hdr; //通知消息句柄</P>  
<P align=justify>UINT action; //通知消息标志</P>  
<P align=justify>TV_ITEM itemOld; //原来的数据结构</P>  
<P align=justify>TV_ITEM itemNew; //新的数据结构</P>  
<P align=justify>POINT ptDrag; //拖动指针</P>  
<P align=justify>} NM_TREEVIEW; </P>  
<P align=justify>④取得或设置数据结构</P>  
<P align=justify>typedef struct _TV_DISPINFO { tvdi </P>  
<P align=justify>NMHDR hdr; //通知消息控制句柄</P>  
<P align=justify>TV_ITEM item; //数据项结构</P>  
<P align=justify>} TV_DISPINFO;</P>  
<P align=justify>⑤指针测试数据结构</P>  
<P align=justify>typedef struct _TVHITTESTINFO { tvhtst </P>  
<P align=justify>POINT pt; //客户区域屏幕坐标指针</P>  
<P align=justify>UINT flags; //存放测试结果的变量</P>  
<P align=justify>HTREEITEM hItem; //测试的数据项结构</P>  
<P align=justify>} TV_HITTESTINFO, FAR *LPTV_HITTESTINFO; </P>  
<P align=justify>其中flags测试结果可以是如下值:</P>  
<P align=justify>TVHT_ABOVE 在客户区域上面</P>  
<P align=justify>TVHT_BELOW 在客户区域下面</P>  
<P align=justify>TVHT_NOWHERE 在客户区域中并在最后一项下面</P>  
<P align=justify>TVHT_ONITEM 在与树项关联的位图或标签内</P>  
<P align=justify>TVHT_ONITEMBUTTON 在与树项关联的按钮上</P>  
<P align=justify>TVHT_ONITEMICON 在与树项关联的位图上</P>  
<P align=justify>TVHT_ONITEMINDENT 在与树项关联的联线上</P>  
<P align=justify>TVHT_ONITEMLABEL 在与树项关联的标签上</P>  
<P align=justify>TVHT_ONITEMRIGHT 在树项的右侧区域中</P>  
<P align=justify>TVHT_ONITEMSTATEICON 在用户定义的状态图标上</P>  
<P align=justify>TVHT_TOLEFT 在客户区域的左侧</P>  
<P align=justify>TVHT_TORIGHT 在客户区域的右侧</P>  
<P align=justify>(四)树控制的应用技巧示例</P>  
<P align=justify>这里仍以基于对话框演示实例来具体介绍树控制及其和图像列表相结构的应用技巧:</P>  
<P align=justify>通过“FILE-&gt;NEW-&gt;PROJECTS-&gt;MFC   
AppWizard(EXE)”建立名为VCTREE的工程,在建立过程中选择基于对话框(Dialog   
based)的应用;将对话框中的默认控件删除,并将所有对话框属性中的Language域设置为Chinese(P.R.C.),以使应用程序支持中文;建立两个图标IDI_PM和IDI_CJ,用来表示图标的选中和非选中状态,对于每个图标都应建立32X32和16X16两种大小,以保证程序的需要;在对话框窗口中添加树控制对象(TREE   
CONTROL),并设置五个按钮“增加|删除|查看|排序|关闭”,其对应标识分别如下:</P>  
<HR align=left SIZE=1 width="78%">  
  
<P>控制名称 标题名称 标识符号</P>  
<HR align=left SIZE=1 width="78%">  
  
<P>树控制 IDC_TREECTRL</P>  
<P align=justify>按钮 增 加 IDC_ADD</P>  
<P align=justify>删 除 IDC_DEL</P>  
<P align=justify>查 看 IDC_VIEW</P>  
<P align=justify>排 序 IDC_SORT</P>  
<P align=justify>关 闭 IDOK</P>  
<HR align=left SIZE=1 width="82%">  
  
<P align=justify>5、选中树控制控件,选择“VIEW-&gt;ClassWizard-&gt;Memory   
Variables。

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -