日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > windows >内容正文

windows

Qt编写可视化大屏电子看板系统14-标准曲线图

發布時間:2023/12/8 windows 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Qt编写可视化大屏电子看板系统14-标准曲线图 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、前言

近期將可視化大屏電子看板系統重新規劃和調整項目結構代碼,幾個重大改變是新增啟動窗體選擇,可選大屏系統、控件演示、模塊演示三種,其中控件演示是專門針對本系統中用到的各種自定義控件單獨做的使用demo,模塊演示是專門針對本系統中每個子模塊單獨演示,這樣可以更方便的切換學習,而不是盲目的在項目代碼中找,可以直接快速切換定位到具體的代碼文件學習。

大屏系統中用到的曲線圖柱狀圖都是在開源的QCustomPlot曲線圖表控件基礎上二次開發改造的,最基礎的曲線展示莫過于標準曲線圖了,QCustomPlot官方一直在更新升級代碼,本人也是一直看著QCustomPlot長大的,代碼質量真的沒的說,后期的代碼更加完美,尤其是增加了更多的模塊接口,比如曲線提示標識可以指定列,XY軸可以互換,這樣就可以很方便的垂直的效果轉成平行的效果尤其是柱狀圖。

在大屏系統中需要展示的曲線會有多條,都要求不同的曲線不同的顏色區分顯示,數據都是通過數據源采集好以后的靜態數據,每次都是整體重新設置數據,其實在這種數據量很小的情況下,重新繪制和追加數據繪制效率沒區別,都是需要重新繪制整個畫布。默認XY軸都是浮點數顯示,可以通過label映射換成對應的文本值顯示,本系統中全部是換成了文本型數值顯示,更靈活,比如對應坐標點X軸1/2/3換成1月、2月、3月這種文字顯示,Y軸的數據還可以后面加上百分比符號等。

