新闻资讯
看你所看,想你所想

Timer

Timer

Timer,定时器,功能是在指定的时间间隔内反覆触发指定视窗的定时器事件。

基本介绍

  • 中文名:定时器
  • 外文名:Timer
  • 功能:指定时间间隔内触发指定视窗。

语法

()
语法Timer ( interval {, windowname } )

参数

指定两次触发Timer事件之间的时间间隔,有效值在0到65之间。如果该参数的值指定为0,那幺关闭定时器,不再触发指定视窗的Timer事件。windowname:视窗名,指定时间间隔到时要触发哪个视窗的Timer事件。省略该参数时,触发当前视窗的Timer事件返回值Integer。函式执行成功时返回1,发生错误时返回-1。如果任何参数的值为NULL,Timer()函式返回NULL。用法使用Timer()函式可以周期性地触发指定视窗的Timer事件,这样,每当时间间隔过去时,应用程式都可以完成一些周期性的工作,比如绘製简单动画等。将Timer()的interval参数设定为非0值时启动定时器并开始计时;将该函式的interval参数设定为0时关闭定时器,终止计时任务。需要注意的是,在Microsoft Windows系统中,该函式能够计时的最小时间间隔为0.055秒(约1/18秒),如果把interval参数的值设定小于0.055,那幺该定时器将每隔0.055秒触发一次视窗的Timer事件。Microsoft Windows 3.x最多只支持系统中同时启动16个定时器。

种类

1、 接通延时型定时器:接通延时型定时器是各种PLC中最常见最基本的定时器,这种定时器在 SIEMENS的PLC中,称为SD型定时器
2、 断开延时型定时器:这种定时器是当输入条件00000为ON时无延时作用,只有在输入条件00000为OFF时产生延时作用。在SIEMENS的PLC中,称为SF型定时器
3、保持型接通延时定时器:这种定时器是当输入条件00000为ON后,即产生锁存功能,即使输入条件00000又变为OFF,仍视输入条件为ON,当定时器的当前值等于设定值时,定时器动作,这种定时器在SIEMENS的PLC中,称为SS型定时器   4、脉冲型定时器:这种定时器是当输入条件00000为ON后,定时器即时动作,但经过定时器所设定的时间后,即使输入条件00000仍为ON,定时器却变为OFF状态。即这种定时器ON状态的维持时间是由设定值决定的。如果00000为ON的时续时间小于定时器的设定值,定时器的ON状态维持时间为输入条件00000为ON的持续时间。这种定时器在SIEMENS的PLC中,称为SP型定时器。   5、扩张型脉冲定时器:这种定时器与脉冲型定时器的区别是,只要输入条件00000齣现了ON状态,不管其持续时间多长,均可使定时器为ON的维持的时间与定时器的设定值一致。这种定时器在SIEMENS的PLC中,称为SE型定时器。

用法

