DOEVENTS |
DOEVENTS() |
Pauses execution to let the system process other events. |
REMARKS |
* The DoEvents function always returns zero. * DoEvents passes control to the operating system. * Control is returned after the operating system has finished processing the events in its queue and all keys in the SendKeys queue have been sent. * DoEvents is most useful for simple things like allowing a user to cancel a process after it has started, for example a search for a file. * For long-running processes, yielding the processor is better accomplished by using a Timer or delegating the task to an ActiveX EXE component. * In the latter case, the task can continue completely independent of your application, and the operating system takes case of multitasking and time slicing. * Any time you temporarily yield the processor within an event procedure, make sure the procedure is not executed again from a different part of your code before the first call returns; this could cause unpredictable results. * In addition, do not use DoEvents if other applications could possibly interact with your procedure in unforeseen ways during the time you have yielded control. * For more information, refer to the Macros > Timing page. * For the Microsoft documentation refer to learn.microsoft.com |
Dim PauseTime As Integer
Dim Start As Single
Dim Finish As Single
Dim TotalTime As Single
PauseTime = 3
Start = VBA.Timer()
Do While VBA.Timer() < (Start + PauseTime)
DoEvents
Loop
Finish = VBA.Timer
TotalTime = Finish - Start
© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited Top