QObject的Timer

  • int QObject::startTimer(int interval, Qt::TimerType timerType = Qt::CoarseTimer)
    开启一个时钟,周期是interval,开启成功返回时钟ID,开启失败返回0

  • void QObject::killTimer(int id)
    关闭一个时钟

  • protected: virtual void QObject::timerEvent(QTimerEvent *event) ;
    此事件处理程序可以在子类中重新实现,以接收对象的计时器事件,不是slot

示例
# q_object_timer.pro

QT -= gui

CONFIG += c++11 console
CONFIG -= app_bundle

# The following define makes your compiler emit warnings if you use
# any Qt feature that has been marked deprecated (the exact warnings
# depend on your compiler). Please consult the documentation of the
# deprecated API in order to know how to port your code away from it.
DEFINES += QT_DEPRECATED_WARNINGS

# You can also make your code fail to compile if it uses deprecated APIs.
# In order to do so, uncomment the following line.
# You can also select to disable deprecated APIs only up to a certain version of Qt.
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000    # disables all the APIs deprecated before Qt 6.0.0

SOURCES += \
        main.cc

# Default rules for deployment.
qnx: target.path = /tmp/$${TARGET}/bin
else: unix:!android: target.path = /opt/$${TARGET}/bin
!isEmpty(target.path): INSTALLS += target

// main.cc

#include <QCoreApplication>
#include <QDebug>

class TimerTest : public QObject {
public:
  TimerTest(QObject *parent = nullptr) : QObject(parent), q_timer_id(0) {

    q_timer_id = startTimer(300);
  }
  virtual ~TimerTest() {}

protected:
  void timerEvent(QTimerEvent *event) override {

    if (event->timerId() == q_timer_id) {
      qDebug() << "q_timer_id{" << q_timer_id << "}";
    }
  }

private:
  int q_timer_id;
};

int main(int argc, char *argv[]) {
  QCoreApplication a(argc, argv);
  TimerTest t;
  return a.exec();
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

tadus_zeng

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

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

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

打赏作者

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

抵扣说明:

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

余额充值