SetTimer
The SetTimer function creates a timer with the specified time-out value.
UINT SetTimer(
HWND hWnd, // handle of window for timer messages
UINT nIDEvent, // timer identifier
UINT uElapse, // time-out value
TIMERPROC lpTimerFunc // address of timer procedure );
The SetTimer function creates a timer with the specified time-out value. 첫번째 인수 : 타이머 받을 윈도우
두번째 인수 : 타이머의 번호 (하나 이용시 1을 쓰고, 그외에 타이머들은 번호를 고유한 부여시킨다 )
세번째 인수 : 타이머의 주기 단위는 1/1000초 ( 1000 == 1초 )
네번째 인수 : 타이머 발생시 호출하는 함수 지정.
예) SetTimer(hWnd, 1, 1000, NULL );
//타이머는 시스템 전역 자원으로 이용 후 파괴하는것이 좋다.
BOOL KillTimer(
HWND hWnd, // handle of window that installed timer
UINT uIDEvent // timer identifier
);
두번째 인수 : SetTimer의 두번째 인자값이며, 파괴할 타이머 번호 대상이 된다.
////////////////////////////////////////////////////////////////////////////////////
두개의 타이머 이용. 두개의 타이머 모두 WM_TIMER를 호출 한다.
또한 강제로 SendMessage()로 WM_TIMER를 불러 프로그램 시작 직후 바로 적용시킨다.
//예제
case WM_CREATE:
SetTimer(hWnd, 1, 1000, NULL);
SetTimer(hWnd, 2, 5000, NULL);
SendMessage(hWnd, WM_TIMER, 1, 0);
return 0;
case WM_TIMER:
switch(wParam)
{
case 1:
GetLocalTime(&st);
wsprintf(sTime,TEXT("현재 시간 %d:%d:%d"),
st.wHour, st.wMinute, st.wSecond);
InvalidateRect(hWnd, NULL, TRUE);
break;
case 2:
MessageBeep(0);
break;
}
return 0;////////////////////////////////////////////////////////////////////////////////////
일회용 타이머를 이용.
//WM_TIMER에 KillTimer를 넣어 이벤트 발생시 3초동안 글자 표시하고 사라지게 만드는 예제
static TCHAR str[128];
switch(iMessage)
{
case WM_TIMER:
KillTimer(hWnd, 1);
lstrcpy(str,"");
InvalidateRect(hWnd, NULL, TRUE);
return 0;
case WM_LBUTTONDOWN:
lstrcpy(str,"왼쪽 버튼을 눌렀습니다.");
InvalidateRect(hWnd, NULL, TRUE);
SetTimer(hWnd, 1, 3000, NULL);
return 0;
case WM_PAINT:
hdc = BeginPaint(hWnd, &ps);
TextOut(hdc, 10,10, str, lstrlen(str));
EndPaint(hWnd, &ps);
return 0;
}