AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein GUI-Design mit VCL / FireMonkey / Common Controls Delphi VirtualTreeView, OnGetImageIndexEx und OverlayImages
Thema durchsuchen
Ansicht
Themen-Optionen

VirtualTreeView, OnGetImageIndexEx und OverlayImages

Ein Thema von Codehunter · begonnen am 20. Mär 2018 · letzter Beitrag vom 21. Mär 2018
Antwort Antwort
Seite 2 von 2     12   
Benutzerbild von Codehunter
Codehunter

Registriert seit: 3. Jun 2003
Ort: Thüringen
2.272 Beiträge
 
Delphi 10.4 Sydney
 
#11

AW: VirtualTreeView, OnGetImageIndexEx und OverlayImages

  Alt 21. Mär 2018, 09:39
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.

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
Ich mache grundsätzlich keine Screenshots. Schießen auf Bildschirme gibt nämlich hässliche Pixelfehler und schadet der Gesundheit vom Kollegen gegenüber. I und E zu vertauschen hätte den selben negativen Effekt, würde aber eher dem Betriebsklima schaden
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 12:04 Uhr.
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