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

news/2025/2/24 13:37:42

便携式动平衡仪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框架完善单元测试。

http://www.niftyadmin.cn/n/5864397.html

相关文章

NavVis VLX三维扫描:高层建筑数字化的革新力量【沪敖3D】

在三维激光扫描领域&#xff0c;楼梯结构因其复杂的空间形态和连续垂直移动的实际需求&#xff0c;一直是技术难点之一。利用NavVis VLX穿戴式移动扫描系统成功完成一栋34层建筑的高效扫描&#xff0c;其中楼梯部分的数据一遍成形且无任何分层或形变。本文将深入分析该项目的技…

python读取sqlite温度数据,并画出折线图

需求&#xff1a; 在Windows下请用python画出折线图&#xff0c;x轴是时间&#xff0c;y轴是温度temperature 和体感温度feels_like_temperature 。可以选择县市近1小时&#xff0c;近1天&#xff0c;近1个月的。sqlite文件weather_data.db当前目录下&#xff0c;建表结构如下…

【ubuntu24.04】pycharm安装pygraphviz

pip install pygraphviz 安装失败 (05_ep_dev) root@k8s-master-pfsrv:/home/zhangbin/perfwork/01_ai/05_ep_dev/expert/src/test/sumory# pip install pygraphviz Collecting pygraphviz Downloading pygraphviz-1.14.tar.gz (106 kB) Installing build dependencies … don…

网络传输的七层协议

网络传输的七层协议是 OSI模型&#xff08;开放系统互联模型&#xff09; 中的七个层次&#xff0c;每一层都负责不同的网络功能。具体如下&#xff1a; 物理层&#xff08;Physical Layer&#xff09; 负责在物理媒介上传输比特流&#xff0c;即将数据以电信号、光信号等形式在…

【框架】参考 Spring Security 安全框架设计出,轻量化高可扩展的身份认证与授权架构

关键字&#xff1a;AOP、JWT、自定义注解、责任链模式 一、Spring Security Spring Security 想必大家并不陌生&#xff0c;是 Spring 家族里的一个安全框架&#xff0c;特别完善&#xff0c;但学习成本比较大&#xff0c;不少开发者都觉得&#xff0c;这个框架“很重” 他的…

机器学习数学通关指南——牛顿-莱布尼茨公式

前言 本文隶属于专栏《机器学习数学通关指南》&#xff0c;该专栏为笔者原创&#xff0c;引用请注明来源&#xff0c;不足和错误之处请在评论区帮忙指出&#xff0c;谢谢&#xff01; 本专栏目录结构和参考文献请见《机器学习数学通关指南》 正文 一句话总结 ∫ a b f ( x ) …

【并发编程】线程池任务抛异常会怎么样?

一、先说结论 得看线程池的实现&#xff0c;JUC 的线程池&#xff08;ThreadPoolExecutor&#xff09;的话 不会影响其他的线程若是 submit 方法&#xff0c;或者任务为 future 任务&#xff0c;异常只有在 get 的时候才会抛出若是 execute runnable 任务&#xff0c;异常就…

DataWhale组队学习 wow-agent task4

整体概念总结 智能体的实现方法 安装与配置&#xff1a;安装和配置MetaGPT&#xff0c;包括Python环境的准备、MetaGPT的安装&#xff08;通过pip或git拉取代码&#xff09;&#xff0c;以及配置大模型API&#xff08;如智谱、科大讯飞、百度千帆等&#xff09;。 单动作单智能…