亲宝软件园·资讯

展开

Qt 柱状图 Qt创建并显示柱状图的方法

我不是微光 人气:4
想了解Qt创建并显示柱状图的方法的相关内容吗,我不是微光在本文为您仔细讲解Qt 柱状图的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:Qt,柱状图,下面大家一起来学习吧。

创建一个简单的柱状图

第一步:创建一个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);
//...

加载全部内容

相关教程
猜你喜欢
用户评论