Qt定時器的應用,實現時鐘的狀態

Qt有兩種定時器,一種是QObject類,另一種是QTimer類。

(1)QObject類提供了一個基本的定時器,通過函數startTimer()來啓動,通過killTimer()來結束,通過QTimerEvent來處理定時器事件

startTimer(int interval)啓動一個時間間隔爲interval毫秒的定時器,返回一個定時器標識符,如果未能啓動成功,則返回0。

該定時器只能使用killTime()來殺死,killTimer(int id)通過定時器標識符來殺死定時器。如果有多個定時器,可以通過QTimerEvent::timerId()來獲取已經啓動的定時器標識符。

(2)QTimer類定時器是QObject類定時器的擴展,它可以提供更多的功能。比如,它支持單次觸發和多次觸發。

使用QTimer類定時器的步驟:

(1)創建一個QTimer定時器實例:QTimer *timer = new QTimer(this);
(2)連接超時信號與槽:connect(timer, SIGNAL(timeout()), this, SLOT(testFunc()));
(3)啓動定時器start();
(4)適時關閉定時器:stop();
(5)刪除定時器實例:delete timer;
公共函數:

int               interval() const                                            獲得定時器時間間隔

bool              isActive() const                                         獲得定時器激活狀態

bool              isSingleShot() const                                 獲得單次觸發使能狀態

int               remainingTime() const                              獲得距離觸發定時器事件的剩餘時間

void              setInterval(int msec)                                設置定時器時間間隔

void              setSingleShot(bool singleShot)              設置使能/禁用單次觸發

void              setTimerType(Qt::TimerType atype)        設置定時器類型

int               timerId() const                                           獲得定時器標識符

Qt::TimerType     timerType() const                             獲得定時器類型


公共槽函數:

void     start(int msec)                             啓動定時時間間隔爲msec毫秒的定時器
void     start()                                           啓動定時器
void     stop()                                           暫停定時器


信號:
void     timeout()                                    超時

以上部分轉載與:http://blog.csdn.net/jan5_reyn/article/details/38955719(以此爲基礎略作修改)

定時器事件和普通鼠標、鍵盤事件一樣進入事件循環處理。因此,定時器的處理函數需要儘快完成,不然也會把界面卡死。

定時器不是精確的,因爲它的處理函數也是放在事件循環中執行的;

頭文件:

mainwindow.h

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>
#include <QTimerEvent>
#include <QTime>

namespace Ui {
class MainWindow;
}

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    explicit MainWindow(QWidget *parent = 0);
    ~MainWindow();

private:
    Ui::MainWindow *ui;
    void timerEvent(QTimerEvent *event);
private:
    int m_timerId;
};

#endif // MAINWINDOW_H
源文件:

main.cpp

#include "mainwindow.h"
#include <QApplication>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    MainWindow w;
    w.show();

    return a.exec();
}
mainwindow.cpp

#include "mainwindow.h"
#include "ui_mainwindow.h"


MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    m_timerId = startTimer(1000);
}

MainWindow::~MainWindow()
{
    delete ui;
}
//定時器處理函數
void MainWindow::timerEvent(QTimerEvent *event)
{
     //可以有多個定時器,每個定時器有不同的處理
    if(event->timerId() == m_timerId)
    {
        QTime now = QTime::currentTime();
        QString text = now.toString("HH:mm:ss");//按照24小時制的格式進行字符串格式化;
        ui->timeLineEdit->setText(text);
    }
}

時間格式化說明:

hh:mm:ss  
按照12小時制的格式進行字符串格式化
如果時間處於00:00:00——12:59:59,則返回的字符串正常
如果時間處於13:00:00——23:59:59,則返回的字符串是實際時間-12小時後的值,也就是說比真實的時間少了12個小時。
例如:14:00:00進行格式化後的字符串爲“2:00:00”

HH:mm:ss
按照24小時制的格式進行字符串格式化
當時間爲任意一個區間,則返回的字符串都是正常的。

設計界面:



發佈了75 篇原創文章 · 獲贊 32 · 訪問量 7萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章