QChart 画柱状图(Qt自带的demo)

QChart:

The QChart class manages the graphical representation of the chart's series, 
legends, and axes.
QChart is a QGraphicsWidget that you can show in a QGraphicsScene. It manages the
 graphical representation of different types of series and other chart related 
class QChartView can be used instead of QChart. In addition, line, spline, area,
 and scatter series can be presented as polar charts by using the QPolarChart class.

QChart类管理图表系列、图例和轴的图形表示。
QChart是一个可以在QGraphicsScene中显示的QGraphicsWidget。
它管理不同类型的系列和其他图表相关对象(如图例和轴)的图形表示。
要简单地在布局中显示图表,可以使用便利类QChartView代替QChart。
此外,直线、样条、面积和散射级数可以通过QPolarChart类来表示为极坐标图

使用QChart 要在安装Qt的选择QChart 模块 否则 不能使用!!!
使用QChart 要在安装Qt的选择QChart 模块 否则 不能使用!!!
使用QChart 要在安装Qt的选择QChart 模块 否则 不能使用!!!

pro 加入 QT += charts

并且在程序的开头加上一句 using namespace Qtcharts或者一个宏 QT_CHARTS_USE_NAMESPACE

先来了解几个部分

QBarSet:

#include <QBarSet> 
QBarSet(const QString label, QObject *parent = Q_NULLPTR)//构造

QBarSet类表示条形图中的一组条形。
一个bar集包含每个类别的一个数据值。
假设集合的第一个值属于第一个类别,
第二个属于第二个类别,依此类推。
如果集合的值小于类别的值,则假设缺失值位于集合的末尾。对于位于集合中间的缺失值,则使用0的数值。
没有显示零值集的标签。

这里写图片描述

这 竖 立 五 个 条 就 是 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 << 5 << 6;// 名字为 Jane 竖条的 6个值 (分别代表6个月的值)
    *set1 << 5 << 0 << 0 << 4 << 0 << 7;
    *set2 << 3 << 5 << 8 << 19<< 8 << 5;
    *set3 << 5 << 6 << 7 << 3 << 4 << 5;
    *set4 << 9 << 7 << 5 << 3 << 1 << 2;

QBarSeries:

#include <QBarSeries> 
QBarSeries(QObject *parent = Q_NULLPTR)

QBarSeries类以垂直条的形式呈现一系列数据,按类别分组。
这个类将数据绘制为一系列按类别分组的竖线,每个类别中有一个竖线添加到这个系列中。
请参阅柱状图示例,了解如何创建分组柱状图

    QBarSeries *series = new QBarSeries();
    series->append(set0);
    series->append(set1);
    series->append(set2);
    series->append(set3);
    series->append(set4);
//把上面5个人的 6个月的值放到 series 待会显示

QBarCategoryAxis:

#include <QBarCategoryAxis> 

QBarCategoryAxis(QObject *parent = Q_NULLPTR)

QBarCategoryAxis类将类别添加到图表的轴中。
可以设置QBarCategoryAxis来显示带有标记、网格线和阴影的轴线。在刻度之间绘制类别。
它还可以与线系列一起使用,如line和BarChart示例所示。

    QStringList categories;
    categories << "Jan" << "Feb" << "Mar" << "Apr" << "May" << "Jun";
    QBarCategoryAxis *axis = new QBarCategoryAxis();
    axis->append(categories);
	//

这里写图片描述

Qt 的demo


#include <QtWidgets/QApplication>
#include <QtWidgets/QMainWindow>
#include <QtCharts/QChartView>
#include <QtCharts/QBarSeries>
#include <QtCharts/QBarSet>
#include <QtCharts/QLegend>
#include <QtCharts/QBarCategoryAxis>

QT_CHARTS_USE_NAMESPACE

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);

//![1]
    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 << 5 << 6;// Jane 6个月份的值
    *set1 << 5 << 0 << 0 << 4 << 0 << 7;
    *set2 << 3 << 5 << 8 << 19<< 8 << 5;
    *set3 << 5 << 6 << 7 << 3 << 4 << 5;
    *set4 << 9 << 7 << 5 << 3 << 1 << 2;
//![1]

//![2]
    QBarSeries *series = new QBarSeries();
    series->append(set0);
    series->append(set1);
    series->append(set2);
    series->append(set3);
    series->append(set4);

//![2]

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

//![4]
    QStringList categories;
    categories << "Jan" << "Feb" << "Mar" << "Apr" << "May" << "Jun";
    QBarCategoryAxis *axis = new QBarCategoryAxis();
    axis->append(categories);
    chart->createDefaultAxes();//创建默认的左侧的坐标轴(根据 QBarSet 设置的值)
    chart->setAxisX(axis, series);//设置坐标轴
//![4]

//![5]
    chart->legend()->setVisible(true); //设置图例为显示状态
    chart->legend()->setAlignment(Qt::AlignBottom);//设置图例的显示位置在底部
//![5]

//![6]
    QChartView *chartView = new QChartView(chart);
    chartView->setRenderHint(QPainter::Antialiasing);
//![6]

//![7]
    QMainWindow window;
    window.setCentralWidget(chartView);
    window.resize(420, 300);
    window.show();
//![7]

    return a.exec();
}

