详解QTimer与QTime如何实现电子时钟
小编这次要给大家分享的是详解QTimer与QTime如何实现电子时钟,文章内容丰富,感兴趣的小伙伴可以来了解一下,希望大家阅读完这篇文章之后能够有所收获。
使用QLCDNumber控件进行显示
QLCDNumber控件默认只显示5个字符,可以使用setDigitCount(int size)进行设置显示个数
使用Display(QString str) 设置显示内容
该函数拥有多个重载,字符 整型 浮点型都可以作为参数
效果图:
代码:头文件
#include <QLCDNumber> class NumClock : public QLCDNumber{ Q_OBJECTpublic: explicit NumClock(QWidget *parent = nullptr); void mousePressEvent(QMouseEvent *event); void mouseMoveEvent(QMouseEvent *event); signals: public slots: void updateTime(); private: QTimer * timer; QPoint mouseOfPonit; // 鼠标坐标跟窗口左上角坐标的偏移值 bool showColon; //是否显示:};
cpp文件:
#include "numclock.h"#include <QTimer>#include <QTime>#include <QMouseEvent>#include <QDebug> NumClock::NumClock(QWidget *parent) : QLCDNumber(parent){ timer = new QTimer(this); timer->setTimerType(Qt::PreciseTimer); // 设置精度为较高精度,差距在毫秒内 timer->start(1000); connect(timer, SIGNAL(timeout()), this, SLOT(updateTime()),Qt::QueuedConnection); setWindowFlag(Qt::FramelessWindowHint); //没有面板边框标题栏的窗体 setWindowOpacity(0.5); //设置窗口的透明度 showColon = true; this->setDigitCount(8); resize(150, 100); updateTime(); setAttribute(Qt::WA_DeleteOnClose);} void NumClock::mousePressEvent(QMouseEvent *event){ if(event->button() == Qt::LeftButton){ mouseOfPonit = event->globalPos() - this->pos(); event->accept(); }else{ close(); }} void NumClock::mouseMoveEvent(QMouseEvent *event){ if(event->buttons() & Qt::LeftButton){ move(event->globalPos() - mouseOfPonit); event->accept(); }} void NumClock::updateTime(){ QString timeStr = QTime::currentTime().toString("hh:mm:ss"); if(showColon){ timeStr = timeStr.replace(QString(":"), QString(" ")); qDebug() << timeStr; showColon = false; }else{ timeStr = timeStr.replace(QString(" "), QString(":")); showColon = true; qDebug() << timeStr; } display(timeStr);}
看完这篇关于详解QTimer与QTime如何实现电子时钟的文章,如果觉得文章内容写得不错的话,可以把它分享出去给更多人看到。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。