微光

最孤独的时光会塑造最坚强的自己。

导航

Qt之如何创建并显示一个柱状图

Posted on 2020-09-06 12:06  我不是微光  阅读(4928)  评论(0编辑  收藏  举报

创建一个简单的柱状图

 

第一步:创建一个QBarSet对象;QBarSet类代表条形图中的一组条形。

QBarSet *set0 = new QBarSet("Jane");
QBarSet *set1 = new QBarSet("John");
QBarSet *set2 = new QBarSet("Axel");
QBarSet *set3 = new QBarSet("Mary");
QBarSet *set4 = new QBarSet("Samantha");

  这样的话相当于我们创建了五个条组,也就是说会有五组数据。

 

第二步:接下来为这五个条组添加数据

*set0 << 1 << 2 << 3 << 4 << 13 << 6;
*set1 << 5 << 0 << 0 << 4 << 15 << 7;
*set2 << 3 << 5 << 8 << 13 << 8 << 5;
*set3 << 5 << 6 << 7 << 3 << 4 << 5;
*set4 << 9 << 7 << 5 << 3 << 1 << 2;

 

第三步:创建一个QBarSeries对象,QBarSeries类将一系列数据显示为按类别分组的竖线。

QBarSeries *series = new QBarSeries();
series->append(set0);
series->append(set1);
series->append(set2);
series->append(set3);
series->append(set4);

 

第四步:创建一个QChart用来装QBarSeries对象;QChart是一个QGraphicsWidget,可以在QGraphicsScene中显示。

QChart *chart = new QChart();
chart->addSeries(series);
chart->setTitle("Simple barchart example");
chart->setAnimationOptions(QChart::SeriesAnimations);

 

第五步:创建一个QChartView来显示表格

QChartView *chartView = new QChartView(chart);

 

第六步:将QChartView添加到一个主窗口然后显示出来。

QMainWindow window;
window.setCentralWidget(chartView);
window.resize(420, 300);
window.show();

  

  然后我们运行就能看到下面这样一个柱状图。

柱状图优化

 

  虽然我们已经成功的显示出了一个条形图,但是这样看上去好像并不是很美观,在实际应用中也会达不到我们想要的效果。然后我们再稍微给它优化一下。

首先给它添加一个坐标轴

QStringList categories;
categories << "Jan" << "Feb" << "Mar" << "Apr" << "May" << "Jun";  //保存横坐标字符串的列表
QBarCategoryAxis *axis = new QBarCategoryAxis();
axis->append(categories);
chart->createDefaultAxes();  //创建一个默认的坐标轴
chart->setAxisX(axis, series);  //设置X坐标轴

  

  然后让它把标签数据显示出来

series->setLabelsPosition(QAbstractBarSeries::LabelsInsideEnd);  //设置标签显示的位置
series->setLabelsVisible(true);  //设置数据标签可见

 

  这样我们就得到了下面这样一个柱状图。

 

  然后我们可以给表格设置一个主题

chart->setTheme(QChart::ChartThemeBlueCerulean);

 

  可以把设置图例的位置设置到下方

chart->legend()->setAlignment(Qt::AlignBottom);

 

  最后看效果,这样子看上去就好了很多对吧。

 

  最后,当我们想把图表显示到我们的布局中去该怎么显示呢?

  当我们试图把QChartView添加到一个QWidget上去时发现我们无法做到,这里的话我们就需要借助QHBoxLayout了。

  就像下面这样:

//...
QWidget *widget = new QWidget();
QHBoxLayout m_pHLayout = new QHBoxLayout();
m_pHLayout->addWidget(chartView);
widget->setLayout(m_pHLayout);
//...

 

  最后希望对你有所帮助。