Timer Events in MFC Applications

Event timers are always handy to have around and useful in nearly every project. When a timer is readily available, such as the Timer control in Visual Basic, you find all kinds of reasons to use one in an application. The lack of a timer object in MFC is, in my opinion, a serious oversight.

Luckily, Microsoft Windows NT/95 systems provide a number of timers for use by application programs. This tutorial provides information on how to install timers in your MFC application, and how to start, process and stop the timers.

In the final section of the tutorial, we develope a simple timer project which is capable of rough animation of an icon in the dialog window. This project is useful in any compute or I/O bound application, and illustrates the techniques involved with installing and using a system timer.

These steps were developed and tested on a WindowsNT 4.0 workstation and Windows95 using VisualC++ 4.2 with Microsoft Foundation Classes.

Installing a Timer

  • In the header file of the dialog using the timer,
  • Add a message number for each timer needed:

    #define

    IDT_TIMER_0

    WM_USER + 200

    #define

    IDT_TIMER_1

    IDT_TIMER_0 + 1

  • Add the timer interrupt handler

    OnTimer (UINT TimerVal)

    to the Generated Message Map:

  • locate the section under Implementation where the AFX_MSG message map is declared (usually begins with the line OnInitDialog());
  • add a line just after the last line in the message map (just before the "//}}AFX_MSG"):

    afx_msg

    void

    OnTimer (UINT TimerVal);

  • This should be the last entry in the message map.
    • In the dialog implementation (.cpp) file,
  • Locate the dialog class start
  • Find the line starting "BEGIN_MESSAGE_MAP"
  • After the last entry in the message map (before the line "//}}AFX_MSG_MAP"), add

    ON_WM_TIMER ( )

    Starting the timer

    To start the timer, you must issue a SetTimer command:

    t-number = SetTimer (t-messaget-interval, NULL)

    where:

    t-message

    The message number assigned for processing the timer request. 
    This is referred to as IDT_TIMER_0 in the installation instructions.

    t-interval

    The timer duration, in mSec.

    t-number

    The system timer number assigned to this event, or 0 if no timers available.

    For Example:

    UINT StartTimer (UINT TimerDuration)

    {

    UINT TimerVal;

    TimerVal = SetTimer (IDT_TIMER_0, TimerDuration, NULL);

    if (TimerVal == 0)

    {

    MessageBox ("Unable to obtain timer",

    "IDT_TIMER_0",

    MB_OK|MB_SYSTEMMODAL);

    }

    return TimerVal;

    }// end StartTimer

    To start the timer, pass it the value of the timer duration, in milliseconds (mSec). If the returned value is non-zero, the timer has been initialized.

    Note: You must save the assigned timer value in order to stop the timer, and also to know which timer to process in a multi-timer application.

    Stopping the Timer

    To stop the timer, issue the KillTimer command:

    t-result = KillTimer (t-number);

    where:

    t-number

    The system timer number from either the SetTimer or OnTimer methods.

    t-result

    The boolean result of the operation, TRUE indicating success.

    For Example:

    BOOL StopTimer (UINT TimerVal)

    {

    //

    // Stop the timer

    //

    if (!KillTimer (TimerVal))

    {

    return FALSE;

    }

    //

    // Place clean-up code following this point.

    //

    return TRUE;

    } // end StopTimer

    Processing Timer Events - The OnTimer Method

    After the timer has been started, the OnTimer event will be called each time the timer counts down to zero (reaches terminal count) from the requested value. This event is asynchronous to the timer - a message is placed in the message queue of the calling process and the timer is automatically restarted.

    The timer can be stopped (refer to Stopping the Timer) upon entry to the OnTimer routine, or left to run if the event will not occur again before processing the OnTimer routine has completed.

    The OnTimer method will be executed each time the timer reaches terminal count. The code in this method should be short and concise; it should be code which must be executed each time the timer reaches its terminal count, such as changing the view of an animated drawing or icon, or setting a flag to process latter, or starting a thread to handle the more complex functions.

    Example:

    void OnTimer (UINT TimerVal)

    {

    //////////////////////////////////////////////

    //

    // Stop the timer

    //

    //////////////////////////////////////////////

    if (!KillTimer (TimerVal))

    {

    }

    //////////////////////////////////////////////

    //

    // Process the event

    //

    //////////////////////////////////////////////

    //////////////////////////////////////////////

    //

    // Restart the timer, if needed, before exiting

    //

    //////////////////////////////////////////////

    }

    Multiple Timers

    The OnTimer method is passed an unsigned integer (UINT) to identify the timer which is interrupting. The value of this timer may be used to stop the associated timer. It can also be used in a multiple timer environment to determine what type of processing must occur.

    Example:

    Assumptions:

    • The timers are started using the example in the section on Installing a Timer.
    • The timer values are placed sequentially into the array ATimer, as follows:
      • ATimer [0] = StartTimer (200); // a 200 mSec timer
      • ATimer [1] = StartTimer (500); // a 500 mSec timer

    void OnTimer (UINT TimerVal)

    {

    int Index;

    /////////////////////////////////////////////////////////////////////////////

    //

    // Check timer number 0

    //

    ////////////////////////////////////////////////////////////////////////////

    if (TimerVal == ATimer[0])

    {

    //

    // Process timer 0 message!

    //

    return;

    }

    ////////////////////////////////////////////////////////////////////////////

    //

    // check timer number 1

    //

    ////////////////////////////////////////////////////////////////////////////

    if (TimerVal == ATimer[1])

    {

    //

    // Process timer 1 message!

    //

    return;

    }

    ////////////////////////////////////////////////////////////////////////////

    //

    // Not timer number 0 or 1

    //

    ////////////////////////////////////////////////////////////////////////////

    if (!KillTimer (TimerVal))

    {

    }

    CString Message;

    Message.format("Unkown timer interrupt: %u", TimerVal);

    MessageBox (Message,"OnTimer",MB_OK|MB_SYSTEMMODAL);

    } // end OnTimer

    From: https://www.developer.com/net/cplus/article.php/603531/Using-Timers-in-MFC-Applications.htm

