QT : 完成绘制时钟

1.头文件

cpp 复制代码
#ifndef WIDGET_H
#define WIDGET_H
 
#include <QWidget>
#include <QPainter>
#include <QTimer>
#include <QTime>
#include <QPaintEvent>
#include <QDebug>
#include <QBrush>
 
QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACE
 
class Widget : public QWidget
{
    Q_OBJECT
 
public:
    Widget(QWidget *parent = nullptr);
    ~Widget();
 
    //重写绘制事件事件处理函数
    void paintEvent(QPaintEvent *event) override;
private slots:
    void updateTime();
 
private:
    Ui::Widget *ui;
    QTimer *timer;
    QPixmap dial;
};
#endif // WIDGET_H

2.源文件

cpp 复制代码
#include "widget.h"
#include "ui_widget.h"
 
Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    this->setFixedSize(600,600);
    QTimer *timer = new QTimer(this);
    connect(timer,&QTimer::timeout,this,&Widget::updateTime);
    timer->start(1000);
    this->setStyleSheet("background-color:white;");
}
 
Widget::~Widget()
{
    delete ui;
}
 
void Widget::paintEvent(QPaintEvent *event)
{
    Q_UNUSED(event);
    //实例化一个画家
    QPainter painter(this);
    //设置绘图器(QPainter)的渲染提示,开启抗锯齿效果
    painter.setRenderHint(QPainter::Antialiasing);
    //获取当前时间
    QTime currentTime = QTime::currentTime();
 
    int X=this->width()/2;
    int Y=this->height()/2;
    int radius=200;
    //绘制表盘
    painter.setPen(QPen(Qt::black,7));     //设置笔
    if(dial.isNull())
    {
        dial.load("E:\\clock.png");
    }
    if(!dial.isNull())
    {
            painter.drawPixmap(X-radius,Y-radius,radius*2,radius*2,dial);
    }
    //绘制时针
    painter.save();    // 保存当前的绘制状态
    painter.translate(X,Y);    // 将绘制的坐标原点移动到表盘的中心
    int hour = currentTime.hour();    // 获取当前的小时
    int minute = currentTime.minute();     // 获取当前的分钟
    double hourAngle = (hour%12 + minute/60.0)*30.0;  // 计算时针的角度,考虑分钟对时针的影响
    painter.rotate(-90);    // 将坐标系旋转,使12点位置对应0度
    painter.rotate(hourAngle);    // 旋转坐标系,使时针指向正确的位置
    painter.setPen(QPen(Qt::black,5));    //设置笔
    painter.drawLine(0,0,0,-radius*0.5);  // 绘制时针,起点是坐标原点 (0, 0),终点是时针的末端位置
    painter.restore();       // 恢复之前保存的绘制状态,以便后续绘制
 
  
    //绘制分针
    painter.save();
    painter.translate(X,Y);
    double minuteAngle = minute*6.0;
    painter.rotate(-90);
    painter.rotate(minuteAngle);
    painter.setPen(QPen(Qt::red,3));        //设置笔
    painter.drawLine(0,0,0,-radius*0.7);
    painter.restore();
 
    //绘制秒针
    painter.save();
    painter.translate(X,Y);
    int second = currentTime.second();
    double secondAngle = second * 6.0;
    painter.rotate(-90);
    painter.rotate(secondAngle);
    painter.setPen(QPen(Qt::blue,2));      //设置笔
    painter.drawLine(0,0,0,-radius*0.9);
    painter.restore();
 
}
 
void Widget::updateTime()
{
    update();
}
相关推荐
blammmp17 分钟前
Java:数据结构-枚举
java·开发语言·数据结构
何曾参静谧30 分钟前
「C/C++」C/C++ 指针篇 之 指针运算
c语言·开发语言·c++
暗黑起源喵35 分钟前
设计模式-工厂设计模式
java·开发语言·设计模式
WaaTong40 分钟前
Java反射
java·开发语言·反射
Troc_wangpeng41 分钟前
R language 关于二维平面直角坐标系的制作
开发语言·机器学习
努力的家伙是不讨厌的43 分钟前
解析json导出csv或者直接入库
开发语言·python·json
Envyᥫᩣ1 小时前
C#语言:从入门到精通
开发语言·c#
童先生1 小时前
Go 项目中实现类似 Java Shiro 的权限控制中间件?
开发语言·go
lulu_gh_yu1 小时前
数据结构之排序补充
c语言·开发语言·数据结构·c++·学习·算法·排序算法
huanggang9821 小时前
在Ubuntu22.04上使用Qt Creator开发ROS2项目
qt·ros2