QChart饼状图

简介: QChart饼状图


//Chart.h
#pragma once
#include <QtWidgets/QMainWindow>
#include "ui_Chart.h"
#include <QtCharts/QChartView>
#include <QtCharts/QPieSeries>
#include <QtCharts/QPieSlice>
#include <QVBoxLayout>
using namespace QtCharts;
class Chart : public QMainWindow
{
    Q_OBJECT
public:
    Chart(QWidget *parent = nullptr);
    ~Chart();
private:
    Ui::ChartClass ui;
  QPieSeries* pie_series;
};
//Chart.cpp
#include "Chart.h"
Chart::Chart(QWidget *parent)
    : QMainWindow(parent)
{
    ui.setupUi(this);
  //饼状图
  pie_series = new QPieSeries(this);
  connect(pie_series, SIGNAL(clicked(QPieSlice*)), this, SLOT(onPieSeriesClicked(QPieSlice*)));
  //定义各扇形切片的颜色
  static const QStringList list_pie_color = {
    "#F51F48","#225AE7","#F3BA0C","#808080",
  };
  //设置数据
  QList<qreal> list_data = { 239, 171, 114, 59 };
  //扇形
  for (int i = 0; i < list_pie_color.size(); i++) {
    QPieSlice* pie_slice = new QPieSlice(this);
    pie_slice->setLabelVisible(true);
    pie_slice->setValue(list_data[i]);
    pie_slice->setLabel(QString::number(list_data[i]));
    pie_slice->setColor(list_pie_color[i]);
    pie_slice->setLabelColor(list_pie_color[i]);
    pie_slice->setBorderColor(list_pie_color[i]);
    pie_series->append(pie_slice);
    //设置是否显示扇形切片的标签
    pie_series->setLabelsVisible(false);
  }
  //设置饼状图的内部空心大小为 0.5
  pie_series->setHoleSize(0.5);
  //图表视图
  QChart* chart = new QChart;
  chart->setTitle(u8"");
  //设置暗黑主题
  chart->setTheme(QChart::ChartThemeLight);
  chart->setBackgroundVisible(false);
  //标题字体
  QFont font = qApp->font();
  font.setBold(true);
  font.setPointSize(10);
  chart->setTitleFont(font);
  //加入饼图
  chart->addSeries(pie_series);
  chart->setAnimationOptions(QChart::SeriesAnimations);
  //图例
  //设置图例的位置在底部
  chart->legend()->setAlignment(Qt::AlignBottom);
  //设置图例是否可见
  chart->legend()->setVisible(false);;
  //加入绘画视图
  QChartView* chartView = new QChartView(this);
  chartView->setRenderHint(QPainter::Antialiasing);
  chartView->setChart(chart);
  chartView->setStyleSheet("background-color: transparent;");
  chartView->resize(800, 600);
  //加入布局
  QVBoxLayout* layout = new QVBoxLayout;
  layout->setContentsMargins(0, 0, 0, 0);
  layout->addWidget(chartView);
  ui.centralWidget->setLayout(layout);
  ui.centralWidget->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
}
Chart::~Chart()
{}


相关文章
|
JavaScript 前端开发
VUE element-ui之table表格自增序号(前端实现)
VUE element-ui之table表格自增序号(前端实现)
2078 0
|
SQL Java 数据库
Springboot整合JPA 多表关联操作 @Query
Springboot整合JPA 多表关联操作 @Query
1165 0
Springboot整合JPA 多表关联操作 @Query
|
机器学习/深度学习 人工智能 语音技术
QT界面中实现视频帧显示的多种方法及应用(三)
QT界面中实现视频帧显示的多种方法及应用
1198 0
|
存储 编解码 监控
QT界面中实现视频帧显示的多种方法及应用(一)
QT界面中实现视频帧显示的多种方法及应用
1583 0
|
应用服务中间件
tomcat服务器get、post请求及响应中文乱码问题
tomcat服务器get、post请求及响应中文乱码问题
204 1
|
移动开发 前端开发 JavaScript
原生求生记:揭秘UniApp的原生能力限制
原生求生记:揭秘UniApp的原生能力限制
|
XML Go 数据格式
Windows自定义后台进程并设置为开机启动
可以在`Windows`上配置任意一个可执行文件后台启动,并且设置为开机启动。
Windows自定义后台进程并设置为开机启动
|
XML Java Scala
Gradle安装配置阿里云
Gradle安装配置阿里云
1424 0
Vscode 插件-代码敲出不同的特效
Vscode 插件-代码敲出不同的特效
328 0
|
传感器 算法 自动驾驶
基于uwb和IMU融合的三维空间定位算法matlab仿真
基于uwb和IMU融合的三维空间定位算法matlab仿真