• <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 閱讀(1751) 評論(0)  編輯 收藏 引用 所屬分類: VC Function

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

            中文版MSDN:
            歡迎體驗

            久久99国产综合精品女同| 国内精品综合久久久40p| 久久久精品免费国产四虎| 中文精品久久久久国产网址| 久久久久国产一级毛片高清板| 欧美精品福利视频一区二区三区久久久精品 | 色妞色综合久久夜夜| 97久久精品无码一区二区| 日日狠狠久久偷偷色综合免费| 久久精品国产亚洲av麻豆图片| 久久久久久久99精品免费观看| 国产精品久久久香蕉| A级毛片无码久久精品免费| 亚洲成色www久久网站夜月 | 99国产欧美精品久久久蜜芽| 午夜精品久久久内射近拍高清| 九九久久99综合一区二区| 国产精品99久久久精品无码| 91精品国产91久久久久久| 久久久久久久久无码精品亚洲日韩| 久久久国产精品| 国产日韩欧美久久| 国内精品久久久久| 久久天天躁狠狠躁夜夜躁2O2O| 久久这里的只有是精品23| 久久久久人妻一区精品| 国产三级观看久久| 9191精品国产免费久久| 欧美伊香蕉久久综合类网站| 国产午夜福利精品久久2021| 久久精品亚洲日本波多野结衣| 波多野结衣AV无码久久一区| 久久人人爽人人爽人人爽| 91麻豆国产精品91久久久| 欧美日韩精品久久久免费观看| 亚洲人成无码www久久久| 伊色综合久久之综合久久| 久久久精品久久久久影院| 久久精品国产精品亚洲精品| 午夜精品久久久久久99热| 久久精品亚洲中文字幕无码麻豆|