Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 19.12.2012, 19:49
Аватар для EvilRussian
EvilRussian EvilRussian вне форума
Начинающий
 
Регистрация: 21.12.2010
Адрес: Россия, Красноярский край
Сообщения: 177
Репутация: 22
По умолчанию Поиск дочернего элемента в TreeView

Добрый день, помогите ещё вот с чем.

Есть 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.
Ответить с цитированием
  #2  
Старый 19.12.2012, 21:09
my33oh my33oh вне форума
Новичок
 
Регистрация: 17.12.2012
Сообщения: 93
Репутация: -579
По умолчанию

TreeView создан для визуализации дерева и общения с пользователем, а не для работы с деревьями в принципе.
При добавлении дитя с чемто ставь флаг родителю что в нем дите с чемто присутствует.
Ответить с цитированием
  #3  
Старый 19.12.2012, 21:21
Аватар для EvilRussian
EvilRussian EvilRussian вне форума
Начинающий
 
Регистрация: 21.12.2010
Адрес: Россия, Красноярский край
Сообщения: 177
Репутация: 22
По умолчанию

Можно пример кода? И как тогда создать дерево для загрузки в TreeView?
__________________
Если не ты, то кто?
(с) Терри Пратчетт

Не забывайте ставить плюсы и говорить спасибо!
Ответить с цитированием
  #4  
Старый 19.12.2012, 21:35
my33oh my33oh вне форума
Новичок
 
Регистрация: 17.12.2012
Сообщения: 93
Репутация: -579
По умолчанию

Цитата:
Сообщение от EvilRussian
И как тогда создать дерево для загрузки в TreeView?
а зачем тебе его загружать в TreeView, я так понимаю что речь идет о парсинге какой-нибудь фигни типа XML
а как создать дерево в памяти учат в школах, институтах и описано в куче книг типа "Фундаментальные алгоритмы и структуры данных в Delphi"
Ответить с цитированием
  #5  
Старый 19.12.2012, 21:39
Аватар для M.A.D.M.A.N.
M.A.D.M.A.N. M.A.D.M.A.N. вне форума
Sir Richard Abramson
 
Регистрация: 05.04.2008
Сообщения: 5,505
Версия Delphi: XE10
Репутация: выкл
По умолчанию

Рекурсивный обход веток и листьев можно сделать.
Каждый лиск указывает на своего родителя-ветку, каждая ветка имеет список своих листьев, двунаправленный список, ничего сложного нет.
__________________
— Как тебя понимать?
— Понимать меня не обязательно. Обязательно меня любить и кормить вовремя.


На Delphi, увы, больше не программирую.
Рекомендуемая литература по программированию
Ответить с цитированием
  #6  
Старый 19.12.2012, 22:00
Аватар для EvilRussian
EvilRussian EvilRussian вне форума
Начинающий
 
Регистрация: 21.12.2010
Адрес: Россия, Красноярский край
Сообщения: 177
Репутация: 22
По умолчанию

my33oh, неправильно понимаешь. Мне нужно загрузить в TreeView список файлов с каталогами из TStringList, где записи примерно такого вида: "\vasya\vaska\VASENKA.jpg". Загрузка с жёсткого не вариант, ибо эти файлы могут и не существовать, а работать с ними надо.
Кроме того, ну создам я дерево в памяти, а факт того, что я не умею с деревьями обращаться, остаётся фактом.

M.A.D.M.A.N., я немного не понял. Это как?
__________________
Если не ты, то кто?
(с) Терри Пратчетт

Не забывайте ставить плюсы и говорить спасибо!
Ответить с цитированием
  #7  
Старый 19.12.2012, 22:11
my33oh my33oh вне форума
Новичок
 
Регистрация: 17.12.2012
Сообщения: 93
Репутация: -579
По умолчанию

Цитата:
Сообщение от EvilRussian
ибо эти файлы могут и не существовать, а работать с ними надо.
оч интересная концепция
вообще алгоритм "список файлов -> дерево" в гугле есть, ибо встречал на форумах такие запросы
но! TreeView все равно медленен для подобных манипуляций, хотя скорость понятие относительное, может тебе и сойдет
Ответить с цитированием
  #8  
Старый 19.12.2012, 22:19
Аватар для M.A.D.M.A.N.
M.A.D.M.A.N. M.A.D.M.A.N. вне форума
Sir Richard Abramson
 
Регистрация: 05.04.2008
Сообщения: 5,505
Версия Delphi: XE10
Репутация: выкл
По умолчанию

Цитата:
Сообщение от EvilRussian
M.A.D.M.A.N., я немного не понял. Это как?
Про двунаправленные списки слышал?
__________________
— Как тебя понимать?
— Понимать меня не обязательно. Обязательно меня любить и кормить вовремя.


На Delphi, увы, больше не программирую.
Рекомендуемая литература по программированию
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 15:32.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter