QPaint绘制自定义仪表盘组件02刻度线

网上视频抄的,用来自己看一下,看完就删掉

ui,创建一个空的widget

widget.h

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QPainter>
#include <QPaintEvent>

QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACE

class Widget : public QWidget
{
    Q_OBJECT

public:
    Widget(QWidget *parent = nullptr);
    ~Widget();

protected:
    void paintEvent(QPaintEvent *event) override;

private:
    Ui::Widget *ui;
};
#endif // WIDGET_H

widget.cpp 

#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
}

Widget::~Widget()
{
    delete ui;
}

void Widget::paintEvent(QPaintEvent *event)
{
    (void)event;
    QPainter painter(this);
    painter.setRenderHint(QPainter::Antialiasing, true);

    // painter永远以自我为原点,处于(0,0)点
    // 将painter移动到(100, 100)位置
    // painter.translate(100, 100);
    // 继续以painter为原点移动(100, 100),此时画家的绝对位置为(200, 200)
    // painter.translate(100, 100);
    // 将painter移动到当前widget的中心位置
    painter.translate(rect().center());
    // 丢掉画笔
    painter.setPen(Qt::NoPen);
    // 设置画刷
    painter.setBrush(Qt::cyan);
    // 画刷会刷满这个封区域的颜色
    painter.drawPie(-230, -230, 460, 460, 0, 180 * 16);
    // 重新设置画笔
    painter.setPen(QPen(Qt::red, 5));
    painter.drawPoint(0, 0);
    // 设置单次旋转角度
    double single = 180 * 1.0 / 20;
    // 旋转20次
    for (int i = 0; i <= 20; ++i) {
        if (i % 5 == 0) {
            // 长刻度线
            painter.drawLine(200, 0, 230, 0);
        } else {
            // 短刻度线
            painter.drawLine(210, 0, 230, 0);
        }
        // 每次逆时针旋转single度
        painter.rotate(-single);
    }


}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值