我们可以使用MFC的CWnd类提供的成员函式SetTimer实现定时器功能,下面分步骤讲解MFC定时器的用法。
1、启动定时器。
启动定时器就需要使用CWnd类的成员函式SetTimer。CWnd::SetTimer的原型如下:
UINT_PTR SetTimer(    UINT_PTR nIDEvent,    UINT nElapse,    void (CALLBACK* lpfnTimer)(        HWND,        UINT,        UINT_PTR,        DWORD    ));
参数nIDEvent指定一个非零的定时器ID;参数nElapse指定间隔时间,单位为毫秒;参数lpfnTimer指定一个回调函式的地址,如果该参数为NULL,则WM_TIMER讯息被传送到应用程式的讯息伫列,并被CWnd对象处理。如果此函式成功则返回一个新的定时器的ID,我们可以使用此ID通过KillTimer成员函式来销毁该定时器,如果函式失败则返回0。
通过SetTimer成员函式我们可以看出,处理定时事件可以有两种方式,一种是通过WM_TIMER讯息的讯息回响函式,一种是通过回调函式。
如果要启动多个定时器就多次调用SetTimer成员函式。另外,在不同的CWnd中可以有ID相同的定时器,并不冲突。
2、为WM_TIMER讯息添加讯息处理函式,或者定义回调函式。
如果调用CWnd::SetTimer函式时最后一个参数为NULL,则通过WM_TIMER的讯息处理函式来处理定时事件。添加WM_TIMER讯息的处理函式的方法是,在VS2010工程的Class View类视图中找到要添加定时器的类,点击右键,选择Properties,显示其属性页,然后在属性页工具列上点击Messages按钮,下面列表就列出了所有讯息,找到WM_TIMER讯息,添加讯息处理函式。添加后,cpp档案中会出现类似如下内容:
BEGIN_MESSAGE_MAP(CExample44Dlg, CDialogEx)
......
ON_WM_TIMER()
END_MESSAGE_MAP()
void CExample44Dlg::OnTimer(UINT_PTR nIDEvent)
{
// TODO: Add your message handler code here and/or call default
CDialogEx::OnTimer(nIDEvent);
}
之后就可以在OnTimer函式中进行相应的处理了。OnTimer的参数nIDEvent为定时器ID,即在SetTimer成员函式中指定的定时器ID,如果有多个定时器,我们可以像下面这样处理:
void CExample44Dlg::OnTimer(UINT_PTR nIDEvent)
{
// TODO: Add your message handler code here and/or call default
switch (nIDEvent)
{
case 1:
// 如果收到ID为1的定时器的讯息则调用func1函式
func1();
break;
case 2:
// 如果收到ID为2的定时器的讯息则调用func2函式
fun2();
break;
......
default:
break;
}
CDialogEx::OnTimer(nIDEvent);
}
如果调用CWnd::SetTimer函式时最后一个参数不为NULL,则需要定义回调函式。回调函式的形式如下:
void CALLBACK EXPORT TimerProc(
HWND hWnd, // handle of CWnd that called SetTimer
UINT nMsg, // WM_TIMER
UINT nIDEvent // timer identification
DWORD dwTime // system time
);
参数hWnd为调用SetTimer成员函式的CWnd对象的句柄,即拥有此定时器的视窗的句柄;参数nMsg为WM_TIMER,而且总是为WM_TIMER;参数nIDEvent为定时器ID;参数dwTime为系统启动以来的毫秒数,即GetTickCount函式的返回值。
这样CWnd::SetTimer函式最后一个参数就可以为TimerProc。
这里注意下,回调函式的名称不一定为TimerProc,可以取其他名字,但返回值类型、参数的类型和个数不能改变。
下面给出一个回调函式的例子:
void CALLBACK EXPORT TimerProc(HWND hWnd,UINT nMsg,UINT nTimerid,DWORD dwTime)
{
switch(nTimerid)
{
case 1:
// 处理ID为1的定时器的事件
func1();
break;
case 2:
// 处理ID为2的定时器的事件
func2();
break;
......
default:
break;
}
}
回调函式为全局函式,需要写在使用它的位置的前面,或者写在后面然后在使用之前声明。
3、销毁定时器。
不再使用定时器时,可以销毁它。销毁定时器需使用CWnd类的KillTimer成员函式,CWnd::KillTimer函式的原型如下:
BOOL KillTimer(UINT_PTR nIDEvent);
参数nIDEvent为要销毁的定时器的ID,是调用CWnd::SetTimer函式时设定的定时器ID。如果定时器被销毁则返回TRUE,而如果没有找到指定的定时器则返回FALSE。
如果要销毁多个定时器,则多次调用KillTimer函式并分别传入要销毁的定时器的ID。

转载请注明出处海之美文 » Timer

相关推荐

    声明:此文信息来源于网络,登载此文只为提供信息参考,并不用于任何商业目的。如有侵权,请及时联系我们:ailianmeng11@163.com