• <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:
            歡迎體驗

            亚洲精品视频久久久| 久久精品国产第一区二区| 亚洲av伊人久久综合密臀性色| 大香伊人久久精品一区二区| 无码国内精品久久人妻麻豆按摩| 欧美久久久久久午夜精品| 青青草原综合久久大伊人导航| 欧美亚洲国产精品久久高清| 国内精品伊人久久久久av一坑| 国产—久久香蕉国产线看观看| 国产精品久久久久久久久久影院| 人人狠狠综合久久88成人| 99久久国产免费福利| 热re99久久精品国99热| 草草久久久无码国产专区| 久久午夜夜伦鲁鲁片免费无码影视 | 亚洲国产精品成人久久| 91麻豆精品国产91久久久久久| 国内精品久久久久影院老司| 99久久99久久| 久久亚洲私人国产精品vA | 久久久久综合国产欧美一区二区| 99久久精品免费看国产一区二区三区| 久久综合久久综合久久| 狠狠色狠狠色综合久久| 久久天天躁狠狠躁夜夜2020老熟妇 | 国产精品久久久天天影视香蕉| 777午夜精品久久av蜜臀| 精品久久久久国产免费 | 国产亚洲色婷婷久久99精品| 久久久久国产一区二区三区| a级成人毛片久久| 精品免费久久久久久久| 亚洲AV无码久久| 久久久久亚洲AV成人片| 亚洲国产精品无码久久| 欧美噜噜久久久XXX| 久久久久国产精品熟女影院| 久久亚洲AV成人无码软件| 国产美女亚洲精品久久久综合| 欧美久久亚洲精品|