TreeView控件的详细注解

发布于 2022-08-21 19:00:21 字数 7612 浏览 8 评论 0

TreeView控件  TreeView 控件显示 Node 对象的分层列表,每个 Node 对象均由一个标签和一个可选的位图组成。TreeView 一般用于显示文档标题、索引入口、磁盘上的文件和目录、或能被有效地分层显示的其它种类信息。创建了 TreeView 控件之后,可以通过设置属性与调用方法对各 Node 对象进行操作,这些操作包括添加、删除、对齐和其它操作。可以编程展开与折回 Node 对象来显示或隐藏所有子节点。Collapse、Expand 和 NodeClick 三个事件也提供编程功能。Node 对象使用 Root、Parent、Child、FirstSibling、Next、Previous 和 LastSibling 属性。在代码中可通过检索对 Node 对象的引用,从而在树上定位。也可以使用键盘定位。UP ARROW 键和 DOWN ARROW 键向下循环穿过所有展开的 Node 对象。从左到右、从上到下地选择 Node 对象。若在树的底部,选择便跳回树的顶部,必要时滚动窗口。RIGHT ARROW 键和 LEFT ARROW 键也穿过所有展开的 Node 对象,但是如果选择了未展开的 Node之后再按 RIGHT ARROW 键,该 Node 便展开;第二次按该键,选择将移向下一个 Node。相反,若扩展的 Node 有焦点,这时再按 LEFT ARROW 键,该 Node 便折回。如果按下 ANSI 字符集 中的键,焦点将跳转至以那个字母开头的最近的 Node。后续的按该键的动作将使选择向下循环,穿过以那个字母开头的所有展开节点。
  控件的外观有八种可用的替换样式,它们是文本、位图、直线和 +/- 号的组合,Node 对象可以任一种组合出现。
  TreeView 控件使用由 ImageList 属性指定的 ImageList 控件,来存储显示于 Node 对象的位图和图标。任何时刻,TreeView 控件只能使用一个 ImageList。这意味着,当 TreeView 控件的 Style 属性被设置成显示图象的样式时,TreeView 控件中每一项的旁边都有一个同样大小的图象。
  发行注意 TreeView 控件是 COMCTL32.OCX 文件中的一组 ActiveX 控件的一部分。为了在应用程序中使用 TreeView 控件,必须将 COMCTL32.OCX 文件添加到工程中。在发行应用程序时,要在用户的 Microsoft Windows System 或 System32 目录中安装 COMCTL32.OCX 文件。
  属性
  DropHighlight属性(ListView, TreeView控件),
  Indentation属性,
  LabelEdit属性,
  LineStyle属性,
  Nodes属性,
  PathSeparator属性(TreeView控件),
  SelectedItem属性(ActiveX控件),
  Sorted属性(TreeView控件),
  Style属性(TreeView控件),
  Checkboxes属性,
  FullRowSelect属性,
  Scroll属性,
  SingleSel属性,
  HotTracking属性,
  TabIndex属性,
  Tag属性,
  Visible属性,
  DragIcon属性,
  DragMode属性,
  CausesValidation属性,
  MouseIcon属性,
  TabStop属性,
  HelpContextID属性,
  Name属性,
  Parent属性,
  Container属性,
  ToolTipText属性,
  WhatsThisHelpID属性,
  OLEDragMode属性(ActiveX控件),
  OLEDropMode属性(ActiveX控件),
  Height , Width属性(ActiveX控件),
  Index属性(ActiveX控件),
  Left, Top属性(ActiveX控件),
  Object属性(ActiveX控件),
  Appearance属性(ActiveX控件),
  BorderStyle属性(ActiveX控件),
  Enable属性(ActiveX控件),
  Font属性(ActiveX控件),
  HideSelection属性(ActiveX控件),
  hWnd属性(ActiveX控件),
  MousePointer属性(ActiveX控件),
  ImageList属性(ActiveX控件)。
  方法
  GetVisibleCount方法,
  HitTest方法(ListView, TreeView控件),
  StartLabelEdit方法,
  SetFocus方法,
  Drag方法,
  Move方法,
  ZOrder方法,
  ShowWhatsThis方法,
  OLEDrag方法(ActiveX控件),
  Refresh方法(ActiveX控件)。
  -----------------------------------------------------------------------------------------------------------
  常用属性
  1、Nodes属性返回对TreeView控件的Node对象的集合的引用。
  语法:object.Nodes
  ? ject所在处代表一个对象表达式,其值是“应用于”列表中的一个对象。
  说明:可以使用标准的集合方法(例如:Add和Remove方法)操作Node对象。可以按其索引或存储在Key属性中的唯一键来访问集合中的每个元素。
  2、Style属性返回或设置图形类型(图象、文本、+/-号、直线)以及出现在 TreeView 控件中每一Node对象上的文本的类型。
  语法:object.Style [ = number]
  Style 语法包含下面部分:
  部分 描述
