Windows API一日一練(67)SetTimer和KillTimer函數

來源:互聯網
上載者:User

在前面介紹了一對定時器的API函數使用,現在又介紹另外一對API函數的使用。它使用起來比前的函數要簡單一些,但它一般是使用到有視窗的程式裡,並且它的精度也沒有前面的API函數高,對於一些要求不高的場合還是非常合適的。它是採用訊息通知的方式,每當定時到了就會收到一條訊息。
 
函數SetTimer和KillTimer聲明如下:
 
WINAPI
SetTimer(
    __in_opt HWND hWnd,
    __in UINT_PTR nIDEvent,
    __in UINT uElapse,
    __in_opt TIMERPROC lpTimerFunc);
 
WINUSERAPI
BOOL
WINAPI
KillTimer(
    __in_opt HWND hWnd,
    __in UINT_PTR uIDEvent);
 
hWnd是視窗接收定時器的控制代碼。
nIDEvent是定時器事件標識號。
uElapse是定時器的毫秒值。
lpTimerFunc是定時到達回呼函數。
 
調用函數的例子如下:
#001 //設定定時器。
#002              ::SetTimer(m_hWnd,             //指向視窗的控制代碼。
#003                   IDT_TIMER1,            // 定時器標識。
#004                   1000,                 // 1秒
#005                   (TIMERPROC) NULL);     // 不使用回呼函數。
 
接收WM_TIMER訊息並關閉定時器:
#001 case WM_TIMER:
#002         {
#003               if (IDT_TIMER1 == wParam)
#004               {
#005                    OutputDebugString(_T("定時器測試訊息關閉\r\n"));
#006                   ::KillTimer(m_hWnd,IDT_TIMER1);
#007               }
#008              
#009         }
#010         break;

本文來自CSDN部落格,轉載請標明出處:http://blog.csdn.net/caimouse/archive/2007/11/07/1872372.aspx

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.