溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Qt圖形圖像開發(fā)之高性能曲線圖模塊QCustomplot庫詳細(xì)使用方法與實(shí)例(支持動(dòng)、靜曲線圖)

發(fā)布時(shí)間:2020-09-03 08:33:18 來源:腳本之家 閱讀:772 作者:wildPointer_ 欄目:編程語言

Qt曲線圖模塊QCustomPlot庫介紹

QCustomPlot是一個(gè)小型的Qt畫圖標(biāo)類,支持繪制靜態(tài)曲線、動(dòng)態(tài)曲線、多重坐標(biāo)曲線,柱狀圖,蠟燭圖等

前段時(shí)間用QChart模塊畫圖,一條曲線上面放8000條數(shù)據(jù)就會(huì)卡的不行必須要換個(gè)其他的控件,后來找到了曲線圖模塊QCustomplot庫

這個(gè)庫性能非常好,畫曲線圖折線圖柱狀圖動(dòng)態(tài)靜態(tài),放大縮小,都很好用,10w條數(shù)據(jù)量無壓力秒畫出來一點(diǎn)也不卡

下載地址

https://www.qcustomplot.com/index.php/download

里面分為

QCustomPlot 2和QCustomPlot 1我用的2這兩個(gè)有一些函數(shù)的差異

下載解壓以后我們只需要qcustomplot.h和qcustomplot.cpp

注意

pro 文件里面 寫入 QT+= printsupport

動(dòng)態(tài)效果

Qt圖形圖像開發(fā)之高性能曲線圖模塊QCustomplot庫詳細(xì)使用方法與實(shí)例(支持動(dòng)、靜曲線圖)

QCustomplot靜態(tài)曲線圖生成

//他繼承QWidget 所以構(gòu)造里面 放控件就會(huì)畫到控件上
QCustomPlot *pCustomPlot = new QCustomPlot(ui->label);
//添加一條曲線
QCPGraph* pgraph = pCustomPlot->addGraph();
//給曲線準(zhǔn)備數(shù)據(jù) 設(shè)置數(shù)據(jù) 
  QVector<double> x(80000);
  QVector<double> y(80000);
  for(int i = 0; i<x.size();i++)
  {
    x[i] = i;
    if(i%2==0)
      y[i] = 10;
    else
      y[i] = 20;
  }
	
	//設(shè)置數(shù)據(jù)
  pCustomPlot->graph(0)->setData(x,y);
	//設(shè)置Y軸范圍
  pCustomPlot->yAxis->setRange(0,30);
	//x軸名字
  pCustomPlot->xAxis->setLabel("X");
  //Y軸名字
  pCustomPlot->yAxis->setLabel("Y");
	//設(shè)置大小
  pCustomPlot->resize(ui->label->width(),ui->label->height());
	//可以進(jìn)行鼠標(biāo)位置 放大縮小 拖拽 放大縮小坐標(biāo)系!??!功能非常強(qiáng)大
  pCustomPlot->setInteractions(QCP::iRangeDrag | QCP::iRangeZoom);
	//重繪 每次改變完以后都要調(diào)用這個(gè)進(jìn)行重新繪制
  pCustomPlot->replot();

運(yùn)行效果如下:

Qt圖形圖像開發(fā)之高性能曲線圖模塊QCustomplot庫詳細(xì)使用方法與實(shí)例(支持動(dòng)、靜曲線圖)

時(shí)間為坐標(biāo)軸的靜曲線圖

大致差不多 區(qū)別在于x軸改為時(shí)間

  QCustomPlot* p2 = new QCustomPlot(ui->label_2);
  QVector<double> time;
  QVector<double> y;
	//模擬幾個(gè)時(shí)間 .toTime_t()是轉(zhuǎn)換為 時(shí)間戳 從1970年到現(xiàn)在的秒數(shù)
  time<<QDateTime::fromString("2019-01-15 17:08:23","yyyy-MM-dd hh:mm:ss").toTime_t();
  time<<QDateTime::fromString("2019-01-25 17:08:23","yyyy-MM-dd hh:mm:ss").toTime_t();
  time<<QDateTime::fromString("2019-02-15 17:08:23","yyyy-MM-dd hh:mm:ss").toTime_t();
  time<<QDateTime::fromString("2019-02-25 17:08:23","yyyy-MM-dd hh:mm:ss").toTime_t();
  time<<QDateTime::fromString("2019-03-27 13:08:23","yyyy-MM-dd hh:mm:ss").toTime_t();
  y<<5<<15<<5<<15<<5;
	
	//增加一條線
  p2->addGraph();
  //設(shè)置Y軸范圍
  p2->yAxis->setRange(0,20);
  
	//QCPAxisTickerDateTime 時(shí)間坐標(biāo)軸 必須要用 智能指針 
  QSharedPointer<QCPAxisTickerDateTime> timer(new QCPAxisTickerDateTime);
	//設(shè)置時(shí)間格式
  timer->setDateTimeFormat("yyyy-MM-dd");
  //設(shè)置時(shí)間軸 一共幾格
  //timer->setTickCount(6);
  //設(shè)置label 旋轉(zhuǎn)30° 橫著顯示可能顯示不全 
  p2->xAxis->setTickLabelRotation(30);
  // timer->setTickStepStrategy(QCPAxisTicker::tssMeetTickCount);
	//設(shè)置坐標(biāo)軸
  p2->xAxis->setTicker(timer);
  p2->xAxis->setRange(time.at(0),time.at(4));
  p2->graph(0)->setData(time,y);
  p2->resize(ui->label_2->width(),ui->label_2->height());
   p2->setInteractions(QCP::iRangeDrag | QCP::iRangeZoom);

運(yùn)行效果如下:

Qt圖形圖像開發(fā)之高性能曲線圖模塊QCustomplot庫詳細(xì)使用方法與實(shí)例(支持動(dòng)、靜曲線圖)

QCustomplot動(dòng)態(tài)曲線圖生成

下圖動(dòng)態(tài)曲線是我用傳感器采集的,大家可以用一些隨機(jī)數(shù)據(jù)來測(cè)試

Qt圖形圖像開發(fā)之高性能曲線圖模塊QCustomplot庫詳細(xì)使用方法與實(shí)例(支持動(dòng)、靜曲線圖)

假設(shè)圖像只顯示10個(gè)點(diǎn) 第11個(gè)點(diǎn)將會(huì)把第一個(gè)點(diǎn)擠出去 就是一個(gè)vector 出棧入棧 里面一直保持10個(gè)數(shù)據(jù)

		//QVector<double> sx_vec,xAxis_vec 存放數(shù)據(jù)的容器
 	
		//m_chartPoint_counter 計(jì)數(shù)器 一直增加 來一條數(shù)據(jù)增加一下 控制x軸前進(jìn) 實(shí)現(xiàn)動(dòng)態(tài)效果
	
		//這時(shí)容器里面還沒10個(gè)點(diǎn) 所有一直向里面存
    if(m_chartPoint_counter < 10)
    {
    	
      sx_vec.append(sx_);
      xAxis_vec.append(m_chartPoint_counter);
	
			//設(shè)置范圍正好 能顯示當(dāng)前點(diǎn)				
      sx_plot->xAxis->setRange(0,xAxis_vec.at(xAxis_vec.size()-1));
     
    }
    else
    {
    	//容器數(shù)據(jù)現(xiàn)在是正好10個(gè) 把第一個(gè)出棧 把第11個(gè)入棧 正好還是10個(gè)數(shù)據(jù)
      sx_vec.removeFirst();
      xAxis_vec.removeFirst();
			
			//入棧
      xAxis_vec.append(m_chartPoint_counter);
      sx_vec.append(sx_);
			//設(shè)置范圍正好 能顯示當(dāng)前點(diǎn)		
      sx_plot->xAxis->setRange(xAxis_vec.at(0),xAxis_vec.at(
                     xAxis_vec.size()-1));
    }
		//設(shè)置Y軸坐標(biāo)系 自動(dòng)縮放以正常顯示所有的數(shù)據(jù)
    sx_plot->yAxis->rescale(true);
  	//設(shè)置數(shù)據(jù)
    sx_plot->graph()->setData(xAxis_vec,sx_vec);
		//重繪制
    sx_plot->replot();
	//這里必須要一直增加 如果增加到10就不增加 效果就是第10個(gè)點(diǎn)一直變化 不會(huì)出現(xiàn)動(dòng)態(tài)效果
	m_chartPoint_counter++;

圖像數(shù)據(jù)清空

//圖像數(shù)據(jù)清空
QCPGraph* thresholdY_line;
thresholdY_line->data().data()->clear();

這里只是介紹一些基本的功能 ,一些強(qiáng)大的功能 在 下載的examples里有

Qt圖形圖像開發(fā)之高性能曲線圖模塊QCustomplot庫詳細(xì)使用方法與實(shí)例(支持動(dòng)、靜曲線圖)

本文主要講解了Qt圖形圖像開發(fā)之高性能曲線圖模塊QCustomplot庫詳細(xì)使用方法與實(shí)例,更多關(guān)于QT開發(fā)的知識(shí)請(qǐng)查看下面的相關(guān)鏈接

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI