| | The Timer control is great when you want to periodically execute a piece of code while the program is doing something else. However, it also has a couple of shortcomings: (1) it requires a parent form, so you can't use it directly inside a BAS module, and (2) it's Interval property can't be higher than 65,535, therefore you can't specify a timeout longer than about 65 seconds. 
 You can work around both the above limitations if you directly create a system timer using the SetTimer function. When you create a timer in this way you provide the address of a callback function, a function in a BAS module that Windows will call periodically. You need the following API declares to create and then distroy a system timer:
 | 
 |  Click here to copy the following block |  | Declare Function SetTimer Lib "user32" (ByVal hWnd As Long, _ ByVal nIDEvent  As Long, ByVal uElapse As Long, ByVal lpTimerFunc As Long) _
 As Long
 Declare Function KillTimer Lib "user32" (ByVal hWnd As Long, _
 ByVal nIDEvent As Long) As Long
 | 
 | This code creates a timer that is invoked every 500 milliseconds: | 
 | Note that you need a module-level or a global timerID variable to store the ID of the timer you create, because you must absolutely destroy the timer before the application terminates (or when you don't need it): ' Destroy the timer created previously
 | 
 | Here is an example of a timer callback routine: | 
 | For simplicity's sake, the above example uses this timer to display the number of milliseconds elapsed since Windows started in a Label control in a form (which is a job for which a regular Timer control is probably a better choice). In a real application you can use this technique for more interesting tasks, such as monitoring data coming from a serial port, checking your email account, watching the contents of a directory, updating program's statistics, and more. 
 
 | 
 |