MFC定时器

在程序中我们经常要使用定时刷新的功能,典型的应用是在信息管理系统中表单要跟着数据库中的数据变动。MFC提供了定时器来完成这个功能。

=========================================================================

在MFC中和定时器相关的有三个函数:

UINT SetTimer( UINT nIDEvent, UINT nElapse, void (CALLBACK EXPORT* lpfnTimer)( HWND, UINT, UINT, DWORD) );
afx_msg void OnTimer( UINT nIDEvent );
BOOL KillTimer( int nIDEvent );

 

=========================================================================

参数说明:
UINT nIDEvent:定时器的ID,给定时器唯一的身份验证,如果在一个程序中有多个定时器可以用这个ID来确定是那个定时器发送的消息。
UINT nElapse: 定义刷新时间,即间隔多长时间刷新一次,单位是毫秒。
void (CALLBACK EXPORT* lpfnTimer)( HWND, UINT, UINT, DWORD):
              这个回调函数中实现刷新时所做的操作,如在数据库中读取数据。但是我们大多数时候不在这里实现,而是在OnTimer中。

=========================================================================


函数功能:
SetTimer用来定义一个定时器的属性,如改定时器的ID,刷新时间,处理函数。
OnTimer实际时系统定义消息用来响应WM_TIMER消息,在这里可以实现对多定时器中的各个定时器分别响应,这里才时定时程序大展宏图的地方。
KillTimer用来结束一个定时器。

下面我们用一个例子来说明定时器的使用:
   这个例子用来实现一个简单的功能,就是在一个单文档程序中,每间隔5秒弹出一个消息框提示“定时器1”,每隔7秒弹出一个消息框提示“定时器2”。
   建立单文档程序略,一路Next。

=========================================================================

(1)在resource.h中定义两个定时器的ID

#define IDTIMER1  1
#define IDTIMER2  2

 


(2)在CMainFrame的OnCreate函数中定义两个定时器的属性。

SetTimer(TIMEID1,5000,0);
SetTimer(TIMEID2,7000,0);

 

(3) CMainFrame中对WM_TIMER进行响应。

复制代码
oid CMainFrame::OnTimer(UINT nIDEvent)
{
    // TODO: Add your message handler code here and/or call default
    switch(nIDEvent) {
    case TIMEID1:
        {   
            AfxMessageBox("定时器1!");
            break;
        }
case TIMEID2:
        {   
            AfxMessageBox("定时器2!");
            break;
        }
    default:
        ;
    }
   
    CFrameWnd::OnTimer(nIDEvent);
}
复制代码

 

(4)在CMainFrame的析构函数中添加

KillTimer(IDTIMER1);
KillTimer(IDTIMER2);

==============================

参考2

 

当执行到程序的某一行代码时,需要添加计时器,就用这条语句:

SetTimer(1, 1000, NULL);

参数如下:

UINT_PTR SetTimer(UINT_PTR nIDEvent, UINT nElapse,
  void (CALLBACK* lpfnTimer)(HWND, UINT, UINT_PTR, DWORD));

设置好后计时器立马生效,1秒后计时器发生中断,在代码所在的类中进行捕捉:

1.在该类的消息中添加:

BEGIN_MESSAGE_MAP(CTab1, CDialog)  // CTab1是自己定义的一个类
    ...
    ON_WM_TIMER()
    ...
END_MESSAGE_MAP()

 

2.所在的类中添加成员函数:

void OnTimer(UINT_PTR nIDEvent);

 

 

3.添加函数的代码,即捕捉后的执行代码:

复制代码
void CTab1::OnTimer(UINT_PTR nIDEvent)
{
    switch (nIDEvent)
    {
    case 1:  // 计时器1
               .... // 处理的代码
               KillTimer(1);  // 删除此计时器,否则计时器中断完后会自动重新开始计时,到下一次中断时还会发生新的中断
               break;

    case 2:  // 计时器2
               .... // 处理的代码
               break;
    default:
               MessageBox("default: KillTimer");
               KillTimer(nIDEvent);
               break;
    }
}
复制代码
posted @   在于思考  阅读(11273)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 内存占用高分析
· .NET Core GC计划阶段(plan_phase)底层原理浅谈
· .NET开发智能桌面机器人:用.NET IoT库编写驱动控制两个屏幕
· 用纯.NET开发并制作一个智能桌面机器人:从.NET IoT入门开始
· 一个超经典 WinForm,WPF 卡死问题的终极反思
阅读排行:
· 20250116 支付宝出现重大事故 有感
· 一个基于 Roslyn 和 AvalonEdit 的跨平台 C# 编辑器
· 2025 最佳免费商用文本转语音模型: Kokoro TTS
· 海康工业相机的应用部署不是简简单单!?
· 在 .NET Core中如何使用 Redis 创建分布式锁
点击右上角即可分享
微信分享提示