Qt编写可视化大屏电子看板系统14-标准曲线图
一、前言
近期將可視化大屏電子看板系統(tǒng)重新規(guī)劃和調(diào)整項(xiàng)目結(jié)構(gòu)代碼,幾個(gè)重大改變是新增啟動(dòng)窗體選擇,可選大屏系統(tǒng)、控件演示、模塊演示三種,其中控件演示是專門針對本系統(tǒng)中用到的各種自定義控件單獨(dú)做的使用demo,模塊演示是專門針對本系統(tǒng)中每個(gè)子模塊單獨(dú)演示,這樣可以更方便的切換學(xué)習(xí),而不是盲目的在項(xiàng)目代碼中找,可以直接快速切換定位到具體的代碼文件學(xué)習(xí)。
大屏系統(tǒng)中用到的曲線圖柱狀圖都是在開源的QCustomPlot曲線圖表控件基礎(chǔ)上二次開發(fā)改造的,最基礎(chǔ)的曲線展示莫過于標(biāo)準(zhǔn)曲線圖了,QCustomPlot官方一直在更新升級(jí)代碼,本人也是一直看著QCustomPlot長大的,代碼質(zhì)量真的沒的說,后期的代碼更加完美,尤其是增加了更多的模塊接口,比如曲線提示標(biāo)識(shí)可以指定列,XY軸可以互換,這樣就可以很方便的垂直的效果轉(zhuǎn)成平行的效果尤其是柱狀圖。
在大屏系統(tǒng)中需要展示的曲線會(huì)有多條,都要求不同的曲線不同的顏色區(qū)分顯示,數(shù)據(jù)都是通過數(shù)據(jù)源采集好以后的靜態(tài)數(shù)據(jù),每次都是整體重新設(shè)置數(shù)據(jù),其實(shí)在這種數(shù)據(jù)量很小的情況下,重新繪制和追加數(shù)據(jù)繪制效率沒區(qū)別,都是需要重新繪制整個(gè)畫布。默認(rèn)XY軸都是浮點(diǎn)數(shù)顯示,可以通過label映射換成對應(yīng)的文本值顯示,本系統(tǒng)中全部是換成了文本型數(shù)值顯示,更靈活,比如對應(yīng)坐標(biāo)點(diǎn)X軸1/2/3換成1月、2月、3月這種文字顯示,Y軸的數(shù)據(jù)還可以后面加上百分比符號(hào)等。
二、功能特點(diǎn)
三、體驗(yàn)地址
四、效果圖
五、核心代碼
#include "frmplotnormal.h" #include "ui_frmplotnormal.h" #include "head.h"frmPlotNormal::frmPlotNormal(QWidget *parent) : QWidget(parent), ui(new Ui::frmPlotNormal) {ui->setupUi(this);this->initForm();this->loadPlot(); }frmPlotNormal::~frmPlotNormal() {delete ui; }void frmPlotNormal::initForm() {//設(shè)置線條名稱,如果要增加線條 只需要這里增加線條名字就行l(wèi)ineNames << "新模" << "修模" << "設(shè)變" << "測試" << "哈哈";//隱藏表格線//ui->customPlot->getPlot()->xAxis->grid()->setVisible(false);//ui->customPlot->getPlot()->yAxis->grid()->setVisible(false);//添加畫布ui->customPlot->addGraph(lineNames.count());//設(shè)置畫布邊距ui->customPlot->setPadding(9); //設(shè)置可拖動(dòng)鼠標(biāo)滾輪縮放ui->customPlot->setInteractions(3);//設(shè)置圖例可見ui->customPlot->setLegend(true, 0, lineNames.count());//綁定雙擊重新加載數(shù)據(jù)connect(ui->customPlot->getPlot(), SIGNAL(mouseDoubleClick(QMouseEvent *)), this, SLOT(loadPlot())); }void frmPlotNormal::loadPlot() {vstring lab;vdouble key;lvdouble values;for (int j = 0; j < lineNames.count(); ++j) {values << vdouble();}int count = lineNames.count();int dataCount = 12;for (int i = 0; i < dataCount; i++) {lab << QString("%1月").arg(i + 1);key << i;//挨個(gè)對每條線段的數(shù)據(jù)賦值for (int j = 0; j < count; ++j) {values[j] << CustomPlotHelper::getRandValue(10, 100);}}//如果需要設(shè)置掃點(diǎn)圖則設(shè)置onlydot屬性即可//ui->customPlot->setOnlyDot(true);LineData data;data.key = key;for (int i = 0; i < count; ++i) {data.index = i;data.name = lineNames.at(i);data.value = values.at(i);//設(shè)置線條顏色,可以指定顏色也可以隨機(jī)顏色data.lineColor = ui->customPlot->getColors().at(i);ui->customPlot->setDataLine(data);}//設(shè)置坐標(biāo)軸范圍值+X坐標(biāo)對應(yīng)顯示文字ui->customPlot->setLabX(key, lab);ui->customPlot->setRangeX(-0.5, key.count() - 0.5);ui->customPlot->setRangeY(0, 120, 10);//初始化指示器數(shù)據(jù)高亮及懸停提示等ui->customPlot->initItem();//重新刷新顯示ui->customPlot->replot(); }總結(jié)
以上是生活随笔為你收集整理的Qt编写可视化大屏电子看板系统14-标准曲线图的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Dynamics 365 On-prem
- 下一篇: java信息管理系统总结_java实现科