![]() |
Re: Node eindeutig identifizieren, JvPageListTreeView
Zitat:
|
Re: Node eindeutig identifizieren, JvPageListTreeView
Guten Morgen...
Zitat:
Danke an alle... |
Re: Node eindeutig identifizieren, JvPageListTreeView
Zitat:
Zitat:
Delphi-Quellcode:
So bekommst Du dann den Index des Knotens. Also nix mit '...dümmlich..' :zwinker:
Function IndexOfNode(aDataContents : Integer) : Integer;
Begin For Result:=0 to TreeView.Nodes.Count-1 do If Integer (TreeView.Nodes[Result].Data) = aDataContents Then Exit; Result := -1 End; Du deklarierst deine ID als Konstanten, z.B.
Delphi-Quellcode:
Dann fügst Du die Knoten in deinen Baum ein, wobei Du der 'Data'-Eigenschaft die ID-Konstanten zuweist.
Const
IDDatenbankSeite = 0; IDBenutzereinstellungen = 1; ... Auf einen konkreten Knoten (z.B. den mit den Benutzereinstellungen) greifst Du dann so zu:
Delphi-Quellcode:
Wenn Dir das zu blöd ist, merkst Du Dir die Indizes der einzelnen ID-Konstanten. Allerdings musst Du die dann bei Änderungen an der Baumstruktur erneut zuweisen:
TreeView.Nodes[IndexOfNode(IDBenutzereinstellungen)].Selected := True
Delphi-Quellcode:
Übrigens hätte ich als Anwender ein Riesenproblem damit, das sich die Reihenfolge des Baumes ändert, wenn neue Eigenschaftsseiten hinzukommen. Anwender bevorzugen kleiche *Positionen* von Dingen als wenn sie in einer sortierten Liste jedesmal suchen müssen. Du hättest in unterschiedlichen Sprachen auch ein unterschiedliches Layout. Toll für den, der deine Anwendung in beiden Sprachen bedienen muss.
Var
idxDatenbankseite, idxBenutzereinstellungen : Integer; ... idxDatenbankseite := IndexOfNode(IDDatenbankSeite); idxBenutzereinstellungen := IndexOfMode(IDBenutzereinstellungen); ... TreeView.Nodes[idxBenutzereinstellungen].Selected := True Obige vorgeschlagene Trennung von Position und Identifikation bleibt jedoch hiervon unberührt, da es die klar robustere Implementierung ggü. fest verdrahteten Index-Konstanten ist. |
Re: Node eindeutig identifizieren, JvPageListTreeView
Liste der Anhänge anzeigen (Anzahl: 1)
Danke für Deine Zeit... 8)
...klar das Dein Code funktioniert :wink: ...aber das ganze ist viel simpler...siehe Bild - ich benutze ein JvPageListTreeView in Verbindung mit JvPageList. - jeder Knoten im Tree ist "verlinkt" mit einer Page aus der JvPageList (Designzeit)...(wie PageControl nur ohne Reiter) - der Tree verändert sich wenn überhaupt nur zur Designzeit - wenn der Tree auch zur Laufzeit Veränderungen hätte, müßte man selbstverständlich mehr Aufwand betreiben. :zwinker: - der Tree ist einfach nur eine Liste und nicht kompliziert "verknotet" - da sich der Tree eigentlich nicht verändert fand ich das Durchsuchen der Nodes jedesmal zur Laufzeit etwas übertrieben. - mir ging es im wesentlichen um die Wartbarkeit des Codes bei Veränderungen / Ergänzungen des Tree´s PS: mit dem "dümmlich" meinte ich den Direktzugriff auf die Eigenschaft. Mit einem Schleifendurchlauf durch alle Nodes ist klar, daß man den Index bzw. die Eigenschaften des Nodes auswerten kann. :zwinker: Zitat:
Zitat:
Ich wünsche Dir frohe Feiertage... :hi: :oops: verkehrtes Bild... |
Re: Node eindeutig identifizieren, JvPageListTreeView
Liste der Anhänge anzeigen (Anzahl: 1)
Ich kenne dieses Paradigma. Ich würde jedoch versuchen, die Eigenschaftsseiten zu gruppieren, also eine Art Hierarchie hereinzubringen. Dann wird das übersichtlicher.
Betrieb -- Allgemeine Einstellungen -- Programmstart -- Datenbank Filter -- Filterarten -- Filtergrößen -- Filterqualitäten ... Bei der Frage, was sich ein Anwender eher merkt, streiten sich die Gelehrten übrigens nicht: Positionen erkennen und merken kann sich der Mensch schon seit Jahrmillionen, Lesen erst seit ein paar hundert Jahren. Bei der Ergonomie sollten Instinkte berücksichtigt werden, kognitive Fähigkeiten eher nicht. Dann wird ein Dialog als 'einfach', 'übersichtlich' und 'nicht überladen' angesehen. Wenn Du schon Paradigmenwechsel beim Eingabedialog (überladene Pagecontrol => strukturierte Treeview) durchführst, solltest Du konsequent sein, und ihn auch bis zum Ende durchziehen (und nicht auf halbem Wege stehenbleiben). Großartig übersichtlicher dein Dialog so ja auch nicht, denn Du stellst ja nur die Tabs anders dar. Solche Eigenschaftsdialoge (ob nun hierarchisch oder nicht) habe ich auch zur Genüge implementiert. Ich verwende mittlerweile die von mir beschriebene Implementierung, da bei der Weiterentwicklung immer wieder neue Eigenschaftsseiten hinzukommen. Ich gruppiere auch um, sodaß sich die Indexe während der Entwicklung ständig ändern. Mit der Trennung habe ich nun keine Probleme mehr. Allerdings hänge ich in die Data-Eigenschaft das TabSheet in in dessen Tag-Eigenschaft meine ID. So kann ich beim Wechsel im Baum das entsprechende Tab anzeigen und finde gleichzeitig den richtigen Knoten zu einem Tab. Ich habe z.B. in meinen Datenbank-Dialogen grundsätzlich einen Knopf "Einstellungen". Wenn man den drückt, kommt der Eigenschaftsdialog hoch, wobei gleich die 'Datenbank'-Seite ausgewählt ist. Zitat:
Zitat:
|
Re: Node eindeutig identifizieren, JvPageListTreeView
Liste der Anhänge anzeigen (Anzahl: 2)
Zitat:
Zitat:
- es gibt im Prinzip 2 Versionen des Tree´s (visuell) mit und ohne Datenbankverbindung - es ist zwar nicht die feine englische Art aber um mir das Neuaufbauen des Tree´s zu ersparen habe ich die 2 Versionen des Tree´s übereinander gelegt und je nach Status ist der eine oder der andere Visible. PS: an deinem Beispiel kann man deutlich sehen, daß die Icons im Tree das ganze optisch auch auflockern. :thumb: ...bis später. [edit] ...ist´s so besser ? :wink: ...siehe Bild PS: - die 5 da oben ist der derzeitige AbsolutIndex des gewählten Knotens...Information für mich 8) - die Breite ist so ok, da es Einstellungen gibt, welche die gesamte Breite beanspruchen. (Bild2) [/edit] |
Alle Zeitangaben in WEZ +1. Es ist jetzt 17:21 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz