Qt繪制簡單時鐘
本文實例為大家分享了Qt繪制簡單時鐘的具體代碼,供大家參考,具體內(nèi)容如下
概述
(1)基本原理
利用簡單的幾何圖形繪出表盤和指針,然后基于系統(tǒng)時間調(diào)整指針偏轉(zhuǎn)角度達到模擬時鐘的效果。
其中可以加上自己喜歡的背景資源,設(shè)計不同風(fēng)格的時鐘。
(2)部分函數(shù)說明
①調(diào)色和填充
painter.setBrush(Qt::red); //設(shè)置畫刷,填充顏色(紅色) painter.setPen(Qt::red); //設(shè)置畫筆,外圍輪廓顏色(紅色)
②抗鋸齒(減少圖形外圍鋸齒狀,使線條平滑)
painter.setRenderHint(QPainter::Antialiasing,true);
③自動保存與恢復(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ù)(第一個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); //確定刷新時間(此處為1000毫秒=1秒)
connect(timer,SIGNAL(timeout()),this,SLOT(update())); //update()為自動刷新界面,使指針可以不停轉(zhuǎn)動
}
繪圖函數(shù)(注意:只要時、分、秒三個指針任意完成一個,則其余兩個只需修改指針旋轉(zhuǎn)角度規(guī)則,其余屬性相同即可)
void Dialog::paintEvent(QPaintEvent *){
QPainter painter(this);
//時鐘背景
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)時間
//表盤
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();
//時針(同秒針)
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();
//表盤刻度
//長刻度(整點刻度)
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、效果圖

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
CreateCompatibleDC()函數(shù)案例詳解
這篇文章主要介紹了CreateCompatibleDC()函數(shù)案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08
Qt?加載?libjpeg?庫出現(xiàn)“長跳轉(zhuǎn)已經(jīng)運行”錯誤問題解決
這篇文章主要介紹了Qt?加載?libjpeg?庫出現(xiàn)“長跳轉(zhuǎn)已經(jīng)運行”錯誤,本文給大家分享完美解決方案,需要的朋友可以參考下2023-04-04