如果数据量大(百万数据不卡顿)并且交互多的话 推荐使用QCustomplot

  • 23
    点赞
  • 141
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 在Qt中使用QChart类实现横向柱状图可以通过以下步骤: 1. 创建一个Qt应用程序,并在项目文件中包含QChart和QChartView的头文件声明。 2. 创建一个QWidget或QMainWindow的派生类作为主窗口。 3. 在主窗口类中创建一个QChart对象,并设置图表的标题、X轴和Y轴标签。 4. 创建一个QBarSeries对象,并将其添加到图表中。 5. 创建一个QBarSet对象,并设置其名称和值。 6. 将QBarSet对象添加到QBarSeries对象中。 7. 创建一个QBarCategoryAxis对象,并将其设置为图表的Y轴。 8. 创建一个QValueAxis对象,并将其设置为图表的X轴。 9. 将QBarSeries对象添加到图表中。 10. 创建一个QChartView对象,并将其设置为主窗口类的中心窗口部件。 11. 在主窗口类的构造函数中,设置图表视图的大小和主窗口类的布局。 12. 在主窗口类的析构函数中,释放QChart对象和QChartView对象。 示例代码如下: ```cpp #include <QtWidgets> #include <QtCharts> QT_CHARTS_USE_NAMESPACE class MainWindow : public QMainWindow { public: MainWindow(QWidget *parent = nullptr) : QMainWindow(parent) { // 创建QChart对象 QChart *chart = new QChart(); chart->setTitle("Horizontal Bar Chart"); chart->legend()->hide(); // 创建QBarSeries对象 QBarSeries *series = new QBarSeries(); // 创建QBarSet对象 QBarSet *barSet = new QBarSet("Values"); *barSet << 1 << 2 << 3 << 4 << 5; // 将QBarSet对象添加到QBarSeries对象 series->append(barSet); // 创建QBarCategoryAxis对象 QBarCategoryAxis *axisY = new QBarCategoryAxis(); chart->addAxis(axisY, Qt::AlignLeft); series->attachAxis(axisY); // 创建QValueAxis对象 QValueAxis *axisX = new QValueAxis(); chart->addAxis(axisX, Qt::AlignBottom); series->attachAxis(axisX); // 将QBarSeries对象添加到QChart对象 chart->addSeries(series); // 创建QChartView对象 QChartView *chartView = new QChartView(chart); chartView->setRenderHint(QPainter::Antialiasing); setCentralWidget(chartView); } ~MainWindow() { delete chart; delete chartView; } private: QChart *chart; QChartView *chartView; }; int main(int argc, char *argv[]) { QApplication app(argc, argv); MainWindow window; window.resize(800, 600); window.show(); return app.exec(); } ``` 以上是使用Qt的QChart类实现横向柱状图的简单示例。可以根据实际需求对图表进行修改和扩展。 ### 回答2: Qt的QChart类是Qt Charts模块中的核心类,用于绘制各种类型的图表,包括横向柱状图。 要实现横向柱状图,首先需要创建一个QChart对象,并设置其标题和刻度。然后,创建一个QBarSet对象,表示各个柱状图的数据集。可以通过QBarSet::append()方法向数据集添加数据。接下来,创建一个QBarSeries对象,并将数据集添加到系列中。然后,创建一个QChartView对象,并将系列添加到图表中。 代码示例: ```cpp // 创建数据集并添加数据 QBarSet *barSet = new QBarSet("柱状图数据集"); barSet->append(10); barSet->append(20); barSet->append(30); barSet->append(40); // 创建柱状图数据系列 QBarSeries *barSeries = new QBarSeries(); barSeries->append(barSet); // 创建图表并设置属性 QChart *chart = new QChart(); chart->addSeries(barSeries); chart->setTitle("横向柱状图"); chart->setAnimationOptions(QChart::SeriesAnimations); // 设置坐标轴和刻度 QCategoryAxis *axisY = new QCategoryAxis(); chart->addAxis(axisY, Qt::AlignLeft); barSeries->attachAxis(axisY); QValueAxis *axisX = new QValueAxis(); chart->addAxis(axisX, Qt::AlignBottom); barSeries->attachAxis(axisX); // 创建图表视图并显示 QChartView *chartView = new QChartView(chart); chartView->setRenderHint(QPainter::Antialiasing); chartView->show(); ``` 这样就可以在Qt应用程序中实现一个简单的横向柱状图了。根据需求,可以进一步添加颜色、标签、图例等属性来定制图表的样式。 ### 回答3: 要实现Qt的QChart横向柱状图,首先我们需要引入QChart和QBarSet类。 QChart类是用于展示和管理图表的主要类,而QBarSet类则用于表示一个柱状图的数据集。 首先,我们需要创建一个QBarSet对象,并设置其名称和值。例如: QBarSet *set = new QBarSet("数据集"); *set << 20 << 40 << 60 << 80; 接下来,我们将创建一个QBarSeries对象,并将QBarSet对象添加到该系列中。例如: QBarSeries *series = new QBarSeries(); series->append(set); 然后,我们创建一个QChart对象,并将该系列添加到图表中。例如: QChart *chart = new QChart(); chart->addSeries(series); 接着,我们创建一个QValueAxis对象,用于表示横轴的数值范围。例如: QValueAxis *axisY = new QValueAxis(); axisY->setRange(0, 100); chart->addAxis(axisY, Qt::AlignLeft); 然后,将该轴添加到图表中,并将系列与该轴绑定。例如: series->attachAxis(axisY); 最后,我们创建一个QChartView对象,用于显示图表,并设置一些显示选项,例如: QChartView *chartView = new QChartView(chart); chartView->setRenderHint(QPainter::Antialiasing); 最后,我们可以将该QChartView对象添加到Qt的窗口或布局中,以显示横向柱状图。 以上是实现Qt的QChart横向柱状图的基本步骤,通过设置不同的数据集、轴范围和显示选项,我们可以根据实际需要来定制柱状图的外观和功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值