• <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>
            posts - 131, comments - 12, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            VC定時器SetTimer函數

            Posted on 2012-09-20 08:56 盛勝 閱讀(557) 評論(0)  編輯 收藏 引用

            一、SetTimer表示的是定義個定時器。根據定義指定的窗口,在指定的窗口(CWnd)中實現OnTimer事件,這樣,就可以相應事件了。

            SetTimer有兩個函數。

            ①一個是全局的函數::SetTimer()

            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
            );

            其中hWnd 是指向CWnd的指針,即處理Timer事件的窗口類。因此繼承CWnd的子類均可以定義SetTimer事件。

            ②SetTimer() 在CWnd中也有定義,即SetTimer()是CWnd的一個成員函數。CWnd的子類可以調用該函數,來設置觸發器。

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

            參數含義:

            nIDEvent:是指設置這個定時器的iD,即身份標志,這樣在OnTimer()事件中,才能根據不同的定時器,來做不同的事件響應。這個ID是一個無符號的整型。

            nElapse

            是指時間延遲。單位是毫秒。這意味著,每隔nElapse毫秒系統調用一次Ontimer()。

            void (CALLBACK EXPORT* lpfnTimer)(HWND, UINT, UINT, DWORD)

            Specifies the address of the application-supplied TimerProc callback function that processes the WM_TIMER messages. If this parameter is NULL, the WM_TIMER messages are placed in the application’s message queue and handled by the CWnd object。

            意思是,指定應用程序提供的TimerProc回調函數的地址,來處里這個Timer事件。如果是NULL,系統將交由OnTimer()來處理這個Timer事件。

            所以,一般情況下,我們將這個值設為NULL,有設置該定時器的對象中的OnTimer()函數來處理這個事件。

            例:SetTimer(1,1000,NULL);

            如果我要加入兩個或者兩個以上的 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;
                }
            }

            二、我們再看看KillTimer()和OnTimer()的定義:

            KillTimer同SetTimer()一樣,他也有兩個,一個是全局的::KillTimer(),另一個是CWnd的一個函數。他的聲明如下:

            //全局函數

            BOOL KillTimer(
            HWND hWnd, // handle of window that installed timer
            UINT uIDEvent // timer identifier
            );

            //CWnd函數

            BOOL KillTimer(int nIDEvent );

            這兩個函數表示的意思是將iD為nIDEVENT的定時器移走。使其不再作用。其用法如同SetTimer()一樣。

            再看看OnTimer()

            CWnd::OnTimer
            afx_msg void OnTimer(UINT nIDEvent);


            ontimer() 是響應CWnd對象產生的WM_Timer消息。nIDEvent表示要響應TIMER事件的ID。

            例子:SetTimer(2,2000,NULL);
            OnTimer(UINT nIDEvent);//此時SetTimer中的2將傳遞給nIDEvent
            99久久精品费精品国产一区二区| 久久人人妻人人爽人人爽| 69久久夜色精品国产69| 久久er热视频在这里精品| 一级女性全黄久久生活片免费| 亚洲欧美国产日韩综合久久| 久久精品水蜜桃av综合天堂| 色综合久久88色综合天天 | 一本久久免费视频| 国产精品9999久久久久| 精品久久人人爽天天玩人人妻| 精品亚洲综合久久中文字幕| 乱亲女H秽乱长久久久| 久久久久波多野结衣高潮| 久久精品综合网| 久久天天日天天操综合伊人av| 久久九九兔免费精品6| 久久天天躁狠狠躁夜夜2020一| 久久人人爽人人爽人人片AV东京热| 开心久久婷婷综合中文字幕| 久久精品国产精品亚洲下载| 国产精品免费看久久久香蕉| 久久国产热这里只有精品| 浪潮AV色综合久久天堂| 久久亚洲AV无码西西人体| 九九热久久免费视频| 国产精品美女久久久久久2018| 日韩电影久久久被窝网| 青青青国产精品国产精品久久久久| 久久99精品综合国产首页| 99久久99久久久精品齐齐| 狠狠人妻久久久久久综合| 久久久精品人妻无码专区不卡| 一本一本久久a久久精品综合麻豆| 久久涩综合| 亚洲综合精品香蕉久久网| 久久久久夜夜夜精品国产| 一本一道久久a久久精品综合 | 久久男人中文字幕资源站| 国产69精品久久久久APP下载| 久久精品亚洲日本波多野结衣|