二、功能特點

  • 采用分層設計,整體總共分三級界面,一級界面是整體布局,二級界面是單個功能模塊,三級界面是單個控件。
  • 子控件包括餅圖、圓環圖、曲線圖、柱狀圖、柱狀分組圖、橫向柱狀圖、橫向柱狀分組圖、合格率控件、百分比控件、進度控件、設備狀態面板、表格數據、地圖控件、視頻控件等。
  • 二級界面可以自由拖動懸浮,支持最小化隱藏、最大化關閉、響應雙擊自定義標題欄。
  • 數據源支持模擬數據(默認)、數據庫采集、串口通信(需定制)、網絡通信(需定制)、網絡請求等,可自由設定每個子界面的采集間隔即數據刷新頻率。
  • 采用純QWidget編寫,親測Qt4.6到Qt6.2任意版本,理論上支持后續其他Qt版本。
  • 超強跨平臺,親測windows、linux、mac、國產uos、國產銀河麒麟kylin等系統,效果完美,同時還支持嵌入式linux比如樹莓派、香橙派、全志、imx6等。
  • 同時集成了自定義控件、qchart餅圖、echart地圖等功能。
  • 內置多套配色風格樣式(紫色、藍色、深藍、黑色),默認紫色,自適應任意分辨率。
  • 可設置系統標題、目標分辨率、布局方案,啟動立即應用。
  • 可設置主背景顏色、面板顏色、十字線游標顏色等各種顏色。
  • 可設置多條曲線不同顏色,沒有設置顏色的情況下內置多套精美顏色隨機應用。
  • 可設置標題欄背景顏色、文字顏色。
  • 可設置曲線圖表背景顏色、文字顏色、網格顏色。
  • 可設置正常顏色、警戒顏色、報警顏色、禁用顏色、百分比進度顏色。
  • 可分別設置各種字體大小,比如全局字體、軟件名稱、標題欄、子標題欄、加粗標簽等。
  • 可設置標題欄高度、表頭高度、行高度。
  • 曲線支持游標、定位線、懸停高亮數據點、懸停顯示值。
  • 柱狀圖支持頂部(可設置頂端、上部、中間、底部)顯示數據,全部自適應計算位置。
  • 支持平滑曲線,內置多種平滑曲線算法,還支持面積圖平滑。
  • 面積圖填充顏色可選多種規則比如單色透明度填充、透明度漸變填充等。
  • 數據庫支持sqlite、mysql、postgresql、oracle、國產人大金倉等數據庫。
  • 主界面直接鼠標右鍵切換布局、配色方案、關閉開啟某個二級窗體。
  • 自動記憶所有子窗口的大小和位置,下次啟動立即應用。
  • 動態加載布局方案菜單,可以動態新建布局、恢復布局、保存布局、另存布局等,用戶可以制造任意布局。
  • 二級窗體,雙擊從主窗體分離出來浮動,可以自由調整大小。再次雙擊標題欄最大化,再次雙擊還原。
  • 子模塊也可以全屏顯示作為一個大屏,這樣就可以一個大屏拓展出多個子大屏,放大查看子模塊的數據詳情,適用多屏展示。
  • 每個模塊都可以自定義采集速度,如果是數據庫采集會自動排隊處理,后期還可以拓展每個子模塊都獨立的數據庫采集。
  • 提供系統設置模塊進行整體的配置參數設置,效果立即應用。
  • 提供精美炫酷的大屏地圖模塊,包括靜態圖片、閃爍效果、遷徙效果、世界地圖、區域地圖等,可指定點的經緯度坐標,識別單擊響應,可以做地圖跳轉等,每個點都可以不同的顏色和提示信息。
  • 除了提供大屏系統外,還將每個模塊都做了獨立的模塊示例界面,每個模塊都可以獨立學習使用,里面用到的控件也單獨做了控件示例界面,方便學習每個控件如何使用。
  • 非常詳細的開發和使用手冊,其中包括數據庫說明、模塊對照圖、控件對照圖、項目結構、代碼說明(精確到每個類)、演示demo、使用方法等。
  • 三、體驗地址

  • 體驗地址:https://pan.baidu.com/s/1d7TH_GEYl5nOecuNlWJJ7g 提取碼:01jf 文件名:bin_bigscreen.zip。
  • 國內站點:https://gitee.com/feiyangqingyun
  • 國際站點:https://github.com/feiyangqingyun
  • 個人主頁:https://blog.csdn.net/feiyangqingyun
  • 知乎主頁:https://www.zhihu.com/people/feiyangqingyun/
  • 在線文檔:https://feiyangqingyun.gitee.io/qwidgetdemo/bigscreen/
  • 四、效果圖

    五、核心代碼

    #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() {//設置線條名稱,如果要增加線條 只需要這里增加線條名字就行lineNames << "新模" << "修模" << "設變" << "測試" << "哈哈";//隱藏表格線//ui->customPlot->getPlot()->xAxis->grid()->setVisible(false);//ui->customPlot->getPlot()->yAxis->grid()->setVisible(false);//添加畫布ui->customPlot->addGraph(lineNames.count());//設置畫布邊距ui->customPlot->setPadding(9); //設置可拖動鼠標滾輪縮放ui->customPlot->setInteractions(3);//設置圖例可見ui->customPlot->setLegend(true, 0, lineNames.count());//綁定雙擊重新加載數據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;//挨個對每條線段的數據賦值for (int j = 0; j < count; ++j) {values[j] << CustomPlotHelper::getRandValue(10, 100);}}//如果需要設置掃點圖則設置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);//設置線條顏色,可以指定顏色也可以隨機顏色data.lineColor = ui->customPlot->getColors().at(i);ui->customPlot->setDataLine(data);}//設置坐標軸范圍值+X坐標對應顯示文字ui->customPlot->setLabX(key, lab);ui->customPlot->setRangeX(-0.5, key.count() - 0.5);ui->customPlot->setRangeY(0, 120, 10);//初始化指示器數據高亮及懸停提示等ui->customPlot->initItem();//重新刷新顯示ui->customPlot->replot(); }

    總結

    以上是生活随笔為你收集整理的Qt编写可视化大屏电子看板系统14-标准曲线图的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。