当前位置: 首页 > news >正文

便携式动平衡仪Qt应用层详细设计方案(基于Qt Widgets)


便携式动平衡仪Qt应用层详细设计方案(基于Qt Widgets)

版本:1.0
日期:2023年10月


一、系统概述

1.1 功能需求
  • 开机流程:长按电源键启动,全屏显示商标动画(快闪3~4次)。
  • 主界面:三栏布局(状态栏、工作区图标、导航栏),支持点击图标跳转。
  • 模板系统:保存/加载动平衡参数模板(.tpl文件),点击模板直接跳转至测量界面。
  • 实时显示:双圆形仪表盘(相位/角度)、数据表格、实时曲线。
1.2 技术选型
  • 开发框架:Qt 6.5 + Qt Widgets
  • 硬件平台:STM32MP157(Cortex-A7 + M4双核)
  • 界面设计工具:Qt Designer
  • 文件格式:JSON + AES加密

二、应用层架构设计

2.1 分层架构
+---------------------+
|     UI界面层         |  <- 使用Qt Designer设计的窗口和控件
+---------------------+
|   业务逻辑层         |  <- 模板管理、导航控制、数据处理
+---------------------+
|   硬件服务层         |  <- 与M4核通信(共享内存/IPC)、文件读写
+---------------------+
2.2 模块划分
模块功能关键类/组件
启动与主界面模块开机动画、主界面布局、图标响应SplashScreen MainWindow
导航管理模块页面堆栈控制(前进/后退)QStackedWidget NavigationManager
模板系统模块模板保存/加载、文件关联、桌面快捷方式生成TemplateManager QFileDialog
实时显示模块相位/角度仪表盘、数据表格、实时曲线PhaseMeterWidget DataTableView
配置模块平衡参数输入、传感器校准界面ConfigDialog CalibrationWizard

三、模块详细设计

3.1 启动与主界面模块
3.1.1 开机动画实现
// SplashScreen.cpp(继承QWidget)
void SplashScreen::showEvent(QShowEvent *event) {QPropertyAnimation *animation = new QPropertyAnimation(this, "opacity");animation->setDuration(1000);animation->setStartValue(1.0);animation->setEndValue(0.3);animation->setLoopCount(3); // 快闪3次animation->start(QAbstractAnimation::DeleteWhenStopped);
}
3.1.2 主界面布局(Qt Designer设计)
  1. Qt Designer设计文件MainWindow.ui

    • 顶部状态栏QStatusBar + QLabel(日期) + QProgressBar(电量)
    • 工作区图标网格QGridLayout + QPushButton(带图标)
    • 底部导航栏QHBoxLayout + QPushButton(前进/后退)
    // MainWindow.cpp(通过ui_MainWindow.h生成)
    void MainWindow::setupUi() {// 初始化网格布局(2行5列)QGridLayout *gridLayout = new QGridLayout(centralWidget);for (int i = 0; i < 8; i++) {QPushButton *btn = new QPushButton(this);btn->setIcon(QIcon(iconPaths[i]));gridLayout->addWidget(btn, i / 5, i % 5);}
    }
    
3.2 导航管理模块
3.2.1 页面堆栈控制
// NavigationManager.cpp
void NavigationManager::switchToPage(QWidget *page) {QStackedWidget *stack = qobject_cast<QStackedWidget*>(parent());if (!stack->children().contains(page)) {stack->addWidget(page);}stack->setCurrentWidget(page);
}
3.2.2 按钮事件绑定
// MainWindow.cpp
connect(ui->btn1Plane, &QPushButton::clicked, [=]{ConfigDialog *configDialog = new ConfigDialog(this);NavigationManager::switchToPage(configDialog);
});
3.3 模板系统模块
3.3.1 模板文件格式(JSON)
{"version": 1,"rpm": 3000,"plane_mode": 1,"calibration": { "sensor_id": "SENSOR_001", "offset": 0.12 }
}
3.3.2 模板加载与文件关联
// TemplateManager.cpp
void TemplateManager::loadTemplate(const QString &path) {QFile file(path);if (!file.open(QIODevice::ReadOnly)) return;QByteArray data = file.readAll();QJsonDocument doc = QJsonDocument::fromJson(decryptData(data));BalanceTemplate tpl = parseJson(doc);emit templateLoaded(tpl); // 触发界面跳转
}// 文件关联(双击事件)
void FileBrowser::onFileDoubleClicked(const QString &path) {if (path.endsWith(".tpl")) {TemplateManager::instance()->loadTemplate(path);NavigationManager::switchToPage(new BalancePage());}
}
3.4 实时显示模块
3.4.1 自定义仪表盘控件
// PhaseMeterWidget.cpp(继承QWidget)
void PhaseMeterWidget::paintEvent(QPaintEvent*) {QPainter painter(this);painter.setRenderHint(QPainter::Antialiasing);painter.setPen(QPen(Qt::red, 8));painter.drawArc(rect(), 90*16, -angle*16); // 角度转换为十六分一度
}
3.4.2 数据表格动态更新
// DataTableView.cpp(继承QTableWidget)
void DataTableView::updateData(const QVector<double> &data) {for (int i = 0; i < data.size(); i++) {QTableWidgetItem *item = new QTableWidgetItem(QString::number(data[i]));setItem(i, 0, item);}
}

四、接口定义与数据流

4.1 硬件服务层接口
接口名称功能实现方式
readSensorData()从M4核读取实时振动数据共享内存 + 互斥锁
saveToFile()保存测量结果到CSV文件QFile + QTextStream
4.2 共享内存通信(A7与M4核)
// SharedData.h
struct SharedData {volatile float phase;volatile float amplitude;pthread_mutex_t lock;
};

五、代码框架与实现

5.1 项目目录结构
项目根目录/
├── src/
│   ├── main.cpp                  # 应用入口
│   ├── ui/
│   │   ├── MainWindow.ui         # 主界面设计文件
│   │   ├── ConfigDialog.ui       # 配置界面设计文件
│   │   └── BalancePage.ui        # 测量界面设计文件
│   ├── core/
│   │   ├── TemplateManager.cpp   # 模板管理逻辑
│   │   └── NavigationManager.cpp # 导航控制
│   ├── widgets/
│   │   ├── PhaseMeterWidget.cpp  # 自定义仪表盘
│   │   └── DataTableView.cpp     # 数据表格
├── resources/
│   ├── icons.qrc                 # 图标资源
│   └── styles/                   # QSS样式表
└── CMakeLists.txt                # 构建配置
5.2 核心代码实现
5.2.1 主程序入口(main.cpp)
int main(int argc, char *argv[]) {QApplication app(argc, argv);// 初始化共享内存SharedData *sharedData = SharedMemory::init();// 加载主窗口MainWindow mainWindow;mainWindow.show();return app.exec();
}
5.2.2 主窗口初始化(MainWindow.cpp)
MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent) {setupUi(this); // 加载MainWindow.ui// 初始化堆栈窗口stackedWidget = new QStackedWidget(this);setCentralWidget(stackedWidget);// 预加载页面stackedWidget->addWidget(new ConfigDialog(this));stackedWidget->addWidget(new BalancePage(this));
}

六、测试计划

6.1 单元测试用例
测试项输入预期输出
模板加载功能合法.tpl文件参数解析正确,跳转至测量界面
实时数据显示模拟10kHz数据流界面刷新率≥30 FPS
6.2 自动化测试脚本
# 使用PySide6进行界面自动化测试
def test_main_window(qtbot):window = MainWindow()qtbot.mouseClick(window.btn1Plane, Qt.LeftButton)assert window.stackedWidget.currentWidget() is ConfigDialog

七、详细设计说明书(DDD)

7.1 系统概述
  • 目标:实现便携式动平衡仪的图形化操作与实时数据处理。
  • 运行环境:STM32MP157 + Linux 5.15,10英寸触控屏。
7.2 模块设计
  • 启动模块:通过QPropertyAnimation实现快闪动画。
  • 模板模块:使用AES-256加密模板文件,支持双击加载。
  • 实时显示模块:自定义QWidget绘制仪表盘,QTimer定时刷新数据。
7.3 接口定义
  • 硬件接口:通过共享内存与M4核交换数据(SharedData结构体)。
  • 文件接口QFileDialog选择文件,QJsonDocument解析数据。
7.4 性能优化
  • 双缓冲绘图:避免仪表盘闪烁。
  • 线程分离:UI线程与数据处理线程通过信号槽通信。

八、总结

本方案基于 Qt Widgets 实现,完整覆盖用户需求:

  1. 开发效率:通过Qt Designer快速设计界面,减少手写布局代码。
  2. 性能保障:自定义控件优化渲染效率,共享内存实现低延迟通信。
  3. 可维护性:模块化设计,业务逻辑与界面分离。

下一步建议

  • 使用Qt的QSS样式表统一界面风格。
  • 结合QTest框架完善单元测试。

相关文章:

便携式动平衡仪Qt应用层详细设计方案(基于Qt Widgets)

便携式动平衡仪Qt应用层详细设计方案&#xff08;基于Qt Widgets&#xff09; 版本&#xff1a;1.0 日期&#xff1a;2023年10月 一、系统概述 1.1 功能需求 开机流程&#xff1a;长按电源键启动&#xff0c;全屏显示商标动画&#xff08;快闪3~4次&#xff09;。主界面&…...

SpringBoot源码解析(十一):准备应用上下文

SpringBoot源码系列文章 SpringBoot源码解析(一)&#xff1a;SpringApplication构造方法 SpringBoot源码解析(二)&#xff1a;引导上下文DefaultBootstrapContext SpringBoot源码解析(三)&#xff1a;启动开始阶段 SpringBoot源码解析(四)&#xff1a;解析应用参数args Sp…...

CSS 使用white-space属性换行

一、white-space属性的常见值 * 原本格式&#xff1a; 1、white-space:normal 默认值&#xff0c;空格和换行符会被忽略过滤掉&#xff1b;宽度不够时文本会自动换行 * 宽度足够时&#xff0c;normal 处理后的格式 * 宽度不够时&#xff0c; normal 处理后的格式 2、white-spa…...

论文笔记(七十二)Reward Centering(四)

Reward Centering&#xff08;四&#xff09; 文章概括摘要附录A 伪代码 文章概括 引用&#xff1a; article{naik2024reward,title{Reward Centering},author{Naik, Abhishek and Wan, Yi and Tomar, Manan and Sutton, Richard S},journal{arXiv preprint arXiv:2405.09999…...

Matlab——图像保存导出成好看的.pdf格式文件

点击图像的右上角&#xff0c;点击第一个保存按钮键。...

官方文档学习TArray容器

一.TArray中的元素相等 1.重载一下 元素中的 运算符&#xff0c;有时需要重载排序。接下来&#xff0c;我们将id 作为判断结构体的标识。 定义结构体 USTRUCT() struct FXGEqualStructInfo {GENERATED_USTRUCT_BODY() public:FXGEqualStructInfo(){};FXGEqualStructInfo(in…...

unxi-进程间通信

