其实用QCustomPlot这个库十分的偶然。以前用过Qwt的,今天有个功能要画曲线图,所以就去网上搜下名字,结果找到了这货。点开网站一看,开源,只需要一个.h和一个.cpp就OK!看了下截图效果,不错啊。下下来开用!
用过之后,确实简单,按照一个例子改吧改吧,半个小时功能搞定!记得原来用qwt时,文档确实全,但要实现一个稍复杂点的功能就需要翻一大篇儿文档,而我的英文水平……
废话一大堆,简单说下使用方法吧。我要实现的是一个x轴显示时间,y轴显示数值的折线图。
创建图表控件:
QCustomPlot* plot = new QCustomPlot;
plot->addGraph(); // 添加一个图表
// 设置关键点的显示效果
plot->graph(0)->setScatterStyle(QCPScatterStyle(QCPScatterStyle::ssCircle, QPen(QColor(41,138,220), 2), QBrush(QColor(5,189,251)), 10));
// 设置x轴显示时间
plot->xAxis->setTickLabelType(QCPAxis::ltDateTime);
plot->xAxis->setDateTimeFormat("hh:mm"); //时间格式
// 设置轴的标题
plot->xAxis->setLabel("时间");
plot->yAxis->setLabel("温度");
ui.layout->addWidget(_plot);
更新数据:
// 填充数据
QVector<double> dates, temps;
......
// 更新数据
plot->graph(0)->setData(dates, temps);
// 自动调整轴上值的显示范围
plot->rescaleAxes();
// 自定义y轴值的显示范围
plot->yAxis->setRange(0,100);
// 重绘
plot->replot();
代码很简洁,基本上看着例子就能做出效果来。
说下我遇到的小问题:由于我需要x轴是根据我输入的值的范围显示,而y轴则是一个给定的显示范围。比如我给出两组值:(20150811, 50),(20150812, 60),我想要的效果是x轴起始的时间为20150811,终止时间是20150812,而y轴我却想要起始值为0,终止值为100,那么就可以先调用rescaleAxes函数,把x轴的起始和终止值都自动调整好,由于rescaleAxes也会影响到y轴,所以再调用setRange单独设置一下y轴的显示范围就OK了。