真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

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

Qt曲線圖模塊QCustomPlot庫介紹

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

網(wǎng)站建設哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁設計、網(wǎng)站建設、微信開發(fā)、成都微信小程序、集團企業(yè)網(wǎng)站建設等服務項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了平樂免費建站歡迎大家使用!

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

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

下載地址

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

里面分為

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

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

注意

pro 文件里面 寫入 QT+= printsupport

動態(tài)效果

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

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

//他繼承QWidget 所以構造里面 放控件就會畫到控件上
QCustomPlot *pCustomPlot = new QCustomPlot(ui->label);
//添加一條曲線
QCPGraph* pgraph = pCustomPlot->addGraph();
//給曲線準備數(shù)據(jù) 設置數(shù)據(jù) 
  QVector x(80000);
  QVector y(80000);
  for(int i = 0; igraph(0)->setData(x,y);
	//設置Y軸范圍
  pCustomPlot->yAxis->setRange(0,30);
	//x軸名字
  pCustomPlot->xAxis->setLabel("X");
  //Y軸名字
  pCustomPlot->yAxis->setLabel("Y");
	//設置大小
  pCustomPlot->resize(ui->label->width(),ui->label->height());
	//可以進行鼠標位置 放大縮小 拖拽 放大縮小坐標系!??!功能非常強大
  pCustomPlot->setInteractions(QCP::iRangeDrag | QCP::iRangeZoom);
	//重繪 每次改變完以后都要調(diào)用這個進行重新繪制
  pCustomPlot->replot();

運行效果如下:

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

時間為坐標軸的靜曲線圖

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

  QCustomPlot* p2 = new QCustomPlot(ui->label_2);
  QVector time;
  QVector y;
	//模擬幾個時間 .toTime_t()是轉換為 時間戳 從1970年到現(xiàn)在的秒數(shù)
  time<addGraph();
  //設置Y軸范圍
  p2->yAxis->setRange(0,20);
  
	//QCPAxisTickerDateTime 時間坐標軸 必須要用 智能指針 
  QSharedPointer timer(new QCPAxisTickerDateTime);
	//設置時間格式
  timer->setDateTimeFormat("yyyy-MM-dd");
  //設置時間軸 一共幾格
  //timer->setTickCount(6);
  //設置label 旋轉30° 橫著顯示可能顯示不全 
  p2->xAxis->setTickLabelRotation(30);
  // timer->setTickStepStrategy(QCPAxisTicker::tssMeetTickCount);
	//設置坐標軸
  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);

運行效果如下:

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

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

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

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

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

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

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

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

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

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

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


當前文章:Qt圖形圖像開發(fā)之高性能曲線圖模塊QCustomplot庫詳細使用方法與實例(支持動、靜曲線圖)
當前鏈接:http://weahome.cn/article/ipejdp.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部