Qt编写可视化大屏电子看板系统21-数据转曲线
一、前言
數據轉曲線,這個用的非常多,比如串口或者網絡收到的數據,對特定的字節數據繪制實時的曲線,或者對歷史記錄存儲的數據進行曲線繪制,按照約定的規則,數據轉曲線繪制必須提供規則,沒有規則只能對所有數據繪制,那樣的話肯定很難看,一般下位機傳過來的數據都是有楨頭幀尾校驗碼的,需要剔除無關的數據,一般需要指定哪個字節或者哪幾個字節屬于需要繪制曲線的數據,如果是多個數據,可能還需要合并,比如2個字節合并成一個無符號ushort數據,4個字節合并成一個uint數據,合并轉換的規則還有高低字節位置的區分,有些是高字節在前面,有些是高字節在后面,都必須在規約中體現出來,否則很可能繪制出來的曲線不正確。
開源的QCustomPlot曲線圖表控件,支持的數據量還是挺大的,能到百萬級別,十幾萬幾十萬的數據一次性繪制,都還可以,繪制這塊已經優化到了極致,主要的速度占用應該是計算,繪制倒都是很快的,數據量很大的情況下一般不建議頻繁的繪制,會把UI卡主,任何開發工具和語言,UI都是在主線程,所以繪制這塊一旦太頻繁很可能導致卡主,如果數據量確實很多可以把運算這塊移到其他線程,運算好以后再一次性繪制。對于大數據量的繪制,還有個算法就是過濾掉取平均值數據,因為一個像素上繪制幾十上百個數據點是沒有意義的,都擠在一塊,人眼觀看都是一個問題,所以不如用算法將這些數據點經過一個規則運算合并成一個點數據,可以非常大的減少數據量,等到縮放的時候再自動還原之前的數據。
二、功能特點
三、體驗地址
四、效果圖
五、核心代碼
#include "frmplotdata.h" #include "ui_frmplotdata.h" #include "quihelper.h"frmPlotData::frmPlotData(QWidget *parent) : QWidget(parent), ui(new Ui::frmPlotData) {ui->setupUi(this);this->initForm();this->loadPlot(); }frmPlotData::~frmPlotData() {delete ui; }void frmPlotData::initForm() {//添加畫布ui->customPlot->addGraph(1);//設置拖動縮放模式ui->customPlot->setInteractions(3);//設置邊距ui->customPlot->setPadding(15);//設置數據點的大小ui->customPlot->setPointSize(0);//設置文本顏色ui->customPlot->setTextColor(Qt::white);//設置XY軸范圍值ui->customPlot->setRangeX(0, 1000, 15);ui->customPlot->setRangeY(0, 1000, 15);//綁定雙擊重新加載數據connect(ui->customPlot->getPlot(), SIGNAL(mouseDoubleClick(QMouseEvent *)), this, SLOT(loadPlot())); }void frmPlotData::loadPlot() {//從文本文件讀取數據 具體格式可以自行打開文件查看QString fileName = QString(":/image/data%1.txt").arg(rand() % 3);QFile file(fileName);if (file.open(QFile::ReadOnly | QIODevice::Text)) {QString value = file.readAll();file.close();vdouble keys, values;QStringList list = value.split(" ");int len = list.length();//如果不是2的倍數則長度要減去1if (len % 2 != 0) {len = (len - 1);}for (int i = 0; i < len / 2; i++) {keys.append(i);}//每兩個16進制數字組合成一個數字for (int i = 0; i < len; i = i + 2) {qint16 value = CustomPlotHelper::strHexToShort(QString("%1%2").arg(list.at(i)).arg(list.at(i + 1)));values.append(value);}LineData data;data.index = 0;data.name = "角度值";data.key = keys;data.value = values;//設置線條顏色,可以指定顏色也可以隨機顏色data.lineColor = CustomPlotHelper::getRandColor();data.scatterShape = 0;data.fillColor = 1;data.autoScale = true;ui->customPlot->setDataLine(data);ui->customPlot->replot();} }總結
以上是生活随笔為你收集整理的Qt编写可视化大屏电子看板系统21-数据转曲线的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 遇雨(随手记)
- 下一篇: 我的梦想是当一个计算机英语,我的梦想英语