Модераторы: Poseidon, Snowy, bems, MetalFan
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> К какому дереву принадлежит нод, Virtual Treeview 
V
    Опции темы
XperT
Дата 4.2.2010, 21:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 269
Регистрация: 19.8.2006

Репутация: 2
Всего: 4



У меня есть 2 дерева  Virtual Treeview. Оба имеют одинаковый тип хранения данных. В разных ситуациях мне нужно работать с нодами этих деревьев, но чтобы считывать данные мне нужно знать к какому дереву принадлежит конкретно взятый нод. Передавать каждый раз в параметорах указатель дерева не очень удобно.

Как можно определить к какому дереву принадлежит конкретный нод?
PM MAIL   Вверх
kami
Дата 4.2.2010, 22:08 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1806
Регистрация: 25.8.2007
Где: Санкт-Петербург

Репутация: 23
Всего: 72



Так пойдет?
Код

if vt1.HasAsParent(MyNode, vt1.RootNode) then
  //NodeOwner=vt1
else
  //NodeOwner=vt2.


Upd: не пойдет, глупость сказал.

Это сообщение отредактировал(а) kami - 4.2.2010, 22:12
PM MAIL WWW   Вверх
XperT
Дата 4.2.2010, 22:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 269
Регистрация: 19.8.2006

Репутация: 2
Всего: 4



Решил проблему написанием такой функции:
Код

function GetVTV(node:PVirtualNode):TBaseVirtualTree;
var
  ANode: Pointer;
begin   
  ANode := node;
  while PVirtualNode(ANode).Parent<>nil do ANode := PVirtualNode(ANode).Parent;
  result := TBaseVirtualTree(ANode);
end;

PM MAIL   Вверх
kami
Дата 4.2.2010, 23:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1806
Регистрация: 25.8.2007
Где: Санкт-Петербург

Репутация: 23
Всего: 72



Цитата(XperT @  4.2.2010,  22:43 Найти цитируемый пост)
Решил проблему 

Если честно, я не понимаю, каким образом это может работать.

Цитата(XperT @  4.2.2010,  22:43 Найти цитируемый пост)
 result := TBaseVirtualTree(ANode);

В этом случае Result будет равен BaseVirtualTree.FRoot.
Смотрим, как он инициализируется:
Код

procedure TBaseVirtualTree.InitRootNode(OldSize: Cardinal = 0);
// Reinitializes the root node
......
  if FRoot = nil then
    FRoot := AllocMem(NewSize)

То есть Froot ну никак не указывает на своего владельца TbaseVirtualTree, а является "самостоятельным" указателем на задействованную область памяти. smile 
PM MAIL WWW   Вверх
XperT
Дата 4.2.2010, 23:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 269
Регистрация: 19.8.2006

Репутация: 2
Всего: 4



Смотри сюда:
Код

TVirtualNode = packed record
...
Parent,                  // reference to the node's parent (for the root this contains the treeview)

PM MAIL   Вверх
kami
Дата 4.2.2010, 23:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1806
Регистрация: 25.8.2007
Где: Санкт-Петербург

Репутация: 23
Всего: 72



Ага, понял.
PM MAIL WWW   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Общие вопросы"
SnowyMetalFan
bemsPoseidon
Rrader

Запрещается!

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами

  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Snowy, MetalFan, bems, Poseidon, Rrader.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1610 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.