原文链接 -> 传送门
函数功能:
SetTimer 函数用于创建一个具有指定超时时间的定时器。
API 函数原型:
注释:_In_ 说明该参数是输入的,_opt_ 说明该参数是可选的。
UINT_PTR WINAPI SetTimer( _In_opt_ HWND hWnd, _In_ UINT_PTR nIDEvent, _In_ UINT uElapse, _In_opt_ TIMERPROC lpTimerFunc );
参数解析:
|
参数 |
含义 |
|
hWnd |
1. 指定与定时器相关联的窗口的句柄 |
|
nIDEvent |
1. 非零的定时器标志符 |
|
uElapse |
1. 以毫秒为单位的超时值 |
|
lpTimerFunc |
1. 指向一个函数的指针,当经过超时值时间时,该函数将被调用 |
返回值:
1. 如果函数调用成功,并且 hWnd 参数为 NULL,则返回值为标识新定时器的整型值。应用程序可以传递该值给 KillTimer 函数来销毁该定时器;
2. 如果函数调用成功,并且 hWnd 参数不为 NULL,则返回值为非零的整型值,应用程序可以传递 nIDEvent 参数的值给 KillTimer 函数来销毁该定时器;
3. 如果函数创建定时器失败,则返回值为 0;
获取有关错误的更多信息,请调用 GetLastError 函数。
备注:
1. 应用程序可以通过在窗口过程中包含 WM_TIMER case 语句,或者在创建定时器时指定 TimerProc 回调函数来处理 WM_TIMER 消息。在你指定了一个 TimerProc 回调函数之后,当窗口处理 WM_TIMER 消息时,默认的窗口过程便会调用该回调函数。因此,你需要在调用线程中分派该消息,甚至在你使用 TimerProc 而不是在窗口过程中处理 WM_TIMER 消息时。
2. WM_TIMER 消息的 wParam 参数包含 nIDEvent 参数的值。
3. 定时器标志符,nIDEvent,是与窗口相关联的。不同的窗口能有相同的定时器标识符。这些定时器是不同的。
4. SetTimer 函数在 hWnd 参数的值为 NULL 的情况下能够重复使用定时器标识符。
需求:
|
Minimum supported client |
Windows 2000 专业版 [桌面应用程序] |
|
Minimum supported server |
Windows 2000 服务器版 [桌面应用程序] |
|
Header |
Winuser.h (包含于 Windows.h) |
|
Library |
User32.lib |
|
DLL |
User32.dll |