1.进程间通信实现方式 【1】同一主机 linux下通信方式: a.传统的进程间通信方式 管道 --- 进行数据传输的"管道" 无名管道 有名管道 信号 --- b.system v 进程间通信 (posix 进程间通信) 共享内存 (进程间…...

微型分组加密算法TEA、XTEA、XXTEA

微型分组加密算法TEA、XTEA、XXTEA TEA&#xff08;Tiny Encryption Algorithm&#xff09;算法是一种分组加密算法&#xff0c;由剑桥大学计算机实验室的‌David Wheeler和‌Roger Needham于1994年发明。TEA、XTEA、XXTEA算法采用64位的明文分组和128位的密钥。它使用Feistel…...

conda 基本命令

1、查询当前所有的环境 conda env list 2、创建虚拟环境 conda create -n 环境名 [pythonpython版本号] 其中[pythonpython版本号]可以不写 conda create -n test python3.12 我们输入conda env list看到我们的环境创建成功了&#xff0c;但是发现他是创建在我们默认的C盘的…...

详解 为什么 tcp 会出现 粘包 拆包 问题

TCP 会出现 粘包 和 拆包 问题&#xff0c;主要是因为 TCP 是 面向字节流 的协议&#xff0c;它不关心应用层发送的数据是否有边界&#xff0c;也不会自动分割或合并数据包。由于 TCP 的流控制和传输机制&#xff0c;数据可能在传输过程中被拆分成多个小的 TCP 包&#xff0c;或…...

Linus的基本命令

以下是一些常见的 Linux 命令&#xff1a; 一、文件和目录操作&#xff1a; - ls&#xff1a;列出目录中的文件和子目录&#xff0c;常用参数有 -a &#xff08;显示所有文件&#xff0c;包括隐藏文件&#xff09;、 -l &#xff08;显示详细信息&#xff09;、 -h &#xff0…...

【Linux】缓冲区和文件系统

个人主页~ 缓冲区和文件系统 一、FILE结构1、fd2、缓冲区&#xff08;一&#xff09;有换行有return全部打印&#xff08;二&#xff09;无换行无return的C接口打印&#xff08;三&#xff09;无换行无return的系统调用接口打印&#xff08;四&#xff09;有换行无return的C接口…...

函数式编程:概念、特性与应用

1. 函数式编程简介 函数式编程&#xff0c;从名称上看就与函数紧密相关。它是一种我们常常使用却可能并未意识到的编程范式&#xff0c;关注代码的结构组织&#xff0c;强调一个纯粹但在实际中有些理想化的不可变世界&#xff0c;涉及数学、方程和副作用等概念&#xff0c;甚至…...

git中的merge和rebase的区别

在 Git 中&#xff0c;git merge 和 git rebase 都是用于整合分支变更的核心命令&#xff0c;但它们的实现方式和结果有本质区别。以下是两者的详细对比&#xff1a; 一、核心区别 特性git mergegit rebase历史记录保留分支拓扑&#xff0c;生成新的合并提交线性化历史&#x…...

【目标检测】目标检测中的数据增强终极指南:从原理到实战,用Python解锁模型性能提升密码(附YOLOv5实战代码)

&#x1f9d1; 博主简介&#xff1a;曾任某智慧城市类企业算法总监&#xff0c;目前在美国市场的物流公司从事高级算法工程师一职&#xff0c;深耕人工智能领域&#xff0c;精通python数据挖掘、可视化、机器学习等&#xff0c;发表过AI相关的专利并多次在AI类比赛中获奖。CSDN…...

uniapp在app下使用mqtt协议!!!支持vue3

什么&#xff1f;打包空白&#xff1f;分享一下我的解决方法&#xff01; 第一步 找大师算过了&#xff0c;装4.1版本运气好&#xff01; 所以根目录执行命令… npm install mqtt4.1.0第二步 自己封装一个mqtt文件方便后期开坛做法&#xff01; // utils/mqtt.js import mqt…...

VMware虚拟机17.5.2版本下载与安装(详细图文教程包含安装包)

文章目录 前言一、vmware虚拟机下载二、vmware虚拟机安装教程三、vmware虚拟机许可证 前言 VMware Workstation Pro 17 功能强大&#xff0c;广受青睐。本教程将带你一步步完成它的安装&#xff0c;简单易上手&#xff0c;助你快速搭建使用环境。 一、vmware虚拟机下载 VMwar…...

如何加固织梦CMS安全,防webshell、防篡改、防劫持,提升DedeCMS漏洞防护能力

织梦系统&#xff08;DedeCMS&#xff09;是一款非常知名的CMS系统&#xff0c;因其功能强大、结构科学合理&#xff0c;深受广大用户喜欢。 虽然织梦CMS&#xff08;DedeCMS&#xff09;非常优秀&#xff0c;但是为了保障网站安全&#xff0c;我们还是需要做一些必要的防护措…...

STM32的HAL库开发---ADC采集内部温度传感器

一、STM32内部温度传感器简介 二、温度计算方法 F1系列&#xff1a; 从数据手册中可以找到V25和Avg_Slope F4、F7、H7系列只是标准值不同&#xff0c;自行查阅手册 三、实验简要 1、功能描述 通过ADC1通道16采集芯片内部温度传感器的电压&#xff0c;将电压值换算成温度后&…...

Linux 命令大全完整版(12)

Linux 命令大全 5. 文件管理命令 ln(link) 功能说明&#xff1a;连接文件或目录。语  法&#xff1a;ln [-bdfinsv][-S <字尾备份字符串>][-V <备份方式>][--help][--version][源文件或目录][目标文件或目录] 或 ln [-bdfinsv][-S <字尾备份字符串>][-V…...

web vue 项目 Docker化部署

Web 项目 Docker 化部署详细教程 目录 Web 项目 Docker 化部署概述Dockerfile 详解 构建阶段生产阶段 构建和运行 Docker 镜像 1. Web 项目 Docker 化部署概述 Docker 化部署的主要步骤分为以下几个阶段&#xff1a; 构建阶段&#xff08;Build Stage&#xff09;&#xff1a…...

uni-app学习笔记二十二---使用vite.config.js全局导入常用依赖

在前面的练习中&#xff0c;每个页面需要使用ref&#xff0c;onShow等生命周期钩子函数时都需要像下面这样导入 import {onMounted, ref} from "vue" 如果不想每个页面都导入&#xff0c;需要使用node.js命令npm安装unplugin-auto-import npm install unplugin-au…...

关于nvm与node.js

1 安装nvm 安装过程中手动修改 nvm的安装路径&#xff0c; 以及修改 通过nvm安装node后正在使用的node的存放目录【这句话可能难以理解&#xff0c;但接着往下看你就了然了】 2 修改nvm中settings.txt文件配置 nvm安装成功后&#xff0c;通常在该文件中会出现以下配置&…...

剑指offer20_链表中环的入口节点

链表中环的入口节点 给定一个链表&#xff0c;若其中包含环&#xff0c;则输出环的入口节点。 若其中不包含环&#xff0c;则输出null。 数据范围 节点 val 值取值范围 [ 1 , 1000 ] [1,1000] [1,1000]。 节点 val 值各不相同。 链表长度 [ 0 , 500 ] [0,500] [0,500]。 …...

苍穹外卖--缓存菜品

1.问题说明 用户端小程序展示的菜品数据都是通过查询数据库获得&#xff0c;如果用户端访问量比较大&#xff0c;数据库访问压力随之增大 2.实现思路 通过Redis来缓存菜品数据&#xff0c;减少数据库查询操作。 缓存逻辑分析&#xff1a; ①每个分类下的菜品保持一份缓存数据…...

基于Docker Compose部署Java微服务项目

一. 创建根项目 根项目&#xff08;父项目&#xff09;主要用于依赖管理 一些需要注意的点&#xff1a; 打包方式需要为 pom<modules>里需要注册子模块不要引入maven的打包插件&#xff0c;否则打包时会出问题 <?xml version"1.0" encoding"UTF-8…...

JDK 17 新特性

#JDK 17 新特性 /**************** 文本块 *****************/ python/scala中早就支持&#xff0c;不稀奇 String json “”" { “name”: “Java”, “version”: 17 } “”"; /**************** Switch 语句 -> 表达式 *****************/ 挺好的&#xff…...

基于IDIG-GAN的小样本电机轴承故障诊断

目录 🔍 核心问题 一、IDIG-GAN模型原理 1. 整体架构 2. 核心创新点 (1) ​梯度归一化(Gradient Normalization)​​ (2) ​判别器梯度间隙正则化(Discriminator Gradient Gap Regularization)​​ (3) ​自注意力机制(Self-Attention)​​ 3. 完整损失函数 二…...

云原生周刊:k0s 成为 CNCF 沙箱项目

开源项目推荐 HAMi HAMi&#xff08;原名 k8s‑vGPU‑scheduler&#xff09;是一款 CNCF Sandbox 级别的开源 K8s 中间件&#xff0c;通过虚拟化 GPU/NPU 等异构设备并支持内存、计算核心时间片隔离及共享调度&#xff0c;为容器提供统一接口&#xff0c;实现细粒度资源配额…...

数据库——redis

一、Redis 介绍 1. 概述 Redis&#xff08;Remote Dictionary Server&#xff09;是一个开源的、高性能的内存键值数据库系统&#xff0c;具有以下核心特点&#xff1a; 内存存储架构&#xff1a;数据主要存储在内存中&#xff0c;提供微秒级的读写响应 多数据结构支持&…...