文档章节

学习 TTreeView [3] - Add、AddChild、AddFirst、AddChildFirst、Parent

涂孟超
 涂孟超
发布于 2014/09/26 15:35
字数 704
阅读 14
收藏 0
本例效果图:


unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, ComCtrls, StdCtrls;

type
  TForm1 = class(TForm)
    TreeView1: TTreeView;
    Button1: TButton;
    Button2: TButton;
    Button3: TButton;
    Button4: TButton;
    Button5: TButton;
    procedure Button1Click(Sender: TObject);
    procedure Button2Click(Sender: TObject);
    procedure Button3Click(Sender: TObject);
    procedure Button4Click(Sender: TObject);
    procedure Button5Click(Sender: TObject);
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

{方法1: 按职务顺序入场}
procedure TForm1.Button1Click(Sender: TObject);
var
  Nodes: TTreeNodes;
  node: TTreeNode;
begin
  Nodes := TreeView1.Items;

  {添加第一个元素}
  node := Nodes.Add(nil, '一连长'); {'一连长'好孤独, 旁边没人}

  {现在 node 代表"一连长", 继续添加与其平级人员, 当然要参照"一连长"}
  Nodes.Add(node, '二连长');
  Nodes.Add(node, '三连长');

  {安排"一连"的下一层: "排长"; 同时让 node 指向"一排长"}
  node := Nodes.AddChild(node, '一排长');
  Nodes.Add(node, '二排长');
  Nodes.Add(node, '三排长');

  {添加平级用 Add, 添加下级用 AddChild; 继续:}
  node := Nodes.AddChild(node, '一班长');
  Nodes.Add(node, '二班长');
  Nodes.Add(node, '三班长');

  {还有 AddChildFirst 和 AddFirst 是专门添加第一个的, 假如忘了第一个...}
  node := Nodes.AddChild(node, '战士2');
  Nodes.Add(node, '战士3');
  Nodes.Add(node, '战士4');
  Nodes.AddFirst(node, '战士1'); {用 AddFirst 可以让它站在前面}
end;


{方法2: 按先后顺序入场}
procedure TForm1.Button2Click(Sender: TObject);
var
  Nodes: TTreeNodes;
  node: TTreeNode;
begin
  Nodes := TreeView1.Items;

  node := Nodes.Add(nil, '一连长');
  node := Nodes.AddChild(node, '一排长');
  node := Nodes.AddChild(node, '一班长');
  node := Nodes.AddChild(node, '战士1');
  Nodes.Add(node, '战士2');
  Nodes.Add(node, '战士3');
  Nodes.Add(node, '战士4');

  node := node.Parent;       {让 node 指向上一层}
  Nodes.Add(node, '二班长');
  Nodes.Add(node, '三班长');

  node := node.Parent;
  Nodes.Add(node, '二排长');
  Nodes.Add(node, '三排长');

  node := node.Parent;
  Nodes.Add(node, '二连长');
  Nodes.Add(node, '三连长');
end;


{方法3: 因为没使用 TTreeNodes 和 TTreeNode, 挺麻烦的}
procedure TForm1.Button3Click(Sender: TObject);
begin
  TreeView1.Items.Add(nil, '一连长');
  TreeView1.Items.Add(TreeView1.Items[0], '二连长');
  TreeView1.Items.Add(TreeView1.Items[0], '三连长');

  TreeView1.Items.AddChild(TreeView1.Items[0], '一排长');
  TreeView1.Items.Add(TreeView1.Items[0].Item[0], '二排长');
  TreeView1.Items.Add(TreeView1.Items[0].Item[0], '三排长');

  TreeView1.Items.AddChild(TreeView1.Items[0].Item[0], '一班长');
  TreeView1.Items.Add(TreeView1.Items[0].Item[0].Item[0], '二班长');
  TreeView1.Items.Add(TreeView1.Items[0].Item[0].Item[0], '三班长');

  TreeView1.Items.AddChild(TreeView1.Items[0].Item[0].Item[0], '战士1');
  TreeView1.Items.Add(TreeView1.Items[0].Item[0].Item[0].Item[0], '战士2');
  TreeView1.Items.Add(TreeView1.Items[0].Item[0].Item[0].Item[0], '战士3');
  TreeView1.Items.Add(TreeView1.Items[0].Item[0].Item[0].Item[0], '战士4');
end;


