Rubrik: Controls · ListBox | VB-Versionen: VB4, VB5, VB6 | 06.07.07 |
ListBox schneller füllen Durch kurzzeitiges "Unsichtbarmachen" der ListBox erfolgt das Füllen der ListBox bei größeren Datenmengen um ein vielfaches schneller. | ||
Autor: Dieter Otter | Bewertung: | Views: 13.340 |
www.tools4vb.de | System: Win9x, WinNT, Win2k, WinXP, Win7, Win8, Win10, Win11 | Beispielprojekt auf CD |
Immer wenn eine ListBox mit größeren Datenmengen gefüllt werden soll, empfiehlt sich die Aktualisierung der ListBox auszuschalten. Das hat den Vorteil, dass das Control nicht flackert, während die Einträge hinzugefügt werden und der gesamte Vorgang auch noch um ein Vielfaches schneller ausgeführt wird.
Am einfachsten lässt sich die Aktualisierung ausschalten, indem die Visible-Eigenschaft auf False gesetzt wird.
Anhand eines kleines Beispielprojekts haben wir einmal die Zeiten mit und ohne "Visible = False" gemessen. Die ListBox wurde hierbei mit 25.000 Einträgen gefüllt. Ohne das Ausschalten der Visible-Eigenschaft benötigte der Code auf unserem System 4,6 Sekunden. Durch das Abschalten der Aktualisierung brauchte der gesamte Vorgang nur noch 1.3 Sekunden.
Beispiel
Erstellen Sie ein neues Projekt, platzieren auf die Form1 ein ListBox-Control, ein CheckBox-Control, sowie einen Command-Button. Fügen Sie nachfolgenden Code in den
Codeteil der Form ein:
Private Sub Form1_Load() ' Controls beschriften Check1.Caption = "Aktualisierung abschalten" Command1.Text = "Start" End Sub Private Sub Command1_Click() Dim nTime As Single Dim i As Long ' Startzeit nTime = Timer With List1 ' Aktualisierung ausschalten If Check1.Value Then .Visible = False ' ListBox füllen .Clear For i = 1 To 25000 .AddItem "Eintrag " & CStr(i) Next i ' Aktualisierung wieder einschalten If Check1.Value Then .Visible = True End With ' Benötigte Zeit anzeigen Me.Caption = Format$(Timer - nTime, "0.#### Sek.") End Sub