mfc 中Settime使用的具体步骤

作者&投稿:诗光 (若有异议请与网页底部的电邮联系)
MFC 单个SetTimer怎么用啊~

Timer事件,即定时器事件,是在游戏编程中,经常使用的一个事件。借助它可以产生定时执行动作的效果。这篇文章,就和大家一起探讨一下如何使用SetTimer()函数。
1、SetTimer定义在那里?
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),我们有必要来看一下CWnd的继承情况:CWnd有以下子类:CFrameWnd,CDialog,CView,CControlBar等类。这也意味这些类中都可以定义SetTimer事件。
同时,SetTimer()在CWnd中也有定义,即SetTimer()是CWnd的一个成员函数。CWnd的子类可以调用该函数,来设置触发器。

UINT SetTimer( UINT nIDEvent, UINTnElapse, 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-suppliedTimerProc callback function that processes theWM_TIMER messages. If this parameter is NULL, theWM_TIMER messages are placed in the application’s message queue and handled by theCWnd object。
意思是,指定应用程序提供的TimerProc回调函数的地址,来处里这个Timer事件。如果是NULL,处理这个Timer事件的定义这个Timer的CWnd对象。他将WM_TIMER消息传递给这个对象,通过实现这个对象的OnTimer()事件来处理这个Timer事件。
所以,一般情况下,我们将这个值设为NULL,有设置该定时器的对象中的OnTimer()函数来处理这个事件。
同样的,我们再看看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。

二、Timer事件的使用:
由以上的分析,我们应该很清楚,如何来使用Timer事件。假定我们在视图上画一个渐变的动画。我们首先在菜单栏上添加一个菜单项,给这个菜单添加命令响应:
pView->SetTimer(1,1000,NULL);//pView是视图类的指针,这里是在视图类当中设置一个定时器。
添加完毕,再给视图类添加一个WM_Timer事件的相应。在OnTimer()函数中编写汉书,进行相应。
如此,就能做出动画。

SetTimer(1,1000,NULL);//1为定时器的ID 1000为他的执行毫秒 最后一个通常为NULL
VC6.0:
建立类向导-找到你当前的XXXXDlg类 找到WM_TIMER 点add那个按钮 再点Edit按钮[就是add下面的]
就会进一个代码区 别动 然后把中间的那句绿色的TODO什么的去掉 写:
if(nidevent == 1)//判断那个定时器的ID
{

a++;
}

1表示定时器的ID,1000表示没1000ms也就是1s调用一次处理函数,最后一个参数是处理的函数,如果填NULL表示,使用系统默认的,默认处理函数是OnTimer()那个函数,在这里面写你要执行的操作就可以了,如果你有多个定时器要在这里写if(id == 1)类似的东西去区分不同的定时器,更换贴图最好是在OnTimer里面更换当前显示的图片编号,然后刷新界面,更换图片的工作让OnPaint去做,让他们各司其职。关闭定时器:KillTimer(1)
启动计时器
UINT ID_TIMER1 = 1 , ID_TIMER2 = 2 //设置id
然后再你需要的时机依次启动各个计时器:
SetTimer(ID_TIMER1 , 300);
……
SetTimer(ID_TIMER2 , 400);
……
……
OnTimer函数中这样写:
void CMyClass::OnTimer(UINT nIDEvent)
{
switch(nIDEvent)
{
case ID_TIMER1:
// id为1的计时器要做的事。
……
break;
case ID_TIMER2:
//id为2的计时器要做的事。
……
break;
……
……
}
}

一 SetTimer函数的用法
1) 函数原型及变形
SetTimer这个API函数的原型 :
UINT_PTR SetTimer(
HWND hWnd, // 窗口句柄
UINT_PTR nIDEvent, // 定时器ID,多个定时器时,可以通过该ID判断是哪个定时器
UINT uElapse, // 时间间隔,单位为毫秒
TIMERPROC lpTimerFunc // 回调函数
);
注意:设置第二个参数时要注意,如果设置的等待时间比处理时间短,程序就会出问题了。
回调函数:在这个函数里,放入你想要做的事情的代码,你可以将它设定为NULL,也就是使用系统默认的回调函数,系统默认认的是onTime函数。
例如 :
SetTimer(m_hWnd,1,1000,NULL); //一个1秒触发一次的定时器
在MFC程序中SetTimer被封装在CWnd类中,调用就不用指定窗口句柄了
于是SetTimer函数的原型变为:
UINT SetTimer(UINT nIDEvent,UINT nElapse,void(CALLBACK EXPORT *lpfnTimer)(HWND,UINT ,YINT ,DWORD)) ,用法如:SetTimer(1,1000,NULL);
2)函数生成方法
在ClassWizard里,选择需要计时器的类,添加WM_TIME消息映射,就自动生成onTime函数了。然后在函数里添加代码,让代码实现功能。
每隔一段时间就会自动执行一次。
3) 回调函数的格式
void CALLBACK TimerProc(HWND hWnd,UINT nMsg,UINT nTimerid,DWORD dwTime);
二. 多个Timer
把ID的值设为〉1的数,如:SetTimer(3,500,NULL);
由WINDOWS会协调他们的然onTimer函数要在函数体内添加每一个timer的处理代码:
onTimer(nIDEvent)
{
switch(nIDEvent)
{
case 1:........;
break;
case 2:.......;
break;
case 3:......;
break;
}

三、KillTimer:取消定时器不再使用定时器后,我们应该调用KillTimer来取消定时。
KillTimer的原型:
BOOL KillTimer(HWND hWnd, // 窗口句柄
UINT_PTR uIDEvent // ID);
在MFC程序中我们可以直接调用KillTimer(int nIDEvent)来取消定时器

什么时候我们需要用到SetTimer函数呢?当你需要每个一段时间执行一件事的的时候就需要使用SetTimer函数了。 使用定时器的方法比较简单,通常告诉WINDOWS一个时间间隔,然后WINDOWS以此时间间隔周期性触发程序。通常有两种方法来实现:发送WM_TIMER消息和调用应用程序定义的回调函数。

1.1 用WM_TIMER来设置定时器
先请看SetTimer这个API函数的原型

UINT_PTR SetTimer(
HWND hWnd, // 窗口句柄
UINT_PTR nIDEvent, // 定时器ID,多个定时器时,可以通过该ID判断是哪个定时器
UINT uElapse, // 时间间隔,单位为毫秒
TIMERPROC lpTimerFunc // 回调函数
);

例如
SetTimer(m_hWnd,1,1000,NULL); //一个1秒触发一次的定时器
在MFC程序中SetTimer被封装在CWnd类中,调用就不用指定窗口句柄了

于是SetTimer函数的原型变为:
UINT SetTimer(UINT nIDEvent,UINT nElapse,void(CALLBACK EXPORT *lpfnTimer)(HWND,UINT ,YINT ,DWORD))

当使用SetTimer函数的时候,就会生成一个计时器。函数中nIDEvent指的是计时器的标识,也就是名字。nElapse指的是时间间隔,也就是每隔多长时间触发一次事件。第三个参数是一个回调函数,在这个函数里,放入你想要做的事情的代码,你可以将它设定为NULL,也就是使用系统默认的回调函数,系统默认认的是onTime函数。这个函数怎么生成的呢?你需要在需要计时器的类的生成onTime函数:在ClassWizard里,选择需要计时器的类,添加WM_TIME消息映射,就自动生成onTime函数了。然后在函数里添加代码,让代码实现功能。每隔一段时间就会自动执行一次。

例:
SetTimer(1,1000,NULL);

1:计时器的名称;

1000:时间间隔,单位是毫秒;

NULL:使用onTime函数。

当不需要计时器的时候调用KillTimer(nIDEvent);

例如:KillTimer(1);

1.2 调用回调函数

此方法首先写一个如下格式的回调函数

void CALLBACK TimerProc(HWND hWnd,UINT nMsg,UINT nTimerid,DWORD dwTime);
然后再用SetTimer(1,100,TimerProc)函数来建一个定时器,第三个参数就是回调函数地址。

二. 或许你会问,如果我要加入两个或者两个以上的 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;

}

}

