Главная страница
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.019 c
13-1120547588
Игорь Шевченко
2005-07-05 11:13
2008.08.24
Социологический опрос: нужен ли отдельный форум по .Net ?


1-1196965642
@!!ex
2007-12-06 21:27
2008.08.24
Как получиьт изображение окна?


2-1213952414
No_Dead
2008-06-20 13:00
2008.08.24
Как можно составить запрос?


2-1215876002
Zhekson
2008-07-12 19:20
2008.08.24
Перевернуть изображение


2-1216297461
User
2008-07-17 16:24
2008.08.24
обработка ошибок записи SaveToFile