![]() |
AW: ListView mit OwnerData schneller machen?
Zitat:
|
AW: ListView mit OwnerData schneller machen?
Ich muss erst gucken ob ich es noch habe. Ich hab es einfach als Übung gesehen, da speichere ich die Ergebnisse nicht immer. Selbst wenn, es war etwas chaotisch, da ich vieles auf ein mal getestet habe. Ich gucke mal aber mein Tempordner ob ich was finde, wenn ja, melde ich mich.
|
AW: ListView mit OwnerData schneller machen?
Zitat:
![]() |
AW: ListView mit OwnerData schneller machen?
TVirtualTreeView funktioniert sehr gut auch mit großen Datenmengen.
|
AW: ListView mit OwnerData schneller machen?
Das Grundprinzip beim OwnerDraw / Virtual ist, dass die Daten in einer Struktur unabhängig vom Control abgelegt werden.
Das Control bekommt bei einer Änderung nur noch mitgeteilt, dass sich die Anzahl der Einträge geändert haben (ruft implizit
Delphi-Quellcode:
auf) oder dass sich einfach nur der Inhalt geändert hat (expliziter Aufruf von
Invalidate
Delphi-Quellcode:
).
Invalidate
Beim ListView mit
Delphi-Quellcode:
sollte zwingend
OwnerDraw
Delphi-Quellcode:
eingeschaltet werden, dass gibt sonst ganz hässliche Effekte (enfach mal ohne ausprobieren, will man danach nicht mehr haben).
DoubleBuffered
Kleiner Profi-Tipp (habe ich mal aufgeschnappt): Eine Basis-Form von der alle Forms des Projekts abgeleitet werden prüft ob es dort ein ListView-Control mit OwnerDraw gibt und schaltet automatisch DoubleBuffered ein. Dann kann man das vergessen, weil man es nicht mehr vergisst ;) |
AW: ListView mit OwnerData schneller machen?
Liste der Anhänge anzeigen (Anzahl: 1)
Also ich konnte das alte Beispiel nicht finden, deshalb habe ich auf die Schnelle etwas zusammengebastelt. Also bitte nicht zu kritisch sein, ist nur eine Übung. Auch habe ich alles in ein Ereignis gepackt, damit es schneller geht. Das Prinzip sollte aber erkennbar sein, zuerst wird alles in eine Liste geladen, dann an LV übergeben, zuletzt im Ereignis vervollständigt.
EDIT: Ich bin den Code noch mal durchgegangen und paar Fehler entdeckt, so werden einige Werte nicht in Data gespeichert, aber es funktioniert trotz dem. |
AW: ListView mit OwnerData schneller machen?
Zitat:
|
AW: ListView mit OwnerData schneller machen?
popov, ich habe dein beispiel mal ausprobiert. auf die art un weise kann ich das Item.ImageIndex := ImageList.AddIcon(FileIcon); in DrawSubItem der ListView verlegen.
mein vorgang dauert zwar noch immer 4 sekunden (besser als +20 vorher) aber in der zeile "Item.ImageIndex := ImageList.AddIcon(FileIcon);" sagt delphi mir dass die "bildgröße nicht gültig/korrekt" wäre. problem hat sich erledigt. statt ImageList musste ich ImageList1 einsetzen. frage: ist das dein persönlicher stil da noch vorher
Delphi-Quellcode:
zu machen oder hat das einen zweck?
ListView := TListView(Sender);
ImageList := TImageList(ListView.SmallImages); denn ich verwende einfach ImageList1 (bei mir gibt es nur eine). |
AW: ListView mit OwnerData schneller machen?
Das hat weniger mit Stil zu tun. Ich kann zwar den Fehler nicht erkennen, aber wie gesagt, es war schnell erstellt. Im Grunde ist es egal ob man
Delphi-Quellcode:
oder
ListView1
Delphi-Quellcode:
nutzt, aber, vorausgesetzt der Sender ist ListView1, brauche ich den Namen nicht, sondern hole mir den lokal. Der Vorteil, ich kann irgendwann ListViews1 umbenennen, ohne das auch ich Code machen zu müssen. Das gleiche gibt für
ListView := TListView(Sender);
Delphi-Quellcode:
. Auch im SmallImages sollte die ImageList stehen, vorausgesetzt sie wurde eingetragen. Warum also auf die Komponente per Namen zugreifen, ich hole mir die Komponente lokal.
ImageList := TImageList(ListView.SmallImages);
Ob das nun richtig ist oder falsch, keine Ahnung, ich sehe Vorteile drin. Bei Bedarf kann ich mir aus einem anderen Programm den Code kopieren ohne ihn ändern zu müssen. Dann gibt es noch die Möglichkeit deine SystemListe zu nutzen, das habe ich aber auch noch nicht ganz raus. @d7user1 Ich hab gerade dein andern Thread: ![]() So wie das Beispiel (oben) steht ist es nicht optimal, aber die Frage war nicht darum optimal zu sein, sondern eine menge Items schnell anzuzeigen. Das andere Problem spielte keine Rolle, also habe ich es im Beispiel gelassen. Es geht drum, dass wenn du 13.000 Dateien mit Icons liest, du auch 13.000 Icons in ImageList speicherst. Das ist eigentlich nicht nötig, denn viele Icons wiederholen sich. Also warum das gleiche Icon immer und immer wieder speichern? Die Lösung ist iIcon, u. U. auch szDisplayName (das habe ich noch nicht ganz geprüft). Zumindest bekommt man bei iIcon eine Zahl die anscheinend Typisch für ein Icon ist. Somit muss prüfen ob das Icon in der ImageList bereits drin ist, wenn ja, einfach nur auf dieses Icon verweisen. |
AW: ListView mit OwnerData schneller machen?
hier ist ein beispiel zu iIcon aber es funktionier nicht mit iner ListView (vorher war überall ComboBoxEx):
Delphi-Quellcode:
procedure DisplayDrivesEx(aListView: TListView);
var i, j: Integer; vItem: TListItem; vFileInfo: TSHFileInfo; vImgList: THandle; s, D: string; sl: TStringList; begin sl := TStringList.Create; sl.Add('C:\'); sl.Add('D:\'); sl.Add('E:\'); sl.Add('D:\TestDatei.exe'); try aListView.Items.BeginUpdate; aListView.Items.Clear; vImgList := SHGetFileInfo(PChar(sl[0]), 0, vFileInfo, SizeOf(vFileInfo), SHGFI_SYSICONINDEX or SHGFI_SMALLICON); SendMessage(aListView.Handle, CBEM_SETIMAGELIST, 0, vImgList); DestroyIcon(vFileInfo.hIcon); for i := 0 to sl.Count - 1 do begin SHGetFileInfo(PChar(sl[i]), 0, vFileInfo, SizeOf(vFileInfo), SHGFI_SYSICONINDEX or SHGFI_SMALLICON or SHGFI_DISPLAYNAME); vItem := aListView.Items.Add; vItem.ImageIndex := vFileInfo.iIcon; end; finally aListView.Items.EndUpdate; end; sl.Free; end; |
Alle Zeitangaben in WEZ +1. Es ist jetzt 21:43 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