QT汇制饼图 QtCharts饼图源码示例

QT汇制饼图 QtCharts饼图源码示例

QtCharts饼图源码

环境

Qt 5.13.1 (MSVC 2017, 32 bit)
Qt Creator 4.10.1
源码在ubuntu20和windows10下面编译通过

.pro文件引入

QT += charts

UI界面

在界面适当位置拖入一个Widget,重命名为ChartView1,右键提升为QChartView

.h文件核心代码

#include <QtCharts>
QT_CHARTS_USE_NAMESPACE
namespace Ui {
class XXXXX;
}

private:
	void showEvent(QShowEvent *);
	void ShujuChartDraw();
    void ShujuChartUpdate();
	QChart *chart = nullptr;
    QPieSeries *series = nullptr;

.cpp文件核心源码

XXXXX::XXXXX(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::XXXXX)
{
    ui->setupUi(this);
    //绘制统计图
    this->ShujuChartDraw();
}
//***************
//* 绘制统计图
//******************
void XXXXX::ShujuChartDraw(){
    series = new QPieSeries();
    series->setUseOpenGL(true);
    series->setPieSize(0.85);
    series->setHoleSize(0.05);  //设置圆洞的大小,放大可以做成圆柱体
    series->setLabelsVisible(true);
    series->setLabelsPosition(QPieSlice::LabelInsideNormal);

    chart = new QChart();
    chart->addSeries(series);
    chart->setTitle("报警消息统计");
    chart->setTheme(QChart::ChartThemeBlueCerulean);
    chart->setAnimationOptions(QChart::SeriesAnimations);
    chart->layout()->setContentsMargins(0, 0, 0, 0);
    chart->setMargins(QMargins(0, 0, 0, 0));
    chart->setBackgroundRoundness(3);

    QFont font;
    font.setPixelSize(11);
    chart->legend()->setFont(font);
    chart->legend()->setContentsMargins(0,0,0,0);
    chart->legend()->setVisible(false);

    ui->ChartView1->setChart(chart);
    ui->ChartView1->setStyleSheet("background: transparent;");
    ui->ChartView1->setRenderHint(QPainter::Antialiasing);
}
//***************
//* 更新统计图
//******************
void XXXXX::ShujuChartUpdate(){
    if( !YourSqliteDb.open() )
        return;

    int C1=0,
    	C2=0,
    	C3=0;

    QString QuerySql="SELECT COUNT(id) AS C1 FROM *** WHERE ntype='1'";
    QuerySql+=" UNION ALL SELECT COUNT(id) AS C2 FROM *** WHERE ntype='2'";
    QuerySql+=" UNION ALL SELECT COUNT(id) AS C3 FROM *** WHERE ntype='3'";
    QSqlQuery myQuery;
    if( myQuery.exec(QuerySql) )
        while(myQuery.next()){
            if(myQuery.at()==0)
            	C1 = myQuery.value(0).toInt();
            if(myQuery.at()==1)
            	C2 = myQuery.value(0).toInt();
            if(myQuery.at()==2)
            	C3 = myQuery.value(0).toInt();
        }
    YourSqliteDb.close();

    int Total = C1 + C2 + C3;
    if(Total < 1){
        Total = 100;
        C3 = 100;
    }
    double D1 = QString::asprintf("%.2f", C1 / Total * 1.0).toDouble();
    double D2 = QString::asprintf("%.2f", C2 / Total * 1.0).toDouble();
    double D3 = QString::asprintf("%.2f", C3 / TotalDateRows * 1.0).toDouble();

    series->clear();
    series->append("消息", fMessages);
    series->append("报警", fWarning);
    series->append("故障", fMalfunction);

    QPieSlice * sliceC1 = series -> slices().at(0);
    QPieSlice * sliceC2 = series -> slices().at(1);
    QPieSlice * sliceC3 = series -> slices().at(2);
    sliceC1 -> setExploded();

    sliceC1 ->setColor(QColor(0,204,0));
    sliceC2 ->setColor(QColor(255,153,51));
    sliceC3 ->setColor(QColor(255,0,0));

    sliceC1 ->setLabelColor(QColor(255,255,255));
    sliceC2 ->setLabelColor(QColor(0,0,0));
    sliceC3 ->setLabelColor(QColor(255,255,255));
    
    sliceC1 -> setLabel(QString("%1%").arg(100 * sliceC1 -> value(), 0, 'f', 0));
    sliceC2 -> setLabel(QString("%1%").arg(100 * sliceC2 -> value(), 0, 'f', 0));
    sliceC3 -> setLabel(QString("%1%").arg(100 * sliceC3 -> value(), 0, 'f', 0));

    QFont font;
    font.setPointSize(10);
    sliceC1 -> setLabelFont(font);
    sliceC2 -> setLabelFont(font);
    sliceC3 -> setLabelFont(font);
}
//***************
//* 每新页面显示都更新一次统计图
//******************
void XXXXX::showEvent(QShowEvent *){
    //更新统计图
    this->ShujuChartUpdate();
}

最终效果图

最终效果图

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

人为峰ing

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值