Qt——定时器QTimer

目录

一.定时事件timerEvent

二.QTimer对象


QTimer是qt中的单次和重复定时器。

其主要有两种定时方式,一种是定时事件,一种是通过信号与槽。

一.定时事件timerEvent

在需要定时器的类中使用startTimer(x)进行定时设置和启动。

int id = startTimer(x);

其中,x是定时事件,单位是毫秒ms,startTimer会自动启动该定时器。

返回值是该定时器独一无二的id。

同时需要使用定时事件timerEvent完成具体的定时任务。

void timerEvent(QTimerEvent* ev){
    if(ev->timerId() == id){//判断是否是定时器id
        //该定时器具体的定时事件
    }

    if(ev->timerId() == id2){//判断是否是定时器id2
        //该定时器2具体的定时事件
    }

    ...
}

 比如我们希望每隔1秒打印一次hello:

Widget::Widget(QWidget *parent)//构造函数
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    id1 = startTimer(1000);//id1已经设置为成员变量
}

void Widget::timerEvent(QTimerEvent* ev){//定时事件
    if(ev->timerId() == id1){
        qDebug() << "hello";
    }
}

 

二.QTimer对象

大多数情况下我们通过使用信号与槽connect的形式完成定时任务。

首先创建一个QTimer类对象,调用start函数完成定时和启动。

之后将QTimer对象的timeout信号与自定义的任务槽函数connect即可。

同样以每隔1秒打印一次hello为例。

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    QTimer* t = new QTimer(this);//加入对象树
    t->start(1000);
    //以lambda表达式的形式设置槽函数
    connect(t, &QTimer::timeout, [=]{
        qDebug() << "hello";
    });
}

值得注意的是,即便是构造函数内部的控件,如果是在lambda表达式中定义的,那么也需要使用show函数才能展示出来。尤其是使用QTimer对象时,因为经常使用lambda表达式,需要格外注意这种情况。

 如果需要停止定时器,使用stop函数即可。

t->stop();

 


如有错误,敬请斧正 

  • 26
    点赞
  • 83
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

就要 宅在家

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值