Détruit le Timer spécifié
#include <Timers.au3>
_Timer_KillTimer ( $hWnd, $iTimerID )
$hWnd |
Handle de la fenêtre associée au Timer indiquée. Cette valeur doit être la même que la valeur $hWnd transmise à la fonction _Timer_SetTimer() qui a créé le Timer |
$iTimerID | Indique l'ID du Timer à détruire |
Succès: | Retourne True |
Échec: | Retourne False |
La fonction _Timer_KillTimer() ne supprime pas les messages WM_TIMER déjà ajoutés à la file d'attente des messages.
Cette fonction ne doit pas être utilisée dans une fonction de rappel définie par _Time_SetTimer().
_Timer_KillAllTimers, _Timer_SetTimer
Consultez KillTimer dans la librairie MSDN.
#include <GUIConstantsEx.au3> #include <GuiStatusBar.au3> #include <ProgressConstants.au3> #include <Timers.au3> #include <WindowsConstants.au3> Global $g_idMemo, $g_hStatus, $g_idProgress, $g_iPercent = 0, $g_iDirection = 1 _Example_CallBack() Func _Example_CallBack() Local $hGUI, $iTimerProgress, $idChange, $iWait = 10, $idState Local $aParts[3] = [75, 330, -1] $hGUI = GUICreate("Utilisation des Timers dans des fonctions CallBack", 400, 320) $g_idMemo = GUICtrlCreateEdit("", 2, 32, 396, 226, BitOR($WS_HSCROLL, $WS_VSCROLL)) GUICtrlSetFont($g_idMemo, 9, 400, 0, "Courier New") $idState = GUICtrlCreateButton("Start Progress Bar", 70, 270, 100, 25) $idChange = GUICtrlCreateButton("Change", 215, 270, 90, 25) GUICtrlSetState($idChange, $GUI_DISABLE) $g_hStatus = _GUICtrlStatusBar_Create($hGUI, $aParts) _GUICtrlStatusBar_SetText($g_hStatus, "Timers") _GUICtrlStatusBar_SetText($g_hStatus, @TAB & @TAB & StringFormat("%02d:%02d:%02d", @HOUR, @MIN, @SEC), 2) $g_idProgress = GUICtrlCreateProgress(0, 0, -1, -1, $PBS_SMOOTH) GUICtrlSetColor($g_idProgress, 0xff0000) _GUICtrlStatusBar_EmbedControl($g_hStatus, 1, GUICtrlGetHandle($g_idProgress)) GUISetState(@SW_SHOW) _Timer_SetTimer($hGUI, 1000, "_UpdateStatusBarClock") ; Crée un Timer Local $iMsg = GUIGetMsg() While $iMsg <> $GUI_EVENT_CLOSE Switch $iMsg Case $idState If GUICtrlRead($idState) = "Start Progress Bar" Then ; Crée un Timer $iTimerProgress = _Timer_SetTimer($hGUI, $iWait, "_UpdateProgressBar") If (Not @error) And ($iTimerProgress <> 0) Then GUICtrlSetData($idState, "Stop Progress Bar") GUICtrlSetState($idChange, $GUI_ENABLE) EndIf Else GUICtrlSetState($idChange, $GUI_DISABLE) _Timer_KillTimer($hGUI, $iTimerProgress) GUICtrlSetData($idState, "Start Progress Bar") EndIf Case $idChange $iWait = ($iWait = 10 ? 250 : 10) MemoWrite("Timer for _UpdateProgressBar set at: " & $iWait & " milliseconds") ; Ré-utilise le Timer avec un intervalle différent $iTimerProgress = _Timer_SetTimer($hGUI, $iWait, "", $iTimerProgress) EndSwitch $iMsg = GUIGetMsg() WEnd ConsoleWrite("Timers détruits? " & _Timer_KillAllTimers($hGUI) & @CRLF) GUIDelete() EndFunc ;==>_Example_CallBack ; Fonction Callback Func _UpdateStatusBarClock($hWnd, $iMsg, $iIDTimer, $iTime) #forceref $hWnd, $iMsg, $iIDTimer, $iTime _GUICtrlStatusBar_SetText($g_hStatus, @TAB & @TAB & StringFormat("%02d:%02d:%02d", @HOUR, @MIN, @SEC), 2) EndFunc ;==>_UpdateStatusBarClock ; Fonction Callback Func _UpdateProgressBar($hWnd, $iMsg, $iIDTimer, $iTime) #forceref $hWnd, $iMsg, $iIDTimer, $iTime $g_iPercent += 5 * $g_iDirection GUICtrlSetData($g_idProgress, $g_iPercent) If $g_iPercent = 100 Or $g_iPercent = 0 Then $g_iDirection *= -1 If $g_iPercent = 100 Then GUICtrlSetColor($g_idProgress, 0xff0000) ElseIf $g_iPercent = 0 Then GUICtrlSetColor($g_idProgress, 0x0000ff) EndIf EndFunc ;==>_UpdateProgressBar ; Écrit une ligne dans le contrôle mémo Func MemoWrite($sMessage) GUICtrlSetData($g_idMemo, $sMessage & @CRLF, 1) EndFunc ;==>MemoWrite
#include <Timers.au3> Global $g_iMsecs = 0, $g_sResult = '', $g_sCDdrv _Example_TimeOut() Func _Example_TimeOut() $g_sCDdrv = DriveGetDrive("CDROM") $g_sCDdrv = $g_sCDdrv[1] Local $hGUI = GUICreate("", 140, 64, -1, -1, 0) GUICtrlCreateLabel("Insérez un CD dans le lecteur", 8, 8, 115, 17) GUISetState(@SW_SHOW) Local $iIDtimer = _Timer_SetTimer($hGUI, 1000, "Check_mounted") ; Crée un timer While $g_sResult = '' Sleep(200) WEnd _Timer_KillTimer($hGUI, $iIDtimer) MsgBox(0, '', $g_sResult, 5) ConsoleWrite("Killed All Timers? " & _Timer_KillAllTimers($hGUI) & @CRLF) ; Doit être False car tous les chronomètres ont déjà été éliminés GUIDelete($hGUI) EndFunc ;==>_Example_TimeOut Func Check_mounted($hWnd, $iMsg, $iIDtimer, $iTime) #forceref $hWnd, $iMsg, $iIDTimer,$iTime $g_sResult = '' If FileExists($g_sCDdrv & '\') Then $g_sResult = DriveGetLabel($g_sCDdrv) & ' inséré' & @CRLF $g_sResult &= 'dans le lecteur ' & $g_sCDdrv Else $g_iMsecs += 1000 If $g_iMsecs = 10000 Then $g_sResult = 'timed out' EndIf EndIf EndFunc ;==>Check_mounted