object 对象表达式,其值是“应用于”列表中的一个对象。
number 指定图形类型的整数,请参阅“设置值”中的描述。

  设置值
  number 的设置值是:
  设置值 描述
0 仅为文本。
1 图象和文本。
2 +/- 号和文本。
3 +/- 号,图象和文本。
4 直线和文本。
5 直线,图象和文本。
6 直线,+/- 号和文本。
7 (缺省)直线,+/- 号,图象和文本。

  说明:若Style属性设置为包含直线的值,则LineStyle属性就确定了直线的外观。如果Style属性设置为不含直线的值,则LineStyle属性将被忽略。
  3、Sorted属性返回或设置一值,此值确定Node对象的子节点是否按字母顺序排列;返回或设置一值,此值确定TreeView控件的根层节点是否按字母顺序排列。
  语法:object.Sorted [ = boolean]
  Sorted属性语法包含下面部分:
  部分 描述
object 对象表达式,其值是“应用于”列表中的一个对象。
boolean 布尔表达式,表示 Node 对象是否已被排序如“设置值”中描述。

  boolean的设置值是:
  设置值 描述
True Node 对象根据它们的 Text 属性按字母顺序排列。其 Text 属性由数字开始的 Node 对象也作为字符串排序,第一个数字确定在排序中的初始位置,后面的数字确定以后的排序。
False Node 对象不排序。

  说明:Sorted属性有两种用法,第一,在TreeView控件的根(顶)层排列Node对象,第二,对任何单个Node对象的立即子节点排序。
  例如,下面的代码是对TreeView控件的根节点排序:
  TreeView1.Sorted = True 顶层Node对象被排序。
  下面的例子表示创建Node对象时如何设置Sorted属性:
  Dim nodX As Node
  Set nodX = TreeView1.Nodes.Add(,,,"Parent Node")
  nodX.Sorted = True
  设置 Sorted 属性为True仅对当前Nodes集合排序。在TreeView控件中添加新的Node对象时,必须再次设置 Sorted 属性为 True,以便对添加的 Node 对象排列。
  常用方法
  1、Add 方法在Treeview控件的Nodes集合中添加一个Node对象。
  语法:
  object.Add(relative, relationship, key, text, image, selectedimage)
  Add 方法的语法包含下面部分:部分 描述
object 必需的。对象表达式,其值是“应用于”列表中的一个对象
relative 可选的。已存在的 Node 对象的索引号或键值。新节点与已存在的节点间的关系,可在下一个参数 relationship 中找到。
relationship 可选的。指定的 Node 对象的相对位置,如设置值中所述。
key 可选的。唯一的字符串,可用于用 Item 方法检索 Node。
text 必需的。在 Node 中出现的字符串。
image 可选的。在关联的 ImageList 控件中的图象的索引。
selectedimage 可选的。在关联的 ImageList 控件中的图象的索引,在 Node 被选中时显示。

  设置值
  relationship 的设置值是:
  常数 值 描述
