根据项目需求,需要在Qt中进行绘图显示我们的数据。这时候,我们就用到了Qt在5.0之后新增的自带QChart控件,不再需要我们自己再去添加第三方库。下面是详细的介绍~
在.pro文件中
QT += charts
在.h文件中
//QChart#include using namespace QtCharts;//定时器#include private slots: void updata_plot(); void on_pushButton_clicked(); void on_pushButton_2_clicked();private: //绘图定时器 QTimer *timer_plot; //曲线 QSplineSeries* line; //曲线点的最大数量 int line_max = 100; //绘图变量和坐标 QChart* chart; QValueAxis *axisX; QValueAxis *axisY;12345678910111213141516171819202122232425
在.cpp文件中
//将变量实例化 timer_plot = new QTimer(this); connect(timer_plot,SIGNAL(timeout()),this,SLOT(updata_plot())); line = new QSplineSeries(this); chart = new QChart(); chart->addSeries(line); axisX = new QValueAxis(this); axisY = new QValueAxis(this);//图像更新函数void MainWindow::updata_plot(){ QVector list; QVector newlist; list = line->pointsVector();//获取现在图中列表 if (list.size() < line_max) { //保持原来 newlist = list; } else { //错位移动 for(int i =1 ; i< list.size();i++) { newlist.append(QPointF(i-1,list.at(i).y())); } } newlist.append(QPointF(newlist.size(),rand()));//最后补上新的数据 line->replace(newlist);//替换更新 line->setName("pressure");//设置曲线名称 line->setPen(QColor(255, 0, 0));//设置曲线颜色 line->setUseOpenGL(true);//openGl 加速 chart->setTitle("Pressure Data");//设置图标标题 chart->removeSeries(line); chart->addSeries(line); chart->createDefaultAxes();//设置坐标轴// axisX->setRange(0,line_max);//范围// axisX->setTitleText("times(secs)");//标题// axisX->setTickCount(10);//分隔个数// axisX->setLineVisible(true);//可视化// axisX->setLinePenColor(Qt::blue);//颜色// axisY->setRange(-200,1200);// axisY->setTitleText("value");// axisY->setTickCount(6);// axisY->setLineVisible(true);// axisY->setLinePenColor(Qt::blue);// chart->setAxisX(axisX,line);// chart->setAxisY(axisY,line); ui->widget_plot->setChart(chart);}void MainWindow::on_pushButton_clicked(){ timer_plot->start(50);//启动定时器}void MainWindow::on_pushButton_2_clicked(){ timer_plot->stop();//关闭定时器}123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
在.ui文件中
先放入Widget,然后将其提升为QChartView,如下图:
希望能够帮助到大家啦~