Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2008.08.24;
Скачать: CL | DM;

Вниз

TreeNode   Найти похожие ветки 

 
maksum   (2008-07-21 21:45) [0]

В TreeView есть TreeNode, в котором есть различные подветки-подпапки. Мне нужно перебрать все-все узлы TreeNode. Как их все перебрать?


 
Сергей М. ©   (2008-07-21 21:48) [1]

Рекурсивно


 
Игорь Шевченко ©   (2008-07-21 21:49) [2]

рекурсивно. У TTreeNode есть свойства HasChildren и массив детей Item[]


 
maksum   (2008-07-21 21:56) [3]

Спасибо. Я никак не соображу, каким образом цикл организовать.

procedure NilNodes(ANode: TTreeNode);
begin
 while ANode <> nil then
 begin
   ANode.Data := nil;
   if ANode.HasChildren then
   begin
     ANode := ?
     NilNodes(ANode);
   end;
 end;
end;


 
Игорь Шевченко ©   (2008-07-21 22:03) [4]

procedure IterateTree (Node: TTreeNode);
var
 I: Integer;
begin
 if Node.HasChildren then
    for I:=0 to Node.Count do
       IterateNode(Node.Item[I]);

 Foo(Node);
end;


 
Германн ©   (2008-07-22 00:43) [5]


> Игорь Шевченко ©   (21.07.08 22:03) [4]

А я почему-то всегда предпочитаю сначала выполнять Foo, а потом Has.


 
Ega23 ©   (2008-07-22 09:48) [6]

А я через GetNextSibling предпочитаю...
Но суть не в этом.


 
MsGuns ©   (2008-07-22 11:52) [7]

Можно через св-во AbsoluteIndex, но на больших деревьях шибко тормозит



Страницы: 1 вся ветка

Текущий архив: 2008.08.24;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.015 c
2-1216626771
Denis__
2008-07-21 11:52
2008.08.24
Что использовать вместо StringGrid?


4-1194784856
Niki
2007-11-11 15:40
2008.08.24
LBN_SELCHANGE


3-1204215439
slimer
2008-02-28 19:17
2008.08.24
Обрыв соединения с MySQL сервером


15-1215575271
AEN
2008-07-09 07:47
2008.08.24
Хочу сделать пробный сайт


2-1216221664
MikeZ
2008-07-16 19:21
2008.08.24
Hooks: память не может быть read.