QT开发之QTimer定时器

本文详细介绍了Qt中定时器的两种使用方式:一种是通过反复触发实现周期性操作,另一种是单次触发用于延迟执行任务。提供了具体的代码示例帮助理解。

1、多次使用,最简单实例

头文件:<QTimer>

.h

private slots:

void fun();


****.cpp

//放置构造函数或者其他

QTimer *timer = new QTimer(this);
connect(timer,SIGNAL(timeout()),this,SLOT(fun()));//注意第一个为timer
timer->start(1000);


void ****::fun()

{

//添加操作,每秒钟相应一次

}


2、单次使用

QTimer::singleShot(200,this,SLOT(fun()));//200毫秒后启动功能函数


QTimerQt 提供的强大定时器类,适用于各种定时操作场景,可实现周期性任务、延时操作和动画等功能。以下是 QTimer 的使用方法介绍: ### 常用 API - `setInterval(int msec)`:设置定时器的时间间隔,单位为毫秒。 - `setSingleShot(bool singleShot)`:设置定时器是否只触发一次,默认为 `false`,即周期性触发。 - `start()`:开启定时器。 - `stop()`:停止定时器。 - `timeout()`:定时器超时信号,当定时器超时时会发出该信号。 - `singleShot(int msec, const QObject *receiver, const char *member)`:静态方法,用于只触发一次的定时器 [^3]。 ### 示例代码 以下是一个使用 QTimer 每秒生成一次随机数并显示在 `LCDNumber` 控件上的实例代码: ```cpp #include <QApplication> #include <QLCDNumber> #include <QTimer> #include <QVBoxLayout> #include <QWidget> #include <cstdlib> #include <ctime> int main(int argc, char *argv[]) { QApplication app(argc, argv); // 创建主窗口和布局 QWidget window; QVBoxLayout *layout = new QVBoxLayout(&window); // 创建 LCDNumber 控件 QLCDNumber *lcdNumber = new QLCDNumber(&window); layout->addWidget(lcdNumber); // 创建 QTimer 对象 QTimer *timer = new QTimer(&window); // 连接定时器的 timeout 信号到自定义槽函数 QObject::connect(timer, &QTimer::timeout, [lcdNumber]() { // 生成随机数 static bool initialized = false; if (!initialized) { std::srand(std::time(nullptr)); initialized = true; } int randomNumber = std::rand() % 100; // 生成 0 到 99 之间的随机数 // 在 LCDNumber 上显示随机数 lcdNumber->display(randomNumber); }); // 设置定时器的时间间隔为 1000 毫秒(即 1 秒) timer->setInterval(1000); // 启动定时器 timer->start(); // 显示主窗口 window.show(); return app.exec(); } ``` ### 注意事项 在使用 QTimer 时,应该避免在定时器的槽函数中执行耗时操作,因为这可能会阻塞 Qt 的事件循环,影响界面响应和其他定时器的准确性 [^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值