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

Вниз

Как связать ветки TreeView c полями записи   Найти похожие ветки 

 
SH ©   (2003-12-29 13:36) [0]

Имеется типизированный файл с записями след. структуры:
------------
TBase = Record
FileName,Group:array[0..255] of char;
Date:TDate;
NumZ:integer;
end;

-------------
На основе типиз. файла генерится дерево, его ветви - имена файлов без пути.
Как сделать, чтобы при щелчке на имени файла в дереве, из тип. файла подзагружалась нужная запись, оттуда бралось полное имя (поле FileName), и файл с этим именем выводился в Memo?


 
YuRock ©   (2003-12-29 14:49) [1]

У каждого TreeView-итема (TTreeNode) есть свойство Data (тип Pointer), куда ты можешь записывать указатели на структуры типа TBase.

Только для каждой новой структуры создавай ее ч-з GetMem. Удалять по-моему не надо (винда сама удалит).

Только создавай каждую структуру ч-з AllocMem(SizeOf(TBase)) (примерно так):

type
PBase = ^TBase;

procedure Load;
var
Data: PBase;
Node: TTreeNode;
begin
while not Eof(f) do begin
Data := AllocMem(SizeOf(TBase));
Read(f, Data);
...
Node := TreeView1.Items.Add(nil, String(Data.FileName));
Node.Data := Data;
end;
Data =
end;

// Событие смены текущего итема
procedure ... (Sender: TObject; Node: TTreeNode);
begin
if Assigned(Node) and Assigned(Node.Data) then
Memo1.Lines.LoadFromFile(PBase(Node.Data).Group);
end;



 
YuRock ©   (2003-12-29 14:52) [2]

Извини за неточный пример (есть синтаксические ошибки и троеточия). Естественно, нужно еще открыть и закрыть файл в процедуре Load.



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

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

Наверх




Память: 0.47 MB
Время: 0.019 c
14-12517
syte_ser78
2004-02-12 17:43
2004.03.05
DVD+/-RW


3-12249
Andrey V.
2004-02-08 10:29
2004.03.05
Работа с большим числом


3-12265
Iscandersam
2004-02-09 09:36
2004.03.05
Передача данных из одной базы в другую.


11-12305
SPeller
2003-06-21 05:17
2004.03.05
Ура! У меня 1000 !!!


3-12251
Layner
2004-02-09 13:18
2004.03.05
Как работать с XML файлом, как с таблицей БД?