Qt繪制簡(jiǎn)單時(shí)鐘
本文實(shí)例為大家分享了Qt繪制簡(jiǎn)單時(shí)鐘的具體代碼,供大家參考,具體內(nèi)容如下
概述
(1)基本原理
利用簡(jiǎn)單的幾何圖形繪出表盤和指針,然后基于系統(tǒng)時(shí)間調(diào)整指針偏轉(zhuǎn)角度達(dá)到模擬時(shí)鐘的效果。
其中可以加上自己喜歡的背景資源,設(shè)計(jì)不同風(fēng)格的時(shí)鐘。
(2)部分函數(shù)說(shuō)明
①調(diào)色和填充
painter.setBrush(Qt::red); //設(shè)置畫刷,填充顏色(紅色) painter.setPen(Qt::red); //設(shè)置畫筆,外圍輪廓顏色(紅色)
②抗鋸齒(減少圖形外圍鋸齒狀,使線條平滑)
painter.setRenderHint(QPainter::Antialiasing,true);
③自動(dòng)保存與恢復(fù)
painter.save(); //保存屬性 painter.restore(); //屬性恢復(fù)
核心代碼
dialog.h文件
class Dialog : public QDialog
{
Q_OBJECT
public:
Dialog(QWidget *parent = nullptr);
~Dialog();
void Dialog::paintEvent(QPaintEvent *); //函數(shù)聲明
private:
Ui::Dialog *ui;
};
頭文件
#include <QPainter> #include <QPoint> #include <QTime> #include <QTimer> #include <QPixmap> #include <math.h>
指針參數(shù)(第一個(gè)QPoint前可以加static)
QPoint sec[4]={QPoint(0,-80),QPoint(2,0),QPoint(0,8),QPoint(-2,0)};
QPoint min[4]={QPoint(0,-62),QPoint(4,0),QPoint(0,10),QPoint(-4,0)};
QPoint hour[4]={QPoint(0,-48),QPoint(5,0),QPoint(0,11),QPoint(-5,0)};
關(guān)聯(lián)函數(shù)
Dialog::Dialog(QWidget *parent)
: QDialog(parent)
, ui(new Ui::Dialog)
{
ui->setupUi(this);
resize(300,300);
QTimer * timer = new QTimer(this);
timer->start(1000); //確定刷新時(shí)間(此處為1000毫秒=1秒)
connect(timer,SIGNAL(timeout()),this,SLOT(update())); //update()為自動(dòng)刷新界面,使指針可以不停轉(zhuǎn)動(dòng)
}
繪圖函數(shù)(注意:只要時(shí)、分、秒三個(gè)指針任意完成一個(gè),則其余兩個(gè)只需修改指針旋轉(zhuǎn)角度規(guī)則,其余屬性相同即可)
void Dialog::paintEvent(QPaintEvent *){
QPainter painter(this);
//時(shí)鐘背景
QRect q1(20,20,0.5*512,0.5*512);
QRect q2(0,0,512,512);
QPixmap map(":/b/ClockBack/clockback.png");
painter.drawPixmap(q1,map,q2);
QTime time=QTime::currentTime(); //調(diào)用系統(tǒng)時(shí)間
//表盤
painter.setRenderHint(QPainter::Antialiasing,true); //抗鋸齒,平滑化
painter.setPen(QPen(Qt::white,6,Qt::SolidLine)); //調(diào)色
painter.translate(50,50);
painter.drawEllipse(0,0,198,198);
//指針屬性
painter.translate(99,99);
//秒針
painter.setRenderHint(QPainter::Antialiasing,true);
painter.setBrush(Qt::red); //設(shè)置畫刷,填充顏色
painter.setPen(Qt::red); //設(shè)置畫筆,外圍輪廓顏色
painter.save(); //保存屬性
painter.rotate(6.0*time.second());
painter.drawPolygon(sec,4); //繪制指針(繪制幾何圖形函數(shù))
painter.restore(); //屬性恢復(fù)
//分針(同秒針)
painter.setRenderHint(QPainter::Antialiasing,true);
painter.setBrush(Qt::white);
painter.setPen(Qt::white);
painter.save();
painter.rotate(6.0*time.minute()+time.second()/60.0);
painter.drawPolygon(min,4);
painter.restore();
//時(shí)針(同秒針)
painter.setRenderHint(QPainter::Antialiasing,true);
painter.setBrush(Qt::black);
painter.setPen(Qt::black);
painter.save();
painter.rotate(30.0*time.hour()+time.minute()/60.0);
painter.drawPolygon(hour,4);
painter.restore();
//表盤刻度
//長(zhǎng)刻度(整點(diǎn)刻度)
for(int i=1;i<=12;i++){
painter.rotate(30);
painter.drawLine(0,-100,0,-85);
}
//短刻度
for(int i=1;i<=60;i++){
painter.rotate(6);
painter.drawLine(0,-94,0,-90);
}
}
背景與效果圖
1、這里分享我自己采用的背景

2、效果圖

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- PyQt5使用QTimer實(shí)現(xiàn)電子時(shí)鐘
- Python+Pyqt實(shí)現(xiàn)簡(jiǎn)單GUI電子時(shí)鐘
- python+PyQT實(shí)現(xiàn)系統(tǒng)桌面時(shí)鐘
- QTimer與QTime實(shí)現(xiàn)電子時(shí)鐘
- Qt編程實(shí)現(xiàn)小時(shí)鐘
- Qt實(shí)現(xiàn)簡(jiǎn)易時(shí)鐘
- Qt實(shí)現(xiàn)指針式時(shí)鐘 Qt實(shí)現(xiàn)動(dòng)態(tài)時(shí)鐘
- Qt設(shè)計(jì)時(shí)鐘效果
- QT實(shí)現(xiàn)動(dòng)態(tài)時(shí)鐘
- QT5實(shí)現(xiàn)電子時(shí)鐘
相關(guān)文章
C++實(shí)現(xiàn)高并發(fā)異步定時(shí)器
這篇文章主要為大家詳細(xì)介紹了如何利用C++實(shí)現(xiàn)高并發(fā)異步定時(shí)器,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-11-11
Opencv?視頻讀取與寫入的實(shí)現(xiàn)示例
本文將介紹如何使用OpenCV進(jìn)行視頻讀寫。通過(guò)閱讀本文,您將了解如何讀取視頻文件、處理視頻幀、寫入視頻文件等操作,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-08-08
C語(yǔ)言動(dòng)態(tài)內(nèi)存函數(shù)詳解
這篇文章主要介紹了C語(yǔ)言動(dòng)態(tài)內(nèi)存函數(shù),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-09-09
基于C++實(shí)現(xiàn)酒店管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了基于C++實(shí)現(xiàn)酒店管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
CreateCompatibleDC()函數(shù)案例詳解
這篇文章主要介紹了CreateCompatibleDC()函數(shù)案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08
Qt?加載?libjpeg?庫(kù)出現(xiàn)“長(zhǎng)跳轉(zhuǎn)已經(jīng)運(yùn)行”錯(cuò)誤問(wèn)題解決
這篇文章主要介紹了Qt?加載?libjpeg?庫(kù)出現(xiàn)“長(zhǎng)跳轉(zhuǎn)已經(jīng)運(yùn)行”錯(cuò)誤,本文給大家分享完美解決方案,需要的朋友可以參考下2023-04-04