你在OnTimer里,先计算,然后Invalidate了,这样做很不错,可进入Draw里,又让Draw负责椭圆的计算工作,是不是应该这样做:
1)定义个CRect m_rectEllipse;
2)在OnTimer中计算m_rectEllipse,在按键按下时也可以计算这个m_rectEllipse。
3)在Draw里只负责画椭圆,其他都不做。
4)程序还有可以改进的地方,如闪屏会出现吗?定时器分辨率较高时应该会吧!呵呵,说下去一大堆了。

P.S.把程序模块调整一下,然后立刻就能发现问题所在了,很好找。

首先在这里说一下,我使用的环境是VS2005。先说一下步骤,然后贴出代码。
步骤1:建立基于Dialog的MFC工程;
步骤2:在对话框上添加两个静态框,分别为“1秒中刷新一次”和“2秒刷新一次” 。两个编辑框,分别为“IDC_EDIT1”和"IDC_EDIT2",默认情况下就是这样的。然后在对应的对话框类中添加两个成员变量:
m_nData1 和 m_nData2
然后把编辑框的ReadOnly都改为TRUE 。
步骤3:点击OK按钮,在其中添加代码,如下:

[html] view plaincopyprint?
void CMFCTimerDlg::OnBnClickedOk()
{
// TODO: Add your control notification handler code here
SetTimer(1, 2000, NULL) ;
SetTimer(2, 1000, NULL) ;
//OnOK();
}
步骤4:对话框类添加WM_TIME消息。代码如下:


