语法
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的原型如下:
1 UINT_PTR SetTimer( 2 UINT_PTR nIDEvent, 3 UINT nElapse, 4 void (CALLBACK* lpfnTimer)( 5 HWND, 6 UINT, 7 UINT_PTR, 8 DWORD 9 ) 10 );
通过SetTimer成员函数我们可以看出,处理定时事件可以有两种方式,一种是通过WM_TIMER消息的消息响应函数,一种是通过回调函数。
如果要启动多个定时器就多次调用SetTimer成员函数。另外,在不同的CWnd中可以有ID相同的定时器,并不冲突。
2、为WM_TIMER消息添加消息处理函数,或者定义回调函数。
如果调用CWnd::SetTimer函数时最后一个参数为NULL,则通过WM_TIMER的消息处理函数来处理 定时事件。添加WM_TIMER消息的处理函数的方法是,在VS2010工程的Class View类视图中找到要添加定时器的类,点击右键,选择Properties,显示其属性页,然后在属性页工具栏上点击Messages按钮,下面列表就 列出了所有消息,找到WM_TIMER消息,添加消息处理函数。添加后,cpp文件中会出现类似如下内容:
1 BEGIN_MESSAGE_MAP(CExample44Dlg, CDialogEx) 2 ...... 3 ON_WM_TIMER() 4 END_MESSAGE_MAP() 5 void CExample44Dlg::OnTimer(UINT_PTR nIDEvent) 6 { 7 // TODO: Add your message handler code here and/or call default 8 CDialogEx::OnTimer(nIDEvent); 9 }
1 void CExample44Dlg::OnTimer(UINT_PTR nIDEvent) 2 { 3 // TODO: Add your message handler code here and/or call default 4 switch (nIDEvent) 5 { 6 case 1: 7 // 如果收到ID为1的定时器的消息则调用func1函数 8 func1(); 9 break; 10 case 2: 11 // 如果收到ID为2的定时器的消息则调用func2函数 12 fun2(); 13 break; 14 ...... 15 default: 16 break; 17 } 18 CDialogEx::OnTimer(nIDEvent); 19 }
如果调用CWnd::SetTimer函数时最后一个参数不为NULL,则需要定义回调函数。回调函数的形式如下:
1 void CALLBACK EXPORT TimerProc( 2 HWND hWnd, // handle of CWnd that called SetTimer 3 UINT nMsg, // WM_TIMER 4 UINT nIDEvent // timer identification 5 DWORD dwTime // system time 6 );
这样CWnd::SetTimer函数最后一个参数就可以为TimerProc。
这里注意下,回调函数的名称不一定为TimerProc,可以取其他名字,但返回值类型、参数的类型和个数不能改变。
下面给出一个回调函数的例子:
1 void CALLBACK EXPORT TimerProc(HWND hWnd,UINT nMsg,UINT nTimerid,DWORD dwTime) 2 { 3 switch(nTimerid) 4 { 5 case 1: 6 // 处理ID为1的定时器的事件 7 func1(); 8 break; 9 case 2: 10 // 处理ID为2的定时器的事件 11 func2(); 12 break; 13 ...... 14 default: 15 break; 16 } 17 }
3、销毁定时器。
不再使用定时器时,可以销毁它。销毁定时器需使用CWnd类的KillTimer成员函数,CWnd::KillTimer函数的原型如下:
BOOL KillTimer(UINT_PTR nIDEvent);
参数nIDEvent为要销毁的定时器的ID,是调用CWnd::SetTimer函数时设置的定时器ID。如果定时器被销毁则返回TRUE,而如果没有找到指定的定时器则返回FALSE。
如果要销毁多个定时器,则多次调用KillTimer函数并分别传入要销毁的定时器的ID。