{方法4: 用 with 简化了"方法3", 也够绕的; 推荐使用前两种方法}
procedure TForm1.Button4Click(Sender: TObject);
begin
  with TreeView1 do begin
    Items.Add(nil, '一连长');
    Items.Add(Items[0], '二连长');
    Items.Add(Items[0], '三连长');

    Items.AddChild(Items[0], '一排长');
    Items.Add(Items[0].Item[0], '二排长');
    Items.Add(Items[0].Item[0], '三排长');

    Items.AddChild(Items[0].Item[0], '一班长');
    Items.Add(Items[0].Item[0].Item[0], '二班长');
    Items.Add(Items[0].Item[0].Item[0], '三班长');

    Items.AddChild(Items[0].Item[0].Item[0], '战士1');
    Items.Add(Items[0].Item[0].Item[0].Item[0], '战士2');
    Items.Add(Items[0].Item[0].Item[0].Item[0], '战士3');
    Items.Add(Items[0].Item[0].Item[0].Item[0], '战士4');
  end;
end;


procedure TForm1.Button5Click(Sender: TObject);
begin
  TreeView1.Items.Clear;
  TButton(Sender).Caption := '清空';
end;

end.

 
 
 
 
 

 

 

  

本文转载自:http://www.cnblogs.com/del/archive/2008/03/11/1100604.html

共有 人打赏支持
涂孟超
粉丝 12
博文 2011
码字总数 14107
作品 0
深圳
程序员
RecyclerView实现倒序列表

RecyclerView实现倒序列表 标签(空格分隔): android RecyclerView 倒序 1、写在前面 实现一个聊天界面,就是类似QQ那种,这里是讲一下倒序排列,不实现QQ的各种高级功能 2、ListView 反转...

走正路
2016/06/16
1K
0
govcl v1.0.4 释出,GO 语言 UI 组件库

1、增加了TListView、TTreeView、TPageControl几个事件; 2、增加了TListView、TTreeView排序过程; 3、修复了New控件时使用CheckPtr增加安全检测; 4、增加了TListView、TTreeView排序,图像...

不在乎y
2017/12/21
2.4K
14
lufylegend-HTML5游戏引擎学习笔记4:绘图进阶

上篇: http://my.oschina.net/wolfx/blog/632130 使用原始canvas绘图 API: http://lufylegend.com/api/zh_CN/out/classes/LGlobal.html 用形状裁剪图片 API: http://lufylegend.com/api/zh_......

WolfX
2016/03/07
122
0
Java中LinkedList笔记

之前写程序似乎也没有怎么关注过底层的结构,最近正好遇到了链表的问题,于是仔细阅读了Java中链表的实现LinkedList 简单记录一下看完的总结: 1.LinkedList中定义了一个类型Node<E> ,包括3...

小翼Eric
2015/07/28
0
0
JAVA 私塾第八、九章笔记整理

JAVA 私塾第八、九章笔记整理 第八章 异常和断言 一. 异常的分类 java.lang.Throwable类充当所有对象的父类,可以使用异常处理机制将这些对象超出并捕获。有Error和Exception两个基本子类。...

luodis
2011/02/15
130
1

没有更多内容

加载失败,请刷新页面

加载更多

awk命令用法介绍

10月18日任务 9.6/9.7 awk 1.awk(上)(下) 1.awk 分段操作功能 指定分隔符,并把第一段打印出来,不会改动文件内容 将所有内容打印出来 awk 没有指定分隔符号,则会默认用空格或者空白字符...

hhpuppy
49分钟前
2
0
Spring Cloud Eureka Server高可用之:在线扩容

本文共 1591字,阅读大约需要 6分钟 ! 概述 业务微服务化以后,我们要求服务高可用,于是我们可以部署多个相同的服务实例,并引入负载均衡机制。而微服务注册中心作为微服务化系统的重要单元...

CodeSheep
今天
2
0
内网esxi主机上安装CoreOS虚拟机

CoreOS是一个为专门运行容器而设计的轻量级linux发行版,旨在通过轻量的系统架构和灵活的应用程序部署能力简化数据中心的维护成本和复杂度。它没有包管理工具,运行容器化应用以提供服务;默...

hiwill
今天
1
0
20181018 上课截图

![](https://oscimg.oschina.net/oscnet/49f66c08ab8c59a21a3b98889d961672f30.jpg) ![](https://oscimg.oschina.net/oscnet/a61bc2d618b403650dbd4bf68a671fabecb.jpg)......

小丑鱼00
今天
3
0
WinDbg

参考来自:http://www.cnit.net.cn/?id=225 SRV*C:\Symbols*http://msdl.microsoft.com/download/symbols ctrl + d to open dump_file Microsoft (R) Windows Debugger Version 6.12.0002.633......

xueyuse0012
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部