[html] view plaincopyprint?
void CMFCTimerDlg::OnTimer(UINT_PTR nIDEvent)
{
// TODO: Add your message handler code here and/or call default
switch(nIDEvent)
{
case 1:
if (5 == m_nData1)
{
KillTimer(1) ;
break ;
}
SetDlgItemInt(IDC_EDIT1, ++m_nData1) ;
case 2:
if (10 == m_nData2)
{
KillTimer(2) ;
break ;
}
SetDlgItemInt(IDC_EDIT2, ++m_nData2) ;
default:
break ;
}
CDialog::OnTimer(nIDEvent);
}

不应该只让它向右移动,而是设置一个方向指向的变量,例如可以设置成int型,0代表向上,1代表向下,2代表向左,3代表向右。在OnTimer里面进行判断,如果该变量是0,则让它向上移动,如果该变量是3才让它向右移动。然后可以添加一个键盘响应函数OnChar,在里面进行判断,如果按下了向上键,则把变量值置为0,如果按下了向下键则置为1……就是这样的。

你说的是 SetTimer吧?
UINT_PTR SetTimer(
HWND hWnd, // 窗口句柄
UINT_PTR nIDEvent, // 定时器ID,多个定时器时,可以通过该ID判断是哪个定时器
UINT nElapse, // 时间间隔,单位为毫秒
TIMERPROC lpTimerFunc // 回调函数
);
如果你在MFC中使用的话 由于已经被封装了 所以不需要制定hWnd参数了。
iIDEvent这个标志一般就是自己定义的标志,比如计算时间需要一个定时器,计算其他的东西需要定时器,也就是说需要区别不同的定时器。
nElapse就是间隔多长时间触发一次定时器。
最后一个参数就是回调函数,意思就是当定时器触发的时候需要哪个函数来处理数据,当设置为NULL的时候,就是调用ONTIME函数,你可以再MFC中重载该函数。
例如
#define UM_TIMER WM_USER+1
SetTimer(UM_TIMER,1000,NULL); //每间隔1秒触发,并且使用ONTIMER函数。
然后在
C**::OnTimer(UINT_PTR nIDEvent)
{
if(nIDEvent == UMTIMER)

{

这个地方填写你需要处理的东西。
}

}

先在一个函数里面添加:SetTimer();开始计时。然后可以通过函数
GetLocalTime(&NowTime); //获取系统时间,并传给CString类型的m_nowTime.
m_nowTime.Format(_T("%d-%d-%d::%d:%d:%d"),
NowTime.wYear,NowTime.wMonth,NowTime.wDay
,NowTime.wHour,NowTime.wMinute,NowTime.wSecond);便可以获取当前时间。

要停止计时,只需要killTimer(1)既可

函数名: settime 
功 能: 设置系统时间  
用 法: void settime(struct time *timep);  
程序例:  
#include <stdio.h>  
#include <dos.h>  
int main(void)  
{  struct time t;  
gettime(&t);  
printf("The current minute is: %d\n", t.ti_min);  
printf("The current hour is: %d\n", t.ti_hour);  
printf("The current hundredth of a second is: %d\n", t.ti_hund);  
printf("The current second is: %d\n", t.ti_sec);  
/* Add one to the minutes struct element and then call settime */  
t.ti_min++;  
settime(&t);  
return 0; 
}


