用QPainterPath实现类似PPT中的3D效果

用QPainterPath实现类似PPT中的3D效果

实现类似PPT中的3D效果

之前做过一个项目实现类似PPT中的图形的3D效果,尝试使用QPainterPath实现的。写个文章记录一下

实现效果如下:

在这里插入图片描述
头文件如下:

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>

QT_BEGIN_NAMESPACE
namespace Ui {
   
    class MainWindow; }
QT_END_NAMESPACE
#include "QGraphicsWidget"

class MyRectItem : public QGraphicsWidget
{
   
   
    Q_OBJECT
public:
    MyRectItem(QGraphicsItem *parent = nullptr);
    void setPath(QList<QPainterPath> path);
    virtual QRectF boundingRect() const override;
    void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget = nullptr) override;
private:
   QList<QPainterPath> m_path;
};

class MainWindow : public QMainWindow
{
   
   
    Q_OBJECT

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

private slots:
    void on_pushButton_clicked();

private:
    void bevel(qreal width, qreal hegiht);
    QList<QPainterPath> m_path;
    Ui::MainWindow *ui;
    MyRectItem *m_rectItem1;
    MyRectItem *m_rectItem2;
};
#endif // MAINWINDOW_H
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include "qdebug.h"
#include "QGraphicsScene"
#include "QMessageBox"
#include "QLabel"
#include <QGraphicsProxyWidget>

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
   
   
    ui->setupUi(this);
    this->resize(600, 400);
    QGraphicsScene* scene = new QGraphicsScene(this);
    ui->graphicsView->setScene(scene);
    MyRectItem* rectItem = new MyRectItem(nullptr);
    rectItem->resize(50, 50);
    bevel(50, 50);
    rectItem->setPath(m_path);
    rectItem->setZValue(100);
    rectItem->resize(50, 50);
    scene->
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值