Using Timers in MFC Applications的更多相关文章

  1. 基于VC的MFC界面开发

    教你熟悉VC6.0创建一个可视化软件的过程 UpdateData(TRUE);//将输入数据赋给文本框变量. UpdateData(FALSE);//将内容显示在文本框中 AfxMessageBox( ...

  2. 区别:Use MFC In A Shared DLL 和 Use MFC In A Static Library

    摘自:Programming Windows with MFC, 2nd Edition Choosing Use MFC In A Shared DLL minimizes your applica ...

  3. 一些非常好的VC++/MFC开源项目链接

    Introduction List of some of the best Open Source projects written in VC++/MFC. Background Codeproje ...

  4. Some Very Good VC++/MFC Resources Besides Codeproject.com

    Some Very Good VC++/MFC Resources Besides Codeproject.com http://www.naughter.com/ (VC++/MFC huge co ...

  5. 基于MFC的Media Player播放器的制作(4---功能实现代码)

    |   版权声明:本文为博主原创文章,未经博主允许不得转载. PandaPlayerDlg.h // PandaPlayerDlg.h : header file // //{{AFX_INCLUDE ...

  6. 第六篇--MFC美化界面

    1.MFC如何设置背景颜色 首先,为对话框添加WM_CTLCOLOR消息,方法为:右击Dialog窗口 --> Class Wizard --> Messages --> WM_CT ...

  7. MFC 学习笔记

    MFC 学习笔记 一.MFC编程基础: 概述: 常用头文件: MFC控制台程序: MFC库程序: 规则库可以被各种程序所调用,扩展库只能被MFC程序调用. MFC窗口程序: 示例: MFC库中类的简介 ...

  8. C++的简单“五子棋”游戏,只是核心代码,资源代码未添加

    ChessBoard.h #ifndef __CHESS_BOARD_H__ #define __CHESS_BOARD_H__ #include "DataStruct.h" # ...

  9. C++ 使用SQLite

    1.SQLite是一个完全独立的.不需要服务器.不要任何配置.支持SQL的.开源的文件数据库引擎.源代码和支持可以登录:http://www.sqlite.org/   1.1.下载sqlite3.d ...

随机推荐

  1. OpenVPN相同证书不同客户端设置不同静态IP的问题

    无解!只能老老实实的使用不同证书不同客户端实现设置不同的静态IP.OpenVPN设置静态IP是根据证书名设置的,不能是登录名,无效. 无解! 无解!

  2. hdu1465(放错信 错排公式)

    Problem Description 大家常常感慨,要做好一件事情真的不容易,确实,失败比成功容易多了! 做好“一件”事情尚且不易,若想永远成功而总从不失败,那更是难上加难了,就像花钱总是比挣钱容易 ...

  3. Uniscribe相关文章

    相关资料很少 http://msdn.microsoft.com/en-us/library/windows/desktop/dd374127(v=vs.85).aspx http://www.cnb ...

  4. C#消息队列(RabbitMQ)零基础从入门到实战演练

    一.课程介绍 如果您从工作中之听过但未有接触过消息对队列(MQ),如果你接触过一点关于MQ的知识,如果没有这么的多如果的话......,那么阿笨将通过本次<C#消息队列零基础从入门到实战演练&g ...

  5. 在使用SQLServer时忘记sa账号密码解决办法

    先以windows 身份验证方式登录SQLServer数据库,如下图所示: 打开查询分析器,运行如下代码: sp_password Null,'新密码','sa' 即可把原来的密码修改成新密码 例如: ...

  6. UIWindow 介绍:概述、作用、主要属性及方法

    概述: UIWindow 类是 UIView 的子类,用于管理.协调应用中显示的窗口,其两个最重要的职能就是 容器,给 view 提供展示的区域: 将事件(例如:点击事件.拖拉事件等)分发给 view ...

  7. 一致性Hash算法说明

    本文章比较好的说明了一致性Hash算法的概念 Hash算法一般分为除模求余和一致性Hash1.除模求余:当新增.删除机器时会导致大量key的移动2.一致性Hash:当新增.删除机器时只会影响到附近的k ...

  8. An internal error occurred during: &quot;Building workspace&quot;. GC overhead limit exceeded

    1 错误描写叙述 2 错误原因 3 解决的方法

  9. ViewFlipper的简单用法

    ViewFlipper和ViewPager挺像的,都是一个view容器.内部可以添加多个view,只是viewpager可以通过左右滑动来切换view,而viewFlipper则没有这个功能,所以需要 ...

  10. Java遍历对象所有属性

    要获取对象的所有属性可以使用getDeclaredFields()方法会返回一个Field数组遍历这个数组几个遍历所有属性注意使用这个方法会抛出4个异常然后根据属性的类型选择执行对应的内容 publi ...