• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            山寨:不是最好的,是最適合我們的!歡迎體驗山寨 中文版MSDN

            Blog @ Blog

            當華美的葉片落盡,生命的脈絡才歷歷可見。 -- 聶魯達

            常用鏈接

            統計

            積分與排名

            BBS

            Blog

            Web

            最新評論

            SetTimer函數的用法

            什么時候我們需要用到SetTimer函數呢?當你需要每個一段時間執行一件事的的時候就需要使用SetTimer函數了。 使用定時器的方法比較簡單,通常告訴WINDOWS一個時間間隔,然后WINDOWS以此時間間隔周期性觸發程序。通常有兩種方法來實現:發送WM_TIMER消息和調用應用程序定義的回調函數。

            1.1 用WM_TIMER來設置定時器

            先請看SetTimer這個API函數的原型

            UINT_PTR SetTimer(
              HWND hWnd,              // 窗口句柄
              UINT_PTR nIDEvent,      // 定時器ID,多個定時器時,可以通過該ID判斷是哪個定時器
              UINT uElapse,           // 時間間隔,單位為毫秒
              TIMERPROC lpTimerFunc   // 回調函數
            );

            例如
            SetTimer(m_hWnd,1,1000,NULL); //一個1秒觸發一次的定時器
            在MFC程序中SetTimer被封裝在CWnd類中,調用就不用指定窗口句柄了

            于是SetTimer函數的原型變為:

            UINT SetTimer(UINT nIDEvent,UINT nElapse,void(CALLBACK EXPORT *lpfnTimer)(HWND,UINT ,YINT ,DWORD))

            當使用SetTimer函數的時候,就會生成一個計時器。函數中nIDEvent指的是計時器的標識,也就是名字。nElapse指的是時間間隔,也就是每隔多長時間觸發一次事件。第三個參數是一個回調函數,在這個函數里,放入你想要做的事情的代碼,你可以將它設定為NULL,也就是使用系統默認的回調函數,系統默認認的是onTime函數。這個函數怎么生成的呢?你需要在需要計時器的類的生成onTime函數:在ClassWizard里,選擇需要計時器的類,添加WM_TIME消息映射,就自動生成onTime函數了。然后在函數里添加代碼,讓代碼實現功能。每隔一段時間就會自動執行一次。

            例:

            SetTimer(1,1000,NULL);

            1:計時器的名稱;

            1000:時間間隔,單位是毫秒;

            NULL:使用onTime函數。

            當不需要計時器的時候調用KillTimer(nIDEvent);

            例如:KillTimer(1);

            1.2 調用回調函數

            此方法首先寫一個如下格式的回調函數

            void CALLBACK TimerProc(HWND hWnd,UINT nMsg,UINT nTimerid,DWORD dwTime);
            然后再用SetTimer(1,100,TimerProc)函數來建一個定時器,第三個參數就是回調函數地址。

            二. 或許你會問,如果我要加入兩個或者兩個以上的 timer怎么辦?

            繼續用SetTimer函數吧,上次的timer的ID是1,這次可以是2,3,4。。。。

            SetTimer(2,1000,NULL);

            SetTimer(3,500,NULL);

            嗯,WINDOWS會協調他們的。當然onTimer函數體也要發生變化,要在函數體內添加每一個timer的處理代碼:

            onTimer(nIDEvent)

            {

            switch(nIDEvent)

            {

            case 1:........;

            break;

            case 2:.......;

            break;

            case 3:......;

            break;

            }

            }

            什么時候我們需要用到SetTimer函數呢?當你需要每個一段時間執行一件事的的時候就需要使用SetTimer函數了。 使用定時器的方法比較簡單,通常告訴WINDOWS一個時間間隔,然后WINDOWS以此時間間隔周期性觸發程序。通常有兩種方法來實現:發送WM_TIMER消息和調用應用程序定義的回調函數。

            1.1 用WM_TIMER來設置定時器

            先請看SetTimer這個API函數的原型

            UINT_PTR SetTimer(
              HWND hWnd,              // 窗口句柄
              UINT_PTR nIDEvent,      // 定時器ID,多個定時器時,可以通過該ID判斷是哪個定時器
              UINT uElapse,           // 時間間隔,單位為毫秒
              TIMERPROC lpTimerFunc   // 回調函數
            );

            例如
            SetTimer(m_hWnd,1,1000,NULL); //一個1秒觸發一次的定時器
            在MFC程序中SetTimer被封裝在CWnd類中,調用就不用指定窗口句柄了

            于是SetTimer函數的原型變為:

            UINT SetTimer(UINT nIDEvent,UINT nElapse,void(CALLBACK EXPORT *lpfnTimer)(HWND,UINT ,YINT ,DWORD))

            當使用SetTimer函數的時候,就會生成一個計時器。函數中nIDEvent指的是計時器的標識,也就是名字。nElapse指的是時間間隔,也就是每隔多長時間觸發一次事件。第三個參數是一個回調函數,在這個函數里,放入你想要做的事情的代碼,你可以將它設定為NULL,也就是使用系統默認的回調函數,系統默認認的是onTime函數。這個函數怎么生成的呢?你需要在需要計時器的類的生成onTime函數:在ClassWizard里,選擇需要計時器的類,添加WM_TIME消息映射,就自動生成onTime函數了。然后在函數里添加代碼,讓代碼實現功能。每隔一段時間就會自動執行一次。

            例:

            SetTimer(1,1000,NULL);

            1:計時器的名稱;

            1000:時間間隔,單位是毫秒;

            NULL:使用onTime函數。

            當不需要計時器的時候調用KillTimer(nIDEvent);

            例如:KillTimer(1);

            1.2 調用回調函數

            此方法首先寫一個如下格式的回調函數

            void CALLBACK TimerProc(HWND hWnd,UINT nMsg,UINT nTimerid,DWORD dwTime);
            然后再用SetTimer(1,100,TimerProc)函數來建一個定時器,第三個參數就是回調函數地址。

            二. 或許你會問,如果我要加入兩個或者兩個以上的 timer怎么辦?

            繼續用SetTimer函數吧,上次的timer的ID是1,這次可以是2,3,4。。。。

            SetTimer(2,1000,NULL);

            SetTimer(3,500,NULL);

            嗯,WINDOWS會協調他們的。當然onTimer函數體也要發生變化,要在函數體內添加每一個timer的處理代碼:

            onTimer(nIDEvent)

            {

            switch(nIDEvent)

            {

            case 1:........;

            break;

            case 2:.......;

            break;

            case 3:......;

            break;

            }

            }

            posted on 2008-03-20 14:04 isabc 閱讀(1747) 評論(0)  編輯 收藏 引用 所屬分類: VC Function

            廣告信息(免費廣告聯系)

            中文版MSDN:
            歡迎體驗

            热久久国产精品| 国产精品免费看久久久| 国产精品99久久久久久www| 国产国产成人久久精品| 久久一区二区三区免费| 蜜臀久久99精品久久久久久小说| 国产精品女同久久久久电影院| 久久精品一区二区三区中文字幕 | 一本色道久久88—综合亚洲精品| 日韩精品久久无码人妻中文字幕| 999久久久免费国产精品播放| 久久亚洲精品成人无码网站| 亚洲国产精品久久久久| 久久精品国产男包| 99热都是精品久久久久久| 久久99国产乱子伦精品免费| 亚洲精品无码久久毛片| 久久国产成人精品麻豆| 久久久久久久女国产乱让韩| 国产精品热久久无码av| 97久久香蕉国产线看观看| 久久久亚洲裙底偷窥综合 | 国内精品久久久久久99| 国产精品gz久久久| 久久国产乱子精品免费女| 色欲久久久天天天综合网精品| 青青草国产97免久久费观看| 国产综合精品久久亚洲| 久久久精品午夜免费不卡| 久久婷婷五月综合色高清| 久久精品国产2020| AV无码久久久久不卡蜜桃| 久久国内免费视频| 亚洲精品第一综合99久久| 国产午夜精品久久久久九九| 国产69精品久久久久99| 色综合久久88色综合天天| 女人香蕉久久**毛片精品| 青青青国产精品国产精品久久久久| 99久久久精品| 9191精品国产免费久久|