完整代码下载地址:
1.折线图(QLineSeries)
首先要创建折线图,需要一个QLineSeries实例。
QLineSeries *series = new QLineSeries();
然后我们向series中添加数据。可以使用append()成员函数或使用流操作符。
series->append(0, 6);
series->append(2, 4);
series->append(3, 8);
series->append(7, 4);
series->append(10, 5);
*series << QPointF(11, 1) << QPointF(13, 3) << QPointF(17, 6) << QPointF(18, 3) << QPointF(20, 2);
为了在图表中显示数据,我们需要一个QChart实例。我们将系列添加到其中,创建默认轴,并设置图表的标题。
QChart *chart = new QChart();
chart->legend()->hide();
chart->addSeries(series);
chart->createDefaultAxes();
chart->setTitle("Simple line chart example");
然后我们用QChart作为参数创建一个QChartView对象。这样我们就不需要自己创建QGraphicsView场景。我们还设置了反锯齿,使渲染线看起来更好。
QChartView *chartView = new QChartView(chart);
chartView->setRenderHint(QPainter::Antialiasing);
然后显示图表
QMainWindow window;
window.setCentralWidget(chartView);
window.resize(400, 300);
window.show();
2.曲线图(QSplineSeries)
要创建曲线图,我们需要将数据放入QSplineSeries中。QSplineSeries自动计算正确绘制曲线所需的控制点。
QSplineSeries *series = new QSplineSeries();
series->setName("spline");
接下来,向series中添加一些数据点。
series->append(0, 6);
series->append(2, 4);
series->append(3, 8);
series->append(7, 4);
series->append(10, 5);
*series << QPointF(11, 1) << QPointF(13, 3) << QPointF(17, 6) << QPointF(18, 3) << QPointF(20, 2);
上面的代码已经填充了数据系列。为了在图表中显示它,我们创建一个QChart对象并将数据系列添加到里面。我们还在y轴上设置标题和值范围,这样图表的可见性就更好了。
QChart *chart = new QChart();
chart->legend()->hide();
chart->addSeries(series);
chart->setTitle("Simple spline chart example");
chart->createDefaultAxes();
chart->axisY()->setRange(0, 10);
然后我们用QChart作为参数创建一个QChartView对象。这样我们就不需要自己创建QGraphicsView场景。我们还设置了反锯齿,使渲染线看起来更好。
QChartView *chartView = new QChartView(chart);
chartView->setRenderHint(QPainter::Antialiasing);
最后,我们将QChartView设置为窗口的中心小部件,图表就能显示了
QMainWindow window;
window.setCentralWidget(chartView);
window.resize(400, 300);
window.show();