18.3.12. TTreeView - дерево иерархии
Компонент TTreeView служит для показа ветвящихся иерархических структур, таких как дерево наследования объектов или файловая структура диска. Он содержит связанные узлы, каждый из которых может содержать пиктограмму, текст и произвольный объект (подобно спискам TStringList - см. п. 14.3.2). Любой узел может иметь собственный список подузлов (рис. 18.27), которые можно раскрывать или закрывать щелчком мыши на пиктограмме узла.
Рис. 18.27. Пример использования компонента TTreeView
Для наполнения списка на этапе конструирования программы нужно щелкнуть по компоненту правой кнопкой мыши и выбрать Items Editor., либо щелкнуть по нему дважды, либо, наконец, щелкнуть по кнопке в свойстве Items - во всех случаях на экране появится окно редактора компонента (рис. 18.28).
Рис. 18.28. Редактор компонента
Чтобы начать наполнение, щелкните по кнопке New item и введите связанный с узлом текст в поле Text. С помощью image index панели item properties устанавливается индекс связанной с узлом пиктограммы, с помощью selected index - индекс пиктограммы для выбранного узла. Для ввода подузла любого уровня сначала нужно щелкнуть в окошке Items по узлу, который должен стать родительским, и лишь затем - на кнопке New subitem.
Для ввода списка в режиме прогона программы широко используется центральное свойство компонента - items типа TTreeNodes, открывающее индексированный доступ ко всем узлам списка. Каждый узел описывается классом TTreeNode, имеющим свои собственные методы и свойства. В частности, его свойство item содержит список всех подузлов данного узла; с помощью многочисленных методов свойства TTreeview. items к этому списку можно добавить новый подузел, а с помощью метода TTreeNode. MoveTo - переместить узел в любую позицию дерева иерархии.
Следующий обработчик события oncreate формы создал рис. 18.29:
procedure TForm1.PormCreate(Sender: TObject) ;
var
k: Integer;
begin with TreeViewl do
begin
// Добавляем корневой узел
Items.Add (NIL,' Корень') ;
//Добавляем 10 вложенных узлов
for k := 1 to 10 do
Items.AddChild(Items[k-1],IntToStr(k))
end
end;
Puc. 18.29. Создание подузлов на этапе прогона программы
Свойства компонента TTreeview:
lean;TBorderStyle = bsNone..bsSingle; property BorderStyle: TBorderStyle; |
Определяет стиль рамки, охватывающей компонент: bsNone - нет рамки; bsSingle - рамка толщиной в 1 пиксель |
||
property ChangeDelay: Integer; |
Указывает задержку (в миллисекундах) перед раскрытием узла |
||
property DropTarget: TTreeNode; |
Указывает узел, который может служить приемником операций Drag&Drop |
||
property HideSelection:Boolean; |
Указывает, будет ли убираться выделение узлов, когда компонент теряет фокус ввода |
||
property Images: TImageList; |
Содержит набор изображений, которые будут использоваться при прорисовке узлов |
||
property Indent: Integer;
|
Определяет отступ в пикселях от левого угла узла для всех его подузлов |
||
property Items: TTreeNodes;
|
Открывает доступ к любому узлу по его индексу. Индексация начинается с нуля и соответствует просмотру всех узлов полностью раскрытого списка |
||
property MultiSelect: Boo lean; |
Разрешает/запрещает одновременный выбор несколь ких узлов |
||
type TMultiSelectStyles = (msControlSel-ect, msShift Select, msVisibleOnly, msSiblingOnly) ; TMultiSelectStyle = set of TMultiSelectStyles; property MultiSelectStyle: TMultiSelect-Style default [msControlSelect]; |
Определяет способ выбора нескольких узлов: msControiselect - с нажатой и удерживаемой клавишей Ctrl для выбора узлов в произвольном порядке; msShiftSelect - с нажатой и удерживаемой клавишей Shift для выбора сплошного диапазона; msVisibleOnly - подобно msShiftSelect, но в диапазон не включаются дочерние нераскрытые узлы; msSiblingOnly - подобно msShiftSelect, но в диапазон включаются только узлы одного уровня |
||
property Readonly: Boolean;
|
Запрещает/разрешает редактирование надписей в узлах |
||
property RightClickSelect: Boolean; |
Разрешает выбор узлов правой кнопкой мыши
|
||
property Selected: TTreeNode; |
Содержит список всех выбранных узлов или nil, если таких нет |
||
property SelectionCount: Cardinal; |
Содержит количество выбранных узлов
|
||
property Selections[Index: Integer]: TTreeNode; |
Обеспечивает индексированный доступ к выбранным узлам |
||
property RowSelect: Boolean; |
Разрешает цветовыделение линий выбранных узлов. Игнорируется, если showLinesFalse |
||
property ShowButfcons: Boolean; |
Разрешает/запрещает показ стандартных кнопок раскрытия подузлов. По умолчанию содержит True. Если False, узел раскрывается двойным щелчком мыши |
||
property ShowLines: Boolean; |
Разрешает/запрещает показ линий
|
||
property ShowRoot: Boolean;
|
Разрешает/запрещает показ линий, идущих от самого верхнего уровня иерархии. Игнорируется, если ShowLines=False |
||
TSortType = (stNone, stData, stText, stBoth) ; property SortType: TSort Type; |
Указывает способ сортировки узлов: stNone - нет сортировки; stData - сортировка по данным; stText - сортировка по тексту надписей; stBoth - сортировка по тексту и по данным. См. также событие OnCompare |
||
property Topitern: , TTreeNode; |
Определяет корневой узел |
||
Методы компонента: |
function AlphaSort: Boolean; TTVCompare = function (IParamI, lParam2, IParamSort: Longint) Integer stdcall; tfunction CustomSort(SortProc: TTVCompare; Data: Longint): Boolean; |
Сортирует узлы по тексту и возвращает True, если сортировка прошла успешно Определяет нестандартную сортировку с помощью функции SortProc. Эта функция должна рассматривать IParamI и lParam2 как объекты TTreeNode и возвращает отрицательное число, если lParaml<lParam2; ноль, если IParamel^lParamS; положительное число, если lParaml>lParam2 |
||
procedure FullCollapse;
|
Прячет все узлы, кроме узлов самого верх него уровня иерархии |
||
Procedure FullExpand; |
Показывает все узлы дерева иерархии |
function GetNodeAt(X, Y: Integer) : TTreeNode;
|
Возвращает узел, располагающийся в указанной точке, или nil, если точка не принадлежит ни одному узлу |
function IsEditing: Boolea'
|
Возвращает True, если пользователь редактирует какой-либо узел |
procedure LoadPromFile(const FileName: String); |
Загружает дерево иерархии из файла
|
procedure SaveToFile(const File Name: String) ; |
Сохраняет в файле дерево иерархии
|
procedure SaveToStream(Stream: TStream) ; |
Сохраняет в потоке данных дерево иерархии события: С компонентом связаны такие |
TTVChangedEvent = procedure(Sender: TObject; Node: TTreeNode) of object; property OnChange: TTVChangedE vent; |
Возникает при смене состояния выбора у одного из узлов. Node - узел, который изменил состояние |
TTVChangingEvent = procedure( Sender: TObject; Node: TTreeNode; var AllowChange: Boolean) of objectproperty OnChangir.g: TTVChang ingEvent; |
Возникает перед сменой состояния выбора у одного из узлов. Node - узел, который будет выбран. Обработчик в параметре AllowChange разрешает или запрещает выбор узла |
TTVExpandedEvent = procedure( Sender: TObject; Node: TTreeNode) of object;property OnCollapsed: TTVExpand edEvent; |
Возникает при закрытии списка подузлов узла Node |
TTVCollapsingEvent = procedure( Sender: TObject; Node: TTreeNode; var AllowCollapse: Boolean) of object; property OnCollapsing: TTVCollapsingEvent; |
Возникает перед закрытием списка подуз лов узла Node. В параметре AllowCollapse обработчик разрешает или запрещает закрыть список |
TTVCompareEvent = procedure( Sender: TObject; Nodel, Node2: TTreeNode; Data: Integer; var Compare: Integer) of object; property OnCompare: TTVCom pareEvent; |
Возникает при сравнении двух узлов Nodel И Node2. В параметре Compare обработчик должен вернуть отрицательное число, если Nodel<Node2; ноль, если Model=Node2; положительное число, если Nodel>Node2 |
TTVExpandedEvent = procedure( Sender: TObject; Node: TTreeNode) of object; property OnDeletion: TTVExpand edEvent; |
Возникает при удалении узла Node из дерева иерархии |
TTVEditedEvent = procedure(Sender: TObject; Node: TTreeNode; var S: String) of object; property OnEdited: TTVEditedEvent; |
Возникает при завершении редактирования надписи в узле Node: S - новая надпись
|
TTVExpandedEvent = procedure( Sender: TObject; Node: TreeNode) of object; property OnExpanded: TTVExpand edEvent; |
Возникает при распахивании списка подузлов узла Node
|
TTVExpandingEvent = procedure( Sender: TObject; Node: TTreeNode; var AllowExpansion: Boolean) of object; property OnExpanding: TTVExpand ingEvent; |
Возникает перед открытием списка подузлов узла Node. В параметре AllowExpansion обработчик разрешает или запрещает открыть список |
TTVExpandedEvent = procedure( Sender: TObject; Node: TreeNode) of object;property OnGetImageIndex: TTVEx pandedEvent; |
Возникает при необходимости получения индекса изображения для прорисовки узла Node в обычном состоянии
|
TVExpandedEvent == procedure( Sender: TObject; Node: TTreeNode) of object; property OnGetSelectedIndex: TTVExpandedEvent; |
Возникает при необходимости получения индекса изображения для прорисовки узла Node в выбранном состоянии
|
При программном заполнении списка следует пользоваться свойством TTreeView. Items класса TTreeNodes.
Свойства класса TTreeNodes:
property Count: Integer; property Item[Index: Integer]: TTreeNode; default-property Owner: TCustomTreeView; |
Количество узлов, входящих в items Открывает индексированный доступ к узлам Содержит ссылку на родительский список |
Методы класса TTreeNodes: |
|
function Add(Node: TTreeNode; const S: String): TTreeNode; function AddChild(Node: TTreeNode; const S: String): TTreeNode; function AddChildFirst(Node: TTreeNode; const S: String): TTreeNode; function AddChildObject(Node: TTreeNode; const S: String; Ptr: Pointer): TTreeNode; function AddChildObjectFirst( Node: TTreeNode; const S: String; Ptr: Pointer): TTreeNode; |
Добавляет узел в конец того списка, в котором зарегистрирован узел Node. Если Node=NlL, добавляется корневой узел для всего компонента Добавляет узел в конец списка item дочерних узлов узла Node Добавляет узел в начало списка Item дочерних узлов узла Node Добавляет узел и данные в конец списка item дочерних узлов узла Node. На данные ссылается указатель Ptr. Связанная с данными область памяти не освобождается автоматически при уничтожении списка Добавляет узел и данные в начало списка item дочерних узлов узла Node. На данные ссылается указатель Ptr. Связанная с данными область памяти не освобождается автоматически при уничтожении списка |
function AddFirst(Node: TTreeNode; const S: String): TTreeNode; |
Добавляет узел в начало того списка, в котором зарегистрирован узел Node |
function AddObject(Node: TTreeNode; const S: String; Ptr: Pointer): TTreeNode;
|
Добавляет узел и данные в конец того же списка, в котором зарегистрирован узел Node. На данные ссылается указатель Ptr. Связанная с данными область памяти не освобождается автоматически при уничтожении списка |
function AddObjectFirst(Node: TTreeNode; const S: String; Ptr: Pointer): TTreeNode;
|
Добавляет узел и данные в начало того же списка, в котором зарегистрирован узел Node. На данные ссылается указатель Ptr. Связанная с данными область памяти не освобождается автоматически при уничтожении списка |
procedure Assign(Source: TPersistent) ; |
Связывает список текущего компонента со списком компонента Source |
procedure BeginUpdate;
|
Блокирует обновление экрана до тех пор, пока не будет выполнен метод EndUpdate. Используется при одновременной вставке нескольких элементов списка для предотвращения мерцания экрана |
procedure Clear;
|
Очищает список всех узлов и подузлов компонента |
procedure Delete(Node: TTreeNode); |
Уничтожает узел Nods
|
procedure EndUpdate; |
Отменяет действие метода BeginUdate |
function GetFirstNode: TTreeNode;
|
Возвращает самый первый узел в списке Items[0] |
function GetNode(Itemid: HTreeItem): TTreeNode; |
Возвращает узел по его идентификатору Itemid |
function Insert(Node: TTreeNode; const S: String): TTreeNode; |
Вставляет узел непосредственно перед узлом Node |
function InsertObj ect(Node: TTreeNode; const S: String; Ptr: Pointer): TTreeNode; |
Вставляет узел и данные непосредственно перед узлом Node
|
Как уже отмечалось, каждый узел класса TTreeNode имеет свой набор методов, свойств и событий.
Свойства TTreeNode:
property Absolutelndex: Integer; |
Возвращает абсолютный индекс узла (с учетом всех подузлов) |
property Count: Integer; |
Содержит количество подузлов в списке Item |
property Cut: Boolean; |
Вырезает узел и помещает его в clipboard |
property Data: Pointer; |
Указывает на связанные с узлом данные |
property Deleting: Boolean; |
Содержит True, если для узла вызван De-story |
property DropTarget: Boolean; |
Содержит True, если узел может служить приемником операции Drag&Drop |
property Expanded: Boolean; |
Содержит True, если узел распахнут |
property Focused: Boolean; |
Содержит True, если узел сфокусирован |
property HasChildren: Boolean;
|
Содержит True, если узел имеет дочерние узлы |
property Imagelndex: TImageIndex;
|
Содержит индекс связанной с узлом пиктограммы |
property Index: Longint;
|
Содержит индекс узла в списке дочерних узлов его родительского узла |
property IsVisible: Boolean; |
Содержит True, если узел виден |
property Item[Index: Integer]: TTreeNode; |
Открывает индексированный доступ ко всем дочерним узлам |
property Itemid: HTreeItem;
|
Содержит уникальный Windows-дескриптор узла |
property Level: Integer; |
Содержит иерархический уровень узла |
property Overlaylndex: Integers-
|
Содержит индекс оверлейной пиктограммы. Оверлейная пиктограмма вычерчивается поверх основной, чтобы, например, указать, что узел стал недоступен |
property Owner: TTreeNodes;
|
Содержит ссылку на владельца данного узла |
property Parent: TTreeNode; |
Содержит ссылку на родительский узел |
property Selected: Boolean; |
Содержит True, если узел выделен цветом |
property Selectedlndex: Integer;
|
Содержит номер пиктограммы для выделенного узла |
property Text: Strings- |
Содержит текст узла |
property TreeView: TCustomTree- View; |
Содержит ссылку на компонент TreeView, к которому принадлежит узел |
Методы класса TTreeNode:
function AlphaSort: Boolean;
|
Сортирует узлы по алфавиту свойств Text и возвращает True в случае успеха |
procedure Assign(Source: TPersis tent); override; |
Связывает список подузлов с источником Source |
procedure Collapse(Recurse: Boolean) ; |
Закрывает все узлы (Recource=True) или только распахнутые(Resource=False) |
type TTVCompare = function( IParamI, lParam2, IParamSort: Longint): Integer stdcall; func tion CustomSort(SortProc: TTVCom pare; Data: Longint): Boolean; |
Реализует нестандартную сортировку узлов
|
procedure Delete; |
Удаляет текущий узел |
procedure DeleteChildren; |
Удаляет дочерние узлы |
function DisplayRect(TextOnly: Boolean): TRect;
|
Возвращает очерчивающий прямоугольник узла. Если TextOnly=True - возвращает очерчивающий прямоугольник текста |
function EditText: Boolean;
|
Переводит текст узла в режим редактирования |
procedure EndEdit(Cancel Boo lean) ; |
Заканчивает редактирование текста и со храняет его изменения, если Cancel=False |
procedure Expand(Recurse: Boo lean) ; |
Открывает узел (и его подузлы, если Recurce=True) |
function GetFirstChild: TTreeNode; |
Возвращает ссылку на первый подузел или nil, если нет подузлов |
function GetLastChild: TTreeNode;
|
Возвращает ссылку на последний подузел или nil, если нет подузлов |
function GetNext: TTreeNode; function GetNextChild(Value: TTreeNode): TTreeNode; |
Возвращает ссылку на очередной подузел dозвращает ссылку на подузел после value (или nil, если такового нет). |
function GetNextSibling: TTreeNode; |
Возвращает ссылку на очередной узел в том же списке. |
function GetNextVisible: TTreeNode;
|
Возвращает ссылку на очередной видимый узел (для которого раскрыты все дочерние узлы) |
function GetPrev: TTreeNode;
|
Возвращает ссылку на предыдущий узел в том же списке независимо от его видимости |
function GetPrevChild(Value: TTreeNode): TTreeNode; |
Возвращает ссылку на предыдущий по отношению к value дочерний узел |
function GetPrevSibling: TTreeNode; |
Возвращает ссылку на предыдущий узел того же уровня |
function GetPrevVisible: TTreeNode; |
Возвращает ссылку на видимый узел того же уровня |
function HasAsParent(Value: TTreeNode): Boolean; |
Возвращает True, если value - родительский узел |
function IndexOf(Value: TTreeNode): Integer; |
Возвращает идентификатор узла value
|
procedure MakeVisible;
|
Если родительский узел видимый, делает видимыми все дочерние узлы |
type TNodeAttachMode = (naAdd, naAddFirst, naAddChild, naAddChildFirst, nalnsert) ; procedure MoveTo(Destination: TTreeNode; Mode: TNodeAttach Mode) ;
|
Перемещает текущий узел в позицию относительно Destination в зависимости от параметра Mode: naAdd - добавляет в конец списка узла того же уровня; naAddFirst - делает первым в списке узлов того же уровня; naAddchild - добавляет в конец списка дочерних узлов; naAddChildFirst -делает первым в списке дочерних узлов; nalnsert - вставляет непосредственно перед узлом |