轮台县13291178658: MFC里SetTimer怎么使用 -
巫若适洛: 当调用SetTimer(1,1000,NULL)就触发WM_TIMER消息,1000为每一秒调用WM_TIMER的消息处理函数,你应该在窗口类中增加一个WM_TIMER消息,然后在OnTimer()函数中写入 m_1++;UpdateData(false);你写的while循环没有意义,因为while循环是以CPU的运行速度来执行的.

轮台县13291178658: mfc中的settimer函数是做什么的里面的参数呢 -
巫若适洛: 参数1: 定时器ID,多个定时器时,可以通过该ID判断是哪个定时器 参数2 时间间隔,单位为毫秒SetTimer 参数3 回调函数 意思就是每隔一段时间(具体的间隔由参数2指定),执行一个函数(参数三指定的函数) 你这里 回调函数是NULL,那么默认执行OnTimer函数,你只要写一个窗口OnTimer函数就可以了 也就是选择WM_TIMER消息,就会生成OnTimer函数

轮台县13291178658: MFC下timer的使用 谢谢 -
巫若适洛: OnTimer()函数用于实现定时控制功能,定时控制功能主要由下面三个函数共同实现:SetTimer, KillTimer()和OnTimer().粗略的说,Settimer是设置一个计时器并开始执行计时器Ontimer中的代码,Ontimer是计时器所执行的代码....

轮台县13291178658: 请问如何使用MFC中的SetTimer、OnTimer,WM - TIMER 事件添加那些的,我用的是Microsoft Visual Studio .N
巫若适洛: 你可以在一个地方用SetTimer函数设置一个定时器,如果最后一个参数是NULL则他会发送一个WM_TIMER 消息,而在mfc里这个事件的响应函数就是OnTimer

轮台县13291178658: MFC中的CTime类该怎么用 -
巫若适洛: 在VC中,我们可以借助CTime时间类,获取系统当前日期1.获取系统当前日期 CTime t = CTime::GetCurrentTime(); //获取系统日期//创建CTime类变量t,并将调用函数GetCurrentTime()的返回值赋给变量t.2.获得当前日期和时间,并可以转化为 CString CTime tm=CTime::GetCurrentTime(); CString str=tm.Format("%Y-%m-%d");//显示年月日 或者:CTime tm=CTime::GetCurrentTime().Format("%Y-%m-%d");//显示年月日

轮台县13291178658: 问下关于MFC中 SetTimer() 和 KillTimer() 的使用 -
巫若适洛: 添加WM_MOUSEMOVE 的消息, 在函数OnMouseMove中添加代码: mouse_distance = sqrt((point.x - 200)*(point.x - 200) + (point.y - 200)*(point.y - 200)); if(mouse_distance <= 250){ /*这里的1是Timer的标识,最好设置为WM_USER+一个常...

轮台县13291178658: 在mfc中设置定时器 -
巫若适洛: 设立个全局变量count = 0,在OnTimer函数中统计调用次数 if(++count == 10) { KillTimer(hwnd,uTimerID); return 0; } KillTimer就是关闭对应的计时器

轮台县13291178658: 求大神!!如何在MFC中设置一个计时器? -
巫若适洛: 定时器,可以帮助开发者或者用户定时完成某项任务.在使用定时器时,我们可以给系统传入一个时间间隔数据,然后系统就会在每个此时间间隔后触发定时处理程序,实现周期性的自动操作.例如,我们可以在数据采集系统中,为定时器设置...

轮台县13291178658: mfc中settimer以及响应函数该怎么样声明、响应以及其它要添加修改的地方,具体点!谢谢! -
巫若适洛: 我简单的给楼主介绍下SetTimer()函数的用法:这是函数的原型:UINT SetTimer( UINT nIDEvent, UINT nElapse, void (CALLBACK EXPORT* lpfnTimer)(HWND, UINT, UINT, DWORD) ); 第一个参数 指定一个非零的定时器标识符.第二个参...

轮台县13291178658: MFC中已做出了画了一个圆并用settime让它向右移动,想问怎么用上下键盘控制它方向,效果就像贪食蛇游戏的 -
巫若适洛: 不应该只让它向右移动,而是设置一个方向指向的变量,例如可以设置成int型,0代表向上,1代表向下,2代表向左,3代表向右.在OnTimer里面进行判断,如果该变量是0,则让它向上移动,如果该变量是3才让它向右移动.然后可以添加一个键盘响应函数OnChar,在里面进行判断,如果按下了向上键,则把变量值置为0,如果按下了向下键则置为1……就是这样的.

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网