-
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();
}