Sie kennen das sicherlich: Während eines längeren Vorgangs soll dem Benutzer die Möglichkeit gegeben werden, den Vorgang bspw. durch Klick auf einen Button abbrechen zu können. Während der Vorgang läuft reagiert das Programm jedoch nicht auf Benutzer-Aktionen. Überall ist zu lesen, dass hier DoEvents das Allheilmittel ist! In gewisser Weise stimmt das auch! Allerdings sollte mit die DoEvents-Anweisung "sparsam" eingesetzt werden, da diese den gesamten Vorgang enorm verlangsamt. Beispiel: Es werden sehr viele Datensätze innerhalb einer Schleife verarbeitet. Der Vorgang soll jederzeit vom Benutzer angehalten / abgebrochen werden können. Wir setzen also ein DoEvents in die Schleife, damit wir auf einen Button-Klick (Abbruch) reagieren können. bAbort = False Do ' Aktion ... ' ... DoEvents ' Damit man auf einen Button-Klick oder ähnliches reagieren kann If bAbort Then Exit Do Loop Until ... Im Click-Event des Abbrechen-Buttons steht: Private Sub btnAbort_Click() If MsgBox("Wollen Sie den Vorgang wirklich abbrechen?", vbQuestion Or vbYesNo) = vbYes Then ' Abbrechen bAbort = True End If End Sub Mit obigen Code wird bei jeder einzelnen Aktion ein DoEvents aufgerufen. Dies verlangsamt den Prozess bei sehr vielen Schleifendurchläufen gewaltig! Besser ist es, wenn man DoEvents bspw. nur alle x - Schleifendurchläufe aufruft: Dim nCount As Long bAbort = False nCount = 0 Do ' Aktion ... ' ... nCount = nCount + 1 ' DoEvents nur alle 10 Schleifendurchläufe aufrufen If nCount Mod 10 = 0 Then DoEvents If bAbort Then Exit Do Loop Until ... Das Aufrufen von DoEvents alle x-Schleifendruchläufe verbessert die Performance schon enorm. Noch besser wäre es aber, wenn man DoEvents nur dann aufruft, wenn der User auch tatsächlich eine Taste oder einen Mausklick getätigt hat - oder? Genau für diesen Fall gibt es die GetInputState API-Funktion. Diese Funktion liefert einen Wert ungleich Null zurück, wenn ein Tastatur- oder Mausklick-Ereignis erfolgte. Option Explicit ' benötigte API-Deklarationen Public Declare Function GetInputState Lib "user32" () As Long Wir ändern den Code der Schleife also wie folgt ab, um die beste Performance zu erzielen: Dim nCount As Long bAbort = False Do ' Aktion ... ' ... ' Falls Tastatur-/Mausklick-Ereignis vorliegt If GetInputState() <> 0 Then DoEvents If bAbort Then Exit Do End If Loop Until ... Dieser Tipp wurde bereits 34.666 mal aufgerufen. Voriger Tipp | Zufälliger Tipp | Nächster Tipp
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv Vol.6 (einschl. Beispielprojekt!) Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! - nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten - Symbol-Galerie mit mehr als 3.200 Icons im modernen Look Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m. |
vb@rchiv CD Vol.6 Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! Online-Update-Funktion Entwickler-Vollversionen u.v.m. Tipp des Monats April 2024 Skyfloy Chart von Microsoft und dazu noch gratis Tutorial für Microsoft Chart Controls für Microsoft .NET Framework 3.5 Neu! sevCoolbar 3.0 Professionelle Toolbars im modernen Design! Mit sevCoolbar erstellen Sie in wenigen Minuten ansprechende und moderne Toolbars und passen diese optimal an das Layout Ihrer Anwendung an (inkl. große Symbolbibliothek) - für VB und MS-Access |
||||||||||||||||
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein. |