Using Timers in MFC Applications
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-message, t-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的更多相关文章
- 基于VC的MFC界面开发
教你熟悉VC6.0创建一个可视化软件的过程 UpdateData(TRUE);//将输入数据赋给文本框变量. UpdateData(FALSE);//将内容显示在文本框中 AfxMessageBox( ...
- 区别: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 ...
- 一些非常好的VC++/MFC开源项目链接
Introduction List of some of the best Open Source projects written in VC++/MFC. Background Codeproje ...
- 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 ...
- 基于MFC的Media Player播放器的制作(4---功能实现代码)
| 版权声明:本文为博主原创文章,未经博主允许不得转载. PandaPlayerDlg.h // PandaPlayerDlg.h : header file // //{{AFX_INCLUDE ...
- 第六篇--MFC美化界面
1.MFC如何设置背景颜色 首先,为对话框添加WM_CTLCOLOR消息,方法为:右击Dialog窗口 --> Class Wizard --> Messages --> WM_CT ...
- MFC 学习笔记
MFC 学习笔记 一.MFC编程基础: 概述: 常用头文件: MFC控制台程序: MFC库程序: 规则库可以被各种程序所调用,扩展库只能被MFC程序调用. MFC窗口程序: 示例: MFC库中类的简介 ...
- C++的简单“五子棋”游戏,只是核心代码,资源代码未添加
ChessBoard.h #ifndef __CHESS_BOARD_H__ #define __CHESS_BOARD_H__ #include "DataStruct.h" # ...
- C++ 使用SQLite
1.SQLite是一个完全独立的.不需要服务器.不要任何配置.支持SQL的.开源的文件数据库引擎.源代码和支持可以登录:http://www.sqlite.org/ 1.1.下载sqlite3.d ...
随机推荐
- External Input Counter and External interrupt
External Input Counter and External interrupt : count the input signal from the button. So what is t ...
- ubuntu中chown设置文件权限
参考文献: http://yanwen.org/doc/chown.html http://www.cppblog.com/deercoder/articles/110129.html 可以通过ls ...
- TCP套接字端口复用SO_REUSEADDR
下面建立的套接字都是tcp套接字 1.进程创建监听套接字socket1,邦定一个指定端口,并接受了若干连接.那么进程创建另外一个套接口socket2,并试图邦定同一个端口时候,bind错误返回“Add ...
- 报错:TargetException, 非静态方法需要一个目标
如果实例为null,调用实例方法会报如上错. 解决办法: 检查实例是否为null,考虑什么情况下实例为null,然后排除实例为null的情况.
- 升级WINDOWS10后任务栏的图标老是闪动是怎么回事
解决方法:1.进入设置→更新和安全→恢复2.找到高级启动,点击“立即重启3.重启后,进入第一个选择画面,点击“疑难解答”4.然后点击“高级选项”5.在其中选择“启动设置”6.这里给出了下次重启后的主要 ...
- 【IntelliJ IDEA】idea设置UTF-8的位置
如下图,JetBrains系列所有IDE都可以设置的位置
- .NET:注意 Primitive 这个小坑
背景 有个需求,需要递归遍历类型的所有属性(属性的属性),然后对不同的类型做不同的处理,或者只是将类型分为三类:Primitive.Complex 和 Collection.因为 MS 的 Type ...
- PetaPoco:SkipTake 和 Page 中的 OrderBy 子句不支持 “[]” 的解决办法
PetaPoco 的 SkipTake 和 Page 方法内部采用了内联视图,而内联视图是不支持 OrderBy 的,因此 PetaPoco 对传入的 SQL 进行分析,对 OrderBy 子句进行分 ...
- Java类加载机制的理解
算上大学,尽管接触Java已经有4年时间并对基本的API算得上熟练应用,但是依旧觉得自己对于Java的特性依然是一知半解.要成为优秀的Java开发人员,需要深入了解Java平台的工作方式,其中类加载机 ...
- [Android Security] APK自我保护 - 代码乱序
cp : https://segmentfault.com/a/1190000005095406 乱序原理 为了增加逆向分析的难度,可以将原有代码在 smali 格式上进行乱序处理同时又不会影响程序的 ...