https://wiki.freepascal.org/api.php?action=feedcontributions&user=Alain&feedformat=atomFree Pascal wiki - User contributions [en]2024-03-29T10:36:47ZUser contributionsMediaWiki 1.35.6https://wiki.freepascal.org/index.php?title=VirtualTreeview_Example_for_Lazarus/fr&diff=70522VirtualTreeview Example for Lazarus/fr2013-06-14T14:11:51Z<p>Alain: Deletion of a non necessary word</p>
<hr />
<div>{{Example for VirtualTreeview on Lazarus}}<br />
<br />
Voici quelques exemples sur la façon d'utiliser VirtualTreeview pour Lazarus (testé sur win32). Ceci sont essentiellement collectés à partir du web écrit pour delphi, et à partir des tutoriels/documents par Philipp Frenzel et Mike Lischke. Les tutoriels/documents peuvent être téléchargé à partir de l'adresse http://www.soft-gems.net . Ci dessous quelqu'un trouverait seulement la manière rapide d'utiliser VirtualTreeview avec Lazarus, pas une explication. Pour des explications et de nombreuses autres fonctions/méthodes obtenir les documents officiels et le didacticiel.<br />
<br />
=Arbre de base Listview avec trois Colonnes=<br />
<br />
1. Installez le composant. Exécutez lazarus. <br />
<br />
2. Déposez un composant TVirtualStringTree (Sous l'onglet Virtual Controls).<br />
<br />
3. Aller à l'éditeur de source (Appuyez sur F12). Sous la clause Uses ajoutez une unité - appelée VirtualTrees (si elle n'est pas déjà là et que ce n'est pas VirtualStringTree). Ainsi, il peut ressembler à:<br />
<PRE><br />
uses<br />
Classes, SysUtils, LResources, Forms, Controls, Graphics, Dialogs,<br />
VirtualStringTree, VirtualTrees; <br />
</PRE> <br />
4. Aller à l'éditeur de fiches (Appuyez sur F12). Sélectionnez le composant Virtual Tree. Sur l'inspecteur d'objet cliquez sur Name, tapez VST et appuyez sur entrer. Cliquez sur Header (augmentez-le) -> Columns, cliquez sur le petit bouton situé à côté de "0 items". Cliquez 3 fois sur Add button pour ajouter 3 colonnes. Ne pas fermer cette fenêtre.<br />
<br />
5. Sur la fenêtre d'édition de la colonne maintenant la 3ième colonne est sélectionnée. Aller à l'inspecteur d'objet. Cliquez sur Options (augmentez-le) -> fixez coAllowClicks à False.<br />
<br />
6. Cliquez sur Text. Tapez Column2.<br />
<br />
7. Cliquez sur Width, tapez 100 et appuyez sur enter.<br />
<br />
8. Allez à la fenêtre d'édition de la colonne, selectionnez la 1ère et la 2ieme colonne, et fixez leur propriété comme ci-dessus (pour le champ Text, utiliser des noms différents, c'est à dire Column0, Column1).<br />
<br />
9. Fermez la fenêtre d'édition de colonnes. Sélectionnez le composant Virtual Tree de la fiche. Sur l'inspecteur d'objet allez à Header -> Options (augmentez-le). Fixez hoVisible à True.<br />
<br />
10. Faites défiler la liste jusqu'à Style fixez le à hsFlatButtons.<br />
<br />
[[Image:ExempleVirtualtreeView1.jpg|center]]<br />
<br />
11. Faites défiler la liste jusqu'à TreeOptions(augmentez-le) -> MiscOption(augmentez-le), fixez toEditable à True. Fixez toGridExtensions à True.<br />
<br />
12. Faites défiler la liste jusqu'à SelectionOptions(augmentez-le) -> fixez le toExtendedFocus à True. Fixez toMultiSelect à True. Sur le concepteur de fiche redimensionnez VST (composant Virtual Tree) pour obtenir le visuel de toutes les colonnes, si nécessaire.<br />
<br />
13. Maintenant ajoutez 3 boutons sur la fiche. Obtenez les à partir de la palette de composants - Onglet standard (Label "OK" ).<br />
<br />
14. CLiquez sur Button1, sur l'inspecteur d'object changez Caption avec AddRoot. Cliquez sur Button2, changez le caption avec AddChild. Changez le caption du Button3 avec Delete.<br />
<br />
[[Image:ExempleVirtualtreeView2.jpg|center]]<br />
<br />
15. Gardez ceci ici et allez à l'éditeur de source(appuyez sur F12). Dans l'éditeur de source remplacez la ligne:<br />
<br />
{$mode objfpc}{$H+} par {$MODE DELPHI}<br />
<br />
16. Sous "implementation" coller les lignes suivantes:<br />
<br />
<PRE><br />
type<br />
PTreeData = ^TTreeData;<br />
TTreeData = record<br />
Column0: String;<br />
Column1: String;<br />
Column2: String;<br />
end;<br />
</PRE><br />
<br />
17. Allez au concepteur de fiche (Appuyez sur F12). sélectionnez VST. Allez à l'inspecteur d'objet, sélectionnez l'onglet évènements, défiler vers le bas vers l'évènement onChange. Double-cliquez sur le combobox. Coller ce qui suit:<br />
<PRE><br />
procedure TForm1.VSTChange(Sender: TBaseVirtualTree; Node: PVirtualNode);<br />
begin<br />
VST.Refresh;<br />
end;<br />
</PRE><br />
<br />
18. Faites défiler jusqu'à onFocusChanged. Double-cliquez et collez ce qui suit:<br />
<PRE><br />
procedure TForm1.VSTFocusChanged(Sender: TBaseVirtualTree; Node: PVirtualNode;<br />
Column: TColumnIndex);<br />
begin<br />
VST.Refresh;<br />
end; <br />
</PRE><br />
<br />
19. Faites défiler jusqu'à onFreeNode. Double-cliquez et collez ce qui suit:<br />
<PRE><br />
procedure TForm1.VSTFreeNode(Sender: TBaseVirtualTree; Node: PVirtualNode);<br />
var<br />
Data: PTreeData;<br />
begin<br />
Data:=VST.GetNodeData(Node);<br />
if Assigned(Data) then begin<br />
Data^.Column0 := '';<br />
Data^.Column1 := '';<br />
Data^.Column2 := '';<br />
end;<br />
end; <br />
</PRE><br />
<br />
20. Faites défiler jusqu'à onGetNodeDataSize. Double-cliquez et collez ce qui suit: <br />
<PRE><br />
procedure TForm1.VSTGetNodeDataSize(Sender: TBaseVirtualTree; var NodeDataSize: Integer);<br />
begin<br />
NodeDataSize := SizeOf(TTreeData);<br />
end; <br />
</PRE><br />
<br />
21. Faites défiler jusqu'à onGetText. Double-cliquez et collez ce qui suit: <br />
<PRE><br />
procedure TForm1.VSTGetText(Sender: TBaseVirtualTree; Node: PVirtualNode;<br />
Column: TColumnIndex; TextType: TVSTTextType; var CellText: WideString);<br />
var<br />
Data: PTreeData;<br />
begin<br />
Data := VST.GetNodeData(Node);<br />
case Column of<br />
0: CellText := Data^.Column0;<br />
1: CellText := Data^.Column1;<br />
2: CellText := Data^.Column2;<br />
end;<br />
end; <br />
</PRE><br />
<br />
22. Pressez sur F12 pour aller à concepteur de fiche. Double-cliquez sur le bouton AddRoot. Collez ce qui suit:<br />
<PRE><br />
procedure TForm1.Button1Click(Sender: TObject);<br />
Var<br />
Data: PTreeData;<br />
XNode: PVirtualNode;<br />
Rand: Integer;<br />
Begin<br />
Randomize;<br />
Rand := Random(99);<br />
XNode:=VST.AddChild(nil);<br />
<br />
if VST.AbsoluteIndex(XNode) > -1 then<br />
Begin<br />
Data := VST.GetNodeData(Xnode);<br />
Data^.Column0:= 'One ' + IntToStr(Rand);<br />
Data^.Column1:= 'Two ' + IntToStr(Rand + 10);<br />
Data^.Column2:= 'Three ' + IntToStr(Rand - 10);<br />
End; <br />
End; <br />
</PRE><br />
<br />
23. Appuyez sur F9 pour exécuter le projet à vérifier. Cliquez sur AddRoot pour ajouter un nœud. Si c'est ok, le nœud sera ajouté sur VST.<br />
<br />
[[Image:ExempleVirtualtreeView3.jpg|center]]<br />
<br />
24. Arrêtez l'exécution. Sur le concepteur de fiche double-cliquez sur le bouton intitulé addChild. Collez ce qui suit:<br />
<PRE><br />
procedure TForm1.Button2Click(Sender: TObject);<br />
var<br />
XNode: PVirtualNode;<br />
Data: PTreeData;<br />
begin<br />
if not Assigned(VST.FocusedNode) then<br />
Exit;<br />
<br />
XNode := VST.AddChild(VST.FocusedNode);<br />
Data := VST.GetNodeData(Xnode);<br />
<br />
Data^.Column0:= 'Ch 1';<br />
Data^.Column1:= 'Ch 2';<br />
Data^.Column2:= 'Ch 3';<br />
<br />
VST.Expanded[VST.FocusedNode]:=True;<br />
end;<br />
</PRE><br />
<br />
25. Sur le concepteur de fiche double-cliquez sur le bouton intitulé Delete. Copiez ce qui suit:<br />
<PRE><br />
procedure TForm1.Button3Click(Sender: TObject);<br />
begin<br />
VST.DeleteSelectedNodes;<br />
end; <br />
</PRE><br />
<br />
26. Exécutez le projet en appuyant sur la touche F9 pour vérifier. Ajoutez quelques nœuds, nœuds fils et effacez les.<br />
<br />
[[Image:ExempleVirtualtreeView4.jpg|center]]<br />
<br />
27. Essayez d'éditer un nœud. Sélectionnez un nœud et pressez sur F2, écrivez une nouvelle valeur. Si vous pouvez voir ce que vous tapez alors c'est OK. Sinon, lisez-dessous "Si l'édition d'une cellule ne peut être vue".<br />
<br />
28. Pour obtenir que VST montre la nouvelle valeur après l'édition, allez au concepteur de fiche, sélectionnez VST. Double-cliquez sur le combobox de l'inspecteur d'objet -> Evenements -> OnNewText. Copiez ce qui suit:<br />
<PRE><br />
procedure TForm1.VSTNewText(Sender: TBaseVirtualTree; Node: PVirtualNode;<br />
Column: TColumnIndex; NewText: WideString);<br />
Var<br />
Data: PTreeData;<br />
begin<br />
Data := VST.GetNodeData(Node);<br />
Case Column of<br />
0: Data^.Column0:= NewText;<br />
1: Data^.Column1:= NewText;<br />
2: Data^.Column2:= NewText;<br />
End;<br />
end; <br />
</PRE><br />
<br />
Jusqu'à présent, l'exemple de l'utilisation de base se termine ici. Vous pouvez mettre quelques boutons de plus sur la fiche afin de tester quelques commandes indiquées ci-dessous. La suite serait de montrer les cases à cocher, les images, la couleur des caractères et l'ajout de combobox sur un noeud. <br />
<br />
<br />
*Une autre manière d'ajouter le nœud racine<br />
<PRE><br />
procedure TForm1.Button8Click(Sender: TObject);<br />
begin<br />
with VST do<br />
RootNodeCount:=RootNodeCount+1;<br />
end;<br />
</PRE><br />
*Une autre façon d'ajouter un nœud enfant<br />
<PRE><br />
procedure TForm1.Button9Click(Sender: TObject);<br />
begin<br />
if Assigned(VST.FocusedNode) Then<br />
VST.ChildCount[VST.FocusedNode]:=VST.ChildCount[VST.FocusedNode]+1;<br />
end;<br />
</PRE><br />
*Déterminer et effacer un enfant d'un nœud donné<br />
<PRE><br />
procedure TForm1.Button4Click(Sender: TObject);<br />
Var<br />
c: Integer;<br />
begin<br />
if not Assigned(VST.FocusedNode) then<br />
Exit;<br />
If VST.HasChildren[VST.FocusedNode] then<br />
Begin<br />
c := VST.ChildCount[VST.FocusedNode];<br />
VST.DeleteChildren(VST.FocusedNode);<br />
ShowMessage('Number of deleted child:' + #13#10 + IntToStr(c));<br />
End;<br />
end; <br />
</PRE><br />
*Effacer un nœud<br />
<PRE><br />
procedure TForm1.Button5Click(Sender: TObject);<br />
begin<br />
{VST.Clear; //Delete All Nodes}<br />
if not Assigned(VST.FocusedNode) then<br />
Exit;<br />
VST.DeleteNode(VST.FocusedNode);<br />
end;<br />
</PRE><br />
*Rechercher et sélectionner un nœud<br />
<PRE><br />
procedure TForm1.Button6Click(Sender: TObject);<br />
Var<br />
XNode: PVirtualNode;<br />
Data: PTreeData;<br />
begin<br />
XNode:= VST.GetFirst;<br />
<br />
while XNode <> nil do<br />
begin<br />
Data:=VST.GetNodeData(XNode);<br />
if Data^.Column0 = '1' then<br />
Begin<br />
VST.ClearSelection;<br />
VST.Selected[XNode]:=True;<br />
VST.SetFocus;<br />
break;<br />
End<br />
Else<br />
XNode:= VST.GetNextSibling(XNode);<br />
End;<br />
End;<br />
</PRE><br />
*Determine Parent<br />
<PRE><br />
procedure TForm1.Button13Click(Sender: TObject);<br />
var<br />
XNode: PVirtualNode;<br />
begin<br />
if not Assigned(VST.FocusedNode) then<br />
Exit;<br />
XNode:=VST.FocusedNode;<br />
while VST.GetNodeLevel(XNode) > 0 do<br />
Begin<br />
XNode := XNode.Parent;<br />
VST.Selected[XNode]:= True;<br />
End;<br />
VST.Refresh;<br />
VST.SetFocus;<br />
end; <br />
</PRE><br />
*Tout rechercher<br />
<PRE><br />
procedure TForm1.Button7Click(Sender: TObject);<br />
Var<br />
XNode: PVirtualNode;<br />
Data: PTreeData;<br />
begin<br />
If VST.GetFirst = nil then Exit;<br />
XNode:=nil;<br />
Repeat<br />
if XNode = nil then XNode:=VST.GetFirst Else XNode:=VST.GetNext(XNode);<br />
Data:=VST.GetNodeData(XNode);<br />
If (Data^.Column0 = '1') OR (Data^.Column1 = '1') OR (Data^.Column2 = '1') then<br />
Begin<br />
ShowMessage('Found at Node Level : ' + IntToStr(VST.GetNodeLevel(XNode)) );<br />
break;<br />
End;<br />
Until XNode = VST.GetLast();<br />
end;<br />
</PRE><br />
*Insérer un nœud<br />
<PRE><br />
procedure TForm1.Button12Click(Sender: TObject);<br />
var<br />
XNode: PVirtualNode;<br />
begin<br />
If Assigned(VST.FocusedNode) then<br />
begin<br />
XNode := VST.InsertNode(VST.FocusedNode,amInsertBefore);<br />
// To Insert After Selected Node.<br />
{XNode := VST.InsertNode(VST.FocusedNode,amInsertAfter);}<br />
VST.Refresh;<br />
end;<br />
end;<br />
</PRE><br />
*Fixer la hauteur d'un nœud<br />
<PRE><br />
procedure TForm1.Button14Click(Sender: TObject);<br />
begin<br />
If Assigned(VST.FocusedNode) then<br />
VST.NodeHeight[VST.FocusedNode] := 32;<br />
end;<br />
</PRE><br />
*Sauvegarde et chargement<br />
Un arbre simple (sans colonne) peut être sauvegardé et chargé ainsi:<br />
<PRE><br />
VST.SaveToFile('filename.dat');<br />
VST.LoadFromFile('filename.dat');<br />
</PRE><br />
<br><br />
Pour enregistrer et charger l'exemple mentionné ci-dessus, placez 2 boutons sur la fiche, renommez le caption avec "Save" pour le 1er et "Load" pour le second. Sélectionnez VST, sur l'inspecteur d'objet -> TreeOptions -> StringOptions assurez-vous que toSaveCaptions est fixé à True. Allez à l'onglet évènements de l'inspecteur d'objet. Faites défiler la liste jusqu'à OnLoadNode, double-cliquez, puis collez:<br />
<PRE><br />
procedure TForm1.VSTLoadNode(Sender: TBaseVirtualTree; Node: PVirtualNode;<br />
Stream: TStream);<br />
Var<br />
Data: PTreeData;<br />
Len: Integer;<br />
begin<br />
Data := VST.GetNodeData(Node);<br />
Stream.read(Len, SizeOf(Len));<br />
SetLength(Data^.Column0, Len);<br />
Stream.read(PChar(Data^.Column0)^, Len);<br />
<br />
Stream.read(Len, SizeOf(Len));<br />
SetLength(Data^.Column1, Len);<br />
Stream.read(PChar(Data^.Column1)^, Len);<br />
<br />
Stream.read(Len, SizeOf(Len));<br />
SetLength(Data^.Column2, Len);<br />
Stream.read(PChar(Data^.Column2)^, Len);<br />
end;<br />
</PRE><br />
<br />
A nouveau sur l'onglet évènements de l'inspecteur d'objet - défiler vers le bas vers OnSaveNode, double-cliquez, puis collez:<br />
<PRE><br />
procedure TForm1.VSTSaveNode(Sender: TBaseVirtualTree; Node: PVirtualNode;<br />
Stream: TStream);<br />
Var<br />
Data: PTreeData;<br />
Len: Integer;<br />
begin<br />
Data := VST.GetNodeData(Node);<br />
Len := Length(Data^.Column0);<br />
Stream.write(Len, SizeOf(Len));<br />
Stream.write(PChar(Data^.Column0)^, Len);<br />
<br />
Len := Length(Data^.Column1);<br />
Stream.write(Len, SizeOf(Len));<br />
Stream.write(PChar(Data^.Column1)^, Len);<br />
<br />
Len := Length(Data^.Column2);<br />
Stream.write(Len, SizeOf(Len));<br />
Stream.write(PChar(Data^.Column2)^, Len);<br />
end;<br />
</PRE><br />
<br />
Sur le concepteur de fiche double-cliquez sur le bouton intitulé Save, collez:<br />
<PRE><br />
procedure TForm1.Button10Click(Sender: TObject);<br />
begin<br />
VST.SaveToFile('C:\vst.dat');<br />
end;<br />
</PRE><br />
<br />
Sur le concepteur de fiche double-cliquez sur le bouton intitulé Load, collez:<br />
<PRE><br />
procedure TForm1.Button11Click(Sender: TObject);<br />
begin<br />
VST.LoadFromFile('C:\vst.dat');<br />
end;<br />
</PRE><br />
Testez maintenant l'enregistrement et le chargement de l'arbre.<br />
<br />
*Problème de défilement<br />
L'en-tête du treeview disparaît totalement ou partiellement lors du défilement. Je n'ai pas pu trouver une bonne solution pour cela. Une façon de surmonter ceci est de fixer la hauteur de l'en-tête à 0, puis d'utiliser un label général pour les colonnes. C'est bon tant qu'il y a peu de colonnes, et quelles sont toutes visibles sans défilement horizontal. Ou bien, la hauteur de l'en-tête peut être réglée à une valeur plus élevée de 25 ou 30. VST.Refresh peut être ajouté à l'évènement OnScroll.<br />
<br />
*Redimensionnement des colonnes<br />
Il n'est pas possible de redimensionner une colonne en faisant glisser la souris sur l'en-tête de VST. Peut être c'est à cause d'un bug de l'en-tête ou j'ai oublié quelque chose. Si c'est à cause de l'en-tête, ça sera probablement fixé avec la prochaine version de Lazarus. Voir ce lien: http://bugs.freepascal.org/view.php?id=11209<br><br />
Quoi qu'il en soit, il est possible de redimensionner la colonne à partir du code. Lorsque vous appuyez sur le bouton droit de la souris et déplacez la roulette vers le haut, la largeur de la colonne sélectionnée augmente et appuyez sur le bouton droit de la souris et déplacez la roulette vers le bas, pour diminuer la largeur de la colonne sélectionnée. Pour faire ceci:<br><br />
<br />
1. Ajouter une variable dans l'éditeur de source nommé CurCol: Integer; Ainsi, le code ressemble à:<br />
<PRE><br />
var<br />
Form1: TForm1; <br />
CurCol: Integer; // <- Add this line only.<br />
<br />
implementation<br />
<br />
{ TForm1 } <br />
</PRE><br />
<br />
2. Sur le concepteur de fiche double-cliquez sur le fiche pour générer l'évènement OnCreate. Dans la procédure OnCreate tapez Form1.OnMouseWheelUp:= et appuyez sur Ctrl+Shift+C, ceci va compléter le code et faire le squelette de l'évènement MouseWheelUp. Maintenant revenir à la procédure TForm1.FormCreate(Sender: TObject); et ajoutez un nouvel évènement pour MouseWheelDown. Tapez Form1.OnMouseWheelDown:= et appuyez sur Ctrl+Shift+C, pour générer l'évènement MouseWheelDown. La procédure FormCreate ressemble maintenant à :<br />
<PRE><br />
procedure TForm1.FormCreate(Sender: TObject);<br />
begin<br />
Form1.OnMouseWheelUp:=@Form1MouseWheelUp;<br />
Form1.OnMouseWheelDown:=@Form1MouseWheelDown;<br />
end;<br />
</PRE><br />
<br />
3. Remplissez la procédure TForm1.Form1MouseWheelUp ainsi:<br />
<PRE><br />
procedure TForm1.Form1MouseWheelUp(Sender: TObject; Shift: TShiftState;<br />
MousePos: TPoint; var Handled: Boolean);<br />
begin<br />
If VST.Focused then<br />
if ssRight in Shift then<br />
VST.Header.Columns[CurCol].Width:= VST.Header.Columns[CurCol].Width + 10;<br />
end; <br />
</PRE><br />
<br />
4. Remplissez la procédure TForm1.Form1MouseWheelDown ainsi:<br />
<PRE><br />
procedure TForm1.Form1MouseWheelDown(Sender: TObject; Shift: TShiftState;<br />
MousePos: TPoint; var Handled: Boolean);<br />
begin<br />
If VST.Focused then<br />
if ssRight in Shift then<br />
VST.Header.Columns[CurCol].Width:= VST.Header.Columns[CurCol].Width - 10;<br />
end; <br />
</PRE><br />
<br />
5. Allez au concepteur de fiche (appuyez sur F12), sélectionnez VST, sur l'onglet des évènement de l'inspecteur d'objet faites défiler jusqu'à OnFocusChanged, double-cliquez et collez:<br />
<PRE><br />
procedure TForm1.VSTFocusChanged(Sender: TBaseVirtualTree;<br />
Node: PVirtualNode; Column: TColumnIndex);<br />
begin<br />
CurCol:=Column;<br />
end;<br />
</PRE><br />
<br />
Lorsque vous exécutez le programme, cliquez sur une colonne puis maintenez enfoncé le bouton droit de la souris et faire bouger la roulette vers le haut pour augmenter la largeur de la colonne, et le roulette vers le bas pour la diminuer. Vous devriez mettre au point les procédures ci-dessus si nécessaire. Ou bien, ajoutez un évènement au clavier avec quelque chose du genre "if (key=187) and (ssShift in Shift) then" pour surveiller le Shift + "+".<br />
----<br />
----<br />
<br />
=Checkbox=<br />
----<br />
Sur le concepteur de fiche sélectionnez VST. Allez à:<br> <br />
#Inspecteur d'objets -> Propriétés -> CheckImageKind et sélectionnez ckDarkCheck.<br />
#Inspecteur d'objets -> Propriétés -> TreeOptions -> MiscOptions -> toCheckSupport et la mettre à True.<br><br />
Maintenant passer à l'onglet évènements.<br><br />
*Faites défiler jusqu'à OnInitNode. Double-cliquez et collez ce qui suit:<br />
<PRE><br />
procedure TForm1.VSTInitNode(Sender: TBaseVirtualTree; ParentNode,<br />
Node: PVirtualNode; var InitialStates: TVirtualNodeInitStates);<br />
Var<br />
Level: Integer;<br />
begin<br />
Level := VST.GetNodeLevel(Node);<br />
if Level = 0 then<br />
Node.CheckType:=ctCheckBox;<br />
<br />
if Level = 2 then<br />
Node.CheckType:=ctRadioButton;<br />
<br />
if Level = 1 then<br />
begin<br />
Node.CheckType:=ctTriStateCheckBox;<br />
Node.CheckState := csCheckedNormal;<br />
end;<br />
<br />
if Level = 3 then<br />
Node.CheckType:=ctButton;<br />
end;<br />
</PRE><br />
Lancez le programme, ajoutez le nœud racine et un nœud enfant puis l'enfant d'un enfant, et vérifiez si vous pouvez cocher et décocher correctement. Si non, fermez le programme. Allez à l'onglet évènements de l'inspecteur d'objets.<br />
*Faites défiler jusqu'à OnChecked, double-cliquez et collez:<br />
<PRE><br />
procedure TForm1.VSTChecked(Sender: TBaseVirtualTree; Node: PVirtualNode);<br />
begin<br />
vst.Refresh;<br />
end;<br />
</PRE><br />
*Faites défiler jusqu'à OnChecking, double-cliquez et collez:<br />
<PRE><br />
procedure TForm1.VSTChecking(Sender: TBaseVirtualTree; Node: PVirtualNode;<br />
var NewState: TCheckState; var Allowed: Boolean);<br />
begin<br />
VST.Refresh;<br />
end;<br />
</PRE><br />
J'espère maintenant que c'est ok. Pour déterminer l'état du checkbox utilisez quelque chose comme:<BR><br />
<br />
If XNode.CheckState = csCheckedNormal then<br><br />
ShowMessage('Checked.');<br><br />
<br />
Les autres états sont:<br><br />
<PRE><br />
csUncheckedNormal = unchecked and not pressed<br />
csUncheckedPressed = unchecked and pressed<br />
csCheckedNormal = checked and not pressed<br />
csCheckedPressed = checked and pressed<br />
csMixedNormal = 3-state check box and not pressed<br />
csMixedPressed = 3-state check box and pressed<br />
</PRE><br />
<br />
Les autres types sont:<br><br />
<PRE><br />
ctNone<br />
ctTriStateCheckBox<br />
ctCheckBox<br />
ctRadioButton<br />
ctButton<br />
</PRE><br />
*Pour capturer le clic du bouton Checkbox (ctButton) <br />
Allez à l'onglet évènements de l'inspecteur d'objets. Faites défiler jusqu'à OnChecked, double-cliquez et collez:<br />
<PRE><br />
procedure TForm1.VSTChecked(Sender: TBaseVirtualTree; Node: PVirtualNode);<br />
begin<br />
if Node.CheckType = ctButton then<br />
ShowMessage('Ok.');<br />
VST.Refresh;<br />
end; <br />
</PRE><br />
Fin de checkbox.<br><br />
<br />
----<br />
----<br />
<br />
=Image & Font Colour=<br />
----<br />
To show image on VST nodes, a list of image should be created.<br />
*Go to the Component Palette -> Common Controls. Select and drop a TImageList component on the form. Right click on the component icon and select ImageList Editor. Click on Add button and and select some images (at least 3 for now), then click on tick button to accept and close the ImageList Editor. By the way, there are some nice images you can download from http://www.famfamfam.com/lab/icons/silk/ <br />
*Now on the Form Designer select VST, and on Object Inspector's Properties tab, scroll to Images and select ImageList1<br />
*On Object Inspector's Events tab scroll to OnGetImageIndex, double click and paste:<br />
<PRE><br />
procedure TForm1.VSTGetImageIndex(Sender: TBaseVirtualTree; Node: PVirtualNode;<br />
Kind: TVTImageKind; Column: TColumnIndex; var Ghosted: Boolean;<br />
var ImageIndex: Integer);<br />
begin<br />
if Kind in [ikNormal , ikSelected] then // Either Selected or not<br />
begin<br />
if Column = 0 then // if 1st Column<br />
ImageIndex:=0; // 1st Image of the ImageList1<br />
<br />
if Column = 1 then // if 2nd Column<br />
ImageIndex:=1; // 2nd Image of the ImageList1<br />
<br />
if Sender.FocusedNode = Node then // Only show if Focused<br />
if Column =2 then // if 3rd Column<br />
ImageIndex:=2; // 3rd Image of the ImageList1<br />
end;<br />
{Sender.NodeHeight[node]:=40; //If Image is big}<br />
end;<br />
</PRE><br />
=====Font Colour=====<br />
On the Form Designer select VST, and on Object Inspector's Events tab, scroll to OnPaintText, double click and paste:<br />
<PRE><br />
procedure TForm1.VSTPaintText(Sender: TBaseVirtualTree;<br />
const TargetCanvas: TCanvas; Node: PVirtualNode; Column: TColumnIndex;<br />
TextType: TVSTTextType);<br />
Var<br />
Data: PTreeData;<br />
begin<br />
Data := VST.GetNodeData(Node);<br />
<br />
if Data^.Column0 = 'sky' then<br />
TargetCanvas.Font.Color:=clBlue;<br />
<br />
if Column = 1 then<br />
begin<br />
TargetCanvas.Font.Color:=clRed;<br />
TargetCanvas.Font.Style:= Font.Style + [fsItalic];<br />
end;<br />
<br />
if Column = 2 then<br />
begin<br />
// ImageList1.Draw(Form1.Canvas,-1,-1,2); {draw top left of form, 3rd image of ImageList1??}<br />
TargetCanvas.Font.Size:= 9;<br />
TargetCanvas.Font.Color:=clHighlightText;<br />
end;<br />
end; <br />
</PRE><br />
Image & Font Colour ends here.<br />
<br />
=Adding A Combobox=<br />
*I guess you have an open project on Lazarus IDE having VST on it and can edit the nodes. If not see the "Basic Tree Listview With 3 Columns" above, and atleast complete steps 1 to 21.<br />
<br />
*Bellow there is an unit file named combo. Copy that unit and save as combo.pas inside the project directory. Under your program's uses clause add combo. So it may look like:<br />
<PRE><br />
uses<br />
Classes, SysUtils, LResources, Forms, Controls, Graphics, Dialogs,<br />
VirtualStringTree, VirtualTrees, combo;<br />
</PRE><br />
<br />
*The combo.pas unit<br />
<PRE><br />
unit combo;<br />
<br />
{$mode delphi}<br />
<br />
interface<br />
<br />
uses<br />
Classes, SysUtils, LResources, Forms, Controls, Graphics, Dialogs,<br />
VirtualStringTree, VirtualTrees, messages, windows, StdCtrls;<br />
<br />
type<br />
TStringEditLink = class(TInterfacedObject, IVTEditLink)<br />
private<br />
FEdit: TWinControl;<br />
FTree: TVirtualStringTree;<br />
FNode: PVirtualNode;<br />
FColumn: Integer;<br />
protected<br />
procedure EditKeyDown(Sender: TObject; var Key: Word; Shift: TShiftState);<br />
public<br />
destructor Destroy; override;<br />
function BeginEdit: Boolean; stdcall;<br />
function CancelEdit: Boolean; stdcall;<br />
function EndEdit: Boolean; stdcall;<br />
function GetBounds: TRect; stdcall;<br />
function PrepareEdit(Tree: TBaseVirtualTree; Node: PVirtualNode; Column: TColumnIndex): Boolean; stdcall;<br />
procedure ProcessMessage(var Message: TMessage); stdcall;<br />
procedure SetBounds(R: TRect); stdcall;<br />
end;<br />
<br />
implementation<br />
<br />
destructor TStringEditLink.Destroy;<br />
begin<br />
FEdit.Free;<br />
inherited;<br />
end;<br />
<br />
procedure TStringEditLink.EditKeyDown(Sender: TObject; var Key: Word; Shift: TShiftState);<br />
begin<br />
case Key of<br />
VK_ESCAPE:<br />
begin<br />
FTree.CancelEditNode;<br />
Key := 0;<br />
FTree.setfocus;<br />
end;<br />
VK_RETURN:<br />
begin<br />
PostMessage(FTree.Handle, WM_KEYDOWN, VK_DOWN, 0);<br />
Key := 0;<br />
FTree.EndEditNode;<br />
FTree.setfocus;<br />
end;<br />
End; //case<br />
end;<br />
<br />
<br />
function TStringEditLink.BeginEdit: Boolean;<br />
begin<br />
Result := True;<br />
//FEdit.Height:=(FTree.DefaultNodeHeight - 1); //Needed for editbox. Not combo<br />
FEdit.Show;<br />
TComboBox(FEdit).DroppedDown:=True;<br />
FEdit.SetFocus;<br />
end;<br />
<br />
function TStringEditLink.CancelEdit: Boolean;<br />
begin<br />
Result := True;<br />
FEdit.Hide;<br />
end;<br />
<br />
<br />
function TStringEditLink.EndEdit: Boolean;<br />
var<br />
S: WideString;<br />
begin<br />
Result := True;<br />
S:= TComboBox(FEdit).Text;<br />
FTree.Text[FNode, FColumn] := S;<br />
<br />
FTree.InvalidateNode(FNode);<br />
FEdit.Hide;<br />
FTree.SetFocus;<br />
end;<br />
<br />
<br />
function TStringEditLink.GetBounds: TRect;<br />
begin<br />
Result := FEdit.BoundsRect;<br />
end;<br />
<br />
<br />
function TStringEditLink.PrepareEdit(Tree: TBaseVirtualTree; Node: PVirtualNode; Column: TColumnIndex): Boolean;<br />
begin<br />
Result := True;<br />
FTree := Tree as TVirtualStringTree;<br />
FNode := Node;<br />
FColumn := Column;<br />
<br />
FEdit.Free;<br />
FEdit := nil;<br />
<br />
FEdit := TComboBox.Create(nil);<br />
with FEdit as TComboBox do<br />
begin<br />
Visible := False;<br />
Parent := Tree;<br />
Items.Add('Google');<br />
Items.Add('Yahoo');<br />
Items.Add('Altavista');<br />
OnKeyDown := EditKeyDown;<br />
end;<br />
end;<br />
<br />
<br />
procedure TStringEditLink.ProcessMessage(var Message: TMessage);<br />
begin<br />
FEdit.WindowProc(Message);<br />
end;<br />
<br />
<br />
procedure TStringEditLink.SetBounds(R: TRect);<br />
var<br />
Dummy: Integer;<br />
<br />
begin<br />
FTree.Header.Columns.GetColumnBounds(FColumn, Dummy, R.Right);<br />
FEdit.BoundsRect := R;<br />
end;<br />
<br />
End.<br />
</PRE><br />
<br />
*After saving the file, on the Form Designer select VST and on Object Inspector's Properties, scroll to TreeOptions -> MiscOptions, set toEditable to True. Then get to TreeOptions -> SelectionOptions, set toExtendedFocus to True.<br />
<br />
*Switch to Object Inspector's Events tab. Scroll to OnCreateEditor, double click and paste:<br />
<PRE><br />
procedure TForm1.VSTCreateEditor(Sender: TBaseVirtualTree;<br />
Node: PVirtualNode; Column: TColumnIndex; out EditLink: IVTEditLink);<br />
begin<br />
EditLink:=TStringEditLink.Create;<br />
end;<br />
</PRE><br />
<br />
*On Object Inspector's Events tab. Scroll to OnNewText, double click and paste:<br />
<PRE><br />
procedure TForm1.VSTNewText(Sender: TBaseVirtualTree; Node: PVirtualNode;<br />
Column: TColumnIndex; NewText: WideString);<br />
Var<br />
Data: PTreeData;<br />
begin<br />
Data := VST.GetNodeData(Node);<br />
Case Column of<br />
0: Data^.Column0:= NewText;<br />
1: Data^.Column1:= NewText;<br />
2: Data^.Column2:= NewText;<br />
End;<br />
end;<br />
</PRE><br />
Run program, select a node and press F2 to get combobox. On pressing Enter new value should appear on the node.<br />
<br />
=If Cell Editing Can't Be Seen=<br />
----<br />
Open VirtualStringTree.pas unit file (if you are still on the above example project, right click on VirtualStringTree <br />
under Uses clause and select Find Declaration. This opens the file on next tab. Go to that file's tab.). Get to the "function TStringEditLink.BeginEdit: Boolean; stdcall;".<br />
It looks like:<br />
<PRE> <br />
function TStringEditLink.BeginEdit: Boolean; stdcall;<br />
<br />
// Notifies the edit link that editing can start now. Descentants may cancel node edit<br />
// by returning False.<br />
<br />
begin<br />
Result := not FStopping;<br />
if Result then<br />
begin<br />
FEdit.Show;<br />
FEdit.SelectAll;<br />
FEdit.SetFocus;<br />
end;<br />
end; <br />
</PRE> <br />
<br />
Now add "FEdit.Height:=18;". It should look like:<br />
<br />
<PRE><br />
function TStringEditLink.BeginEdit: Boolean; stdcall;<br />
<br />
// Notifies the edit link that editing can start now. Descentants may cancel node edit<br />
// by returning False.<br />
<br />
begin<br />
Result := not FStopping;<br />
if Result then<br />
begin<br />
FEdit.Show;<br />
FEdit.SelectAll;<br />
FEdit.SetFocus;<br />
FEdit.Height:=18; // <--- Added this line.<br />
end;<br />
end; <br />
</PRE><br />
<br />
Save the file (press Ctrl + S). If you are on the example project, close this (Project -> Close Project). Click on Tools -> Configure "Build Lazarus" ... Select Clean Up + Build All and then click on the Build button. After compile Lazarus should be restarted. Now open the example project and try to edit node on VST. This time it should be ok.<br />
<BR><br />
Thank you.<BR><br />
--[[User:Rabiul|Rabiul]] 21:37, 20 October 2008 (CEST)<BR><br />
Alhamdulillah.<br />
<br />
----<br />
[http://es.wikibooks.org/wiki/Programaci%C3%B3n_en_Pascal Programando en Pascal] - Spanish tutorial focused on FPC/Lazarus, hosted in Wikibooks.</div>Alain