tvwFirst 0 首的节点。该 Node 和在 relative 中被命名的节点位于同一层,并 位于所有同层节点之前。
tvwLast 1 最后的节点。该 Node 和在 relative 中被命名的节点位于同一层,并 位于所有同层节点之后。任何连续地添加的节点可能位于最后添加的节点之后
tvwNext 2 (缺省)下一个节点。该 Node 位于在 relative 中被命名的节点之后。
tvwPrevious 3 前一个节点。该 Node 位于在 relative 中被命名的节点之前。
tvwChild 4 (缺省)子节点。该 Node 成为在 relative 中被命名的节点的子节点。

  注意:如果在relative中没有被命名的Node对象,则新节点被放在节点顶层的最后位置。
  说明:Nodes 集合是一个基于 1 的集合。在添加Node对象时,它被指派一个索引号,该索引号被存储在Node对象的Index属性中。这个最新成员的Index属性值就是Node集合的Count属性的值。因为Add方法返回对新建立的Node对象的引用,所以使用这个引用来设置新Node的属性十分方便。
  2、GetVisibleCount方法返回固定在 TreeView 控件的内部区域的 Node 对象的个数。
  语法:object.GetVisibleCount
  object 所在处代表一个对象表达式,其值是“应用于”列表中的一个对象。
  说明: Node 对象的个数取决于在一个窗口中能固定多少行。总的行数取决于控件的高度和 Font 对象的 Size 属性。该计数包括列表底部的只能看到一局部的项。可以使用 GetVisibleCount 属性确保可视的最小行数,这样可以精确地访问一个层。如果最小行数是不可视的,可以用Height属性重新设置TreeView的大小。
  常用事件
  NodeClick 事件在一个 Node 对象被单击时,这个事件便发生。语法:Private Sub object_NodeClick(ByVal node As Node)
  NodeClick 事件的语法包含下面部分::
  部分 描述
  object 对象表达式,其值是“应用于”列表中的一个对象。
  node 对被点取的 Node 对象的引用。
  说明:
  在单击节点对象之外的 TreeView 控件的任何部位,标准的 Click 事件发生。当单击某个特定的 Node 对象时,NodeClick 事件发生;NodeClick 事件也返回对特定的 Node 对象的引用,在下一步操作之前,这个引用可用来使这个 Node 对象可用。
  NodeClick 事件发生在标准的 Click 事件之前。
  语法
  object.Add(relative, relationship, key, text, image, selectedimage)
  Add 方法的语法包含下面部分:
  部分 描述
  object 必需的。对象表达式,其值是“应用于”列表中的一个对象
  relative 可选的。已存在的 Node 对象的索引号或键值。新节点与已存在的节点间的关系,可在下一个参数 relationship 中找到。
  relationship 可选的。指定的 Node 对象的相对位置,如设置值中所述。
  key 可选的。唯一的字符串,可用于用 Item 方法检索 Node。
  text 必需的。在 Node 中出现的字符串。
  image 可选的。在关联的 ImageList 控件中的图像的索引。
  selectedimage 可选的。在关联的 ImageList 控件中的图像的索引,在 Node 被选中时显示。
  设置值
  relationship 的设置值是:
  常数 值 描述
  tvwFirst 0 首的节点。该 Node 和在 relative 中被命名的节点位于同一层,并 位于所有同层节点之前。
  tvwLast 1 最后的节点。该 Node 和在 relative 中被命名的节点位于同一层,并 位于所有同层节点之后。任何连续地添加的节点可能位于最后添加的节点之后
  tvwNext 2 (缺省)下一个节点。该 Node 位于在 relative 中被命名的节点之后。
  tvwPrevious 3 前一个节点。该 Node 位于在 relative 中被命名的节点之前。
  tvwChild 4 (缺省)子节点。该 Node 成为在 relative 中被命名的
  节点的子节点。
  注意 如果在 relative 中没有被命名的 Node 对象,则新节点被放在节点顶层的最后位置。
  说明
  Nodes 集合是一个基于 1 的集合。
  在添加 Node 对象时,它被指派一个索引号,该索引号被存储在 Node 对象的 Index 属性中。这个最新成员的 Index 属性值就是 Node 集合的 Count 属性的值。
  因为 Add 方法返回对新建立的 Node 对象的引用,所以使用这个引用来设置新 Node 的属性十分方便。以下例子添加几个具有相同属性的 Node 对象:
  Dim nodX As Node '声明对象变量。
  Dim I as Integer '声明计数器变量。
  For I = 1 to 4
  Set nodX = TreeView1.Nodes.Add(,,,"Node " & Cstr(i))
  '使用引用来设置其它属性,如 Enabled。
  nodX.Enabled = True
  '把图像属性设置为在关联的 ImageList 中的图像 3。
  nodX.ExpandedImage = 3
  Next I

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文