![]() |
|
|
Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
|
Опции темы | Поиск в этой теме | Опции просмотра |
#1
|
||||
|
||||
![]() Добрый день, помогите ещё вот с чем.
Есть TreeView, который я динамически заполняю следующей процедурой: Код:
procedure AddTree(nod:TTreeNode; s:string); var ID: integer; prefix: string; begin ID := Pos('\', s); if ID > 0 then begin prefix := Copy(s,0,ID-1); delete(s,0,ID-1); nod := FindNodeWithText(nod, prefix); //Ищем: есть ли уже такой элемент? if nod = nil then begin nod := TreeView1.Items.AddChild(nod, prefix); AddTree(nod,s) end end else nod := TreeView1.Items.AddChild(nod, s); end; Следовательно, мне нужно находить, есть ли в дочерних элементах этой ноды "nod" элемент "prefix". Как можно сделать это? Пробовал перебор а-ля TStringList, но совершенно не понимаю, как его реализовать: Код:
function FindNodeWithText(nod:TTreeNode; find:string): TTreeNode; var i:integer; begin Result:=nil; for i:=0 to nod.??? do //Как узнать количество детей? begin if nod.Item[i].Text=find then //Это название? begin Result:=nod.Item[i].???; //Как задать определённое дитя как результат? break end; end; end; Помогите, пожалуйста, кто-нибудь советом по реализации, а лучше - кодом. Очень важна эффективность кода, потому что придётся прогонять через это очень большие деревья, не меньше тысячи элементов. Кроме того, как в TreeView разделяются, так сказать, "папки" и "записи"? Это разные элементы или один и тот же? Если не ты, то кто? (с) Терри Пратчетт Не забывайте ставить плюсы и говорить спасибо! Последний раз редактировалось EvilRussian, 19.12.2012 в 20:40. |