• QT Object定时器使用


    #ifndef WIDGET_H
    #define WIDGET_H
    
    #include 
    
    QT_BEGIN_NAMESPACE
    namespace Ui { class Widget; }
    QT_END_NAMESPACE
    
    class Widget : public QWidget
    {
        Q_OBJECT
    
    public:
        Widget(QWidget *parent = nullptr);
    
        // 需要对timerEvent函数进行重写
        virtual void timerEvent(QTimerEvent* event);
    
        ~Widget();
    
    private slots:
        void on_startTimer_clicked();
    
    
    
        void on_killTimer_clicked();
    
    private:
        Ui::Widget *ui;
        int eventId; // 定时器返回的唯一id,用于区分不同定时器
        int pictureId=1; // 不同图片的编号
    };
    #endif // WIDGET_H
    
    #include "widget.h"
    #include "ui_widget.h"
    
    #define TIME_OUT 1 * 1000
    
    /**
    QObject中有定时器,可以直接进行使用startTimer和killTimer操作
    但需要对timerEvent进行重新定义,以自己的方式处理定时器
    */
    Widget::Widget(QWidget *parent)
        : QWidget(parent)
        , ui(new Ui::Widget)
    {
        ui->setupUi(this);
        QString path("D:\\workspace\\qt\\Timer\\");
        path += QString::number(this->pictureId)+".jpg";
    
        QPixmap pix(path);
        ui->label->setPixmap(pix);
    }
    
    Widget::~Widget()
    {
        delete ui;
    }
    
    
    void Widget::on_startTimer_clicked()
    {
        // 开启定时器
        // QObject中有定时器,直接使用,Widget->QWidget->QObject
        this->eventId = this->startTimer(TIME_OUT);
    
    }
    
    
    void Widget::timerEvent(QTimerEvent* event) {
    
        // 获取timerId是否为开启定时器所操作的
        if (event->timerId() == this->eventId) {
            QString path("D:\\workspace\\qt\\Timer\\");
            path += QString::number(this->pictureId)+".jpg";
    
            QPixmap pix(path);
            ui->label->setPixmap(pix);
    		this->pictureId++;
    
            if (this->pictureId == 5) {
                this->pictureId = 1;
            }
        }
    }
    
    void Widget::on_killTimer_clicked()
    {
        this->killTimer(this->eventId);
    }
    
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86
    • 87
    • 88
    • 89
    • 90
    • 91
    • 92
    • 93
    • 94
  • 相关阅读:
    Clonable 接口 深拷贝与浅拷贝(超详细!!!代码附注释带图)
    MySQL学习之——多表查询
    网络安全笔记-Web服务器
    L57.linux命令每日一练 -- 第九章 Linux进程管理命令 -- ps和pstree
    计算机网络分层结构
    分段管理存储
    git从入门到跑路
    Leetcode46. Permutations | 模拟 | 递归 | 记忆化搜索
    学习与尝试 --> 事件风暴
    数据库PostgreSQL PG 字符串拼接,大小写转换,substring
  • 原文地址:https://blog.csdn.net/CodeHouse/article/details/132749506