Option Explicit
'Класс ВашТаймер служит упаковкой функций WIN32 API работы с таймером
'Интерфейс класса будут составлять две функции:
'СоздатьТаймер, УдалитьТаймер и свойство ИнтервалТаймера
'При работе с классом необходимо описать Callback функцию по следующему образцу:
'Public Sub TimerProc(ByVal HandleW As Long, ByVal msg As Long, _
' ByVal idEvent As Long, ByVal TimeSys As Long)
' 'Функция обратного вызова. Вызывается при обработке сообщения WM_Timer,
' 'посылаемого таймером, созданным процедурой SetTimer
'
' 'Поместите здесь свой код!
'
'End Sub
'Функции Win32 API для работы с таймером
Private Declare Function SetTimer Lib "user32" (ByVal hwnd As Long, _
ByVal nIDEvent As Long, ByVal uElapse As Long, ByVal lpTimerFunc As Long) As Long
Private Declare Function KillTimer Lib "user32" (ByVal hwnd As Long, ByVal nIDEvent As Long) As Long
'Свойства: Интервал - хранит значение интервала посылки сообщений
Private Интервал As Long
'Идентификатор таймера
Private IdEv As Long
Public Sub СоздатьТаймер()
'Создает таймер, вызывая Win32 Api функцию SetTimer
IdEv = SetTimer(0&, 0&, Интервал, AddressOf TimerProc)
If IdEv = 0 Then
MsgBox ("Не удалось создать таймер!")
Else
Debug.Print "Создан Таймер: Идентификатор = ", IdEv
End If
End Sub
Public Sub УдалитьТаймер()
'Удаляет таймер
If IdEv > 0 Then
Call KillTimer(0&, IdEv)
Debug.Print "Удален Таймер: Идентификатор = ", IdEv
IdEv = 0
End If
End Sub
Public Property Get ИнтервалТаймера() As Long
ИнтервалТаймера = Интервал
End Property
Public Property Let ИнтервалТаймера(ByVal NewValue As Long)
Интервал = NewValue
End Property
Private Sub Class_Initialize()
Интервал = 1000
End Sub
Private Sub Class_Terminate()
УдалитьТаймер
End Sub
|
Пример 6.12. |
| Закрыть окно |