Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   GUI-Design mit VCL / FireMonkey / Common Controls (https://www.delphipraxis.net/18-gui-design-mit-vcl-firemonkey-common-controls/)
-   -   Delphi VirtualTreeView, OnGetImageIndexEx und OverlayImages (https://www.delphipraxis.net/195726-virtualtreeview-ongetimageindexex-und-overlayimages.html)

Codehunter 21. Mär 2018 09:39

AW: VirtualTreeView, OnGetImageIndexEx und OverlayImages
 
Hallo Uwe,

ich hatte den Bug gestern Abend bei Github gemeldet und der Joachim Marder hat den so schnell behoben dass ich gar nicht hinterher kam das zu kapieren ^^

du hast in allen Punkten völlig recht. Das fängt schon mit der Win32-seitigen Implementierung der Overlays an. Eine Limitierung auf 15 wirkt willkürlich und irgendwie aus der Zeit gefallen. Es wird sicher einmal gute Gründe dafür gegeben haben, heute sehe ich darin keinen Sinn mehr. Die Implementierung im VST greift diese Tatsache auf, wahrscheinlich um abwärtskompatibel zu bleiben zu dem altertümlichen Overlay-Zeichnen von Windows und der TImageList.

Meine Vermutung war anscheinend richtig, als man OnGetImageIndexEx eingebaut hat, wurde die Tatsache schlicht vergessen dass die Overlays in der selben Imagelist liegen müssen. Das läuft dem Konzept von OnGetImageIndexEx grundsätzlich zuwider, das ja sich von OnGetImageIndex nur darin unterscheidet, eben mehrere Imagelists verwenden zu können.

Zitat:

Zitat von Uwe Raabe (Beitrag 1396853)
Ich finde die aktuelle Implementierung ziemlich verwirrend und fehleranfällig.

Also verwirrend ist sie wirklich. Ich hab da den halben Tag gestanden wie der Ochs vorm Scheunentor wie man bei uns sagt. Ich habe mit dem "klassischen" Overlay-Zeichnen (also die von Windows vorgesehene Lösung mit den ersten 15 Images) noch nie verwendet. Für mich war die Lösung mit dem Custom Drawing viel naheliegender und vom Anwendungsdesign her viel eleganter.

Bleibt halt nur noch die Frage, ob der Performancegewinn der nativen Pinselei so viel ausmacht, dass es die Nachteile der verwirrenden Implementierung aufwiegt.

Grüße
Cody


Alle Zeitangaben in WEZ +1. Es ist jetzt 15:30 Uhr.
Seite 2 von 2     12   

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz