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

Qt动态生成 UI

动态生成 UI

  • 1. 创建UI
    • 1.1 窗口样式创建
      • 核心分类
      • 使用
      • 相关函数
  • 2. 获取UI对象
    • 2.1 通过objectName获取控件
      • 使用QObject::findChild()(推荐)
      • 使用QObject::findChildren()(批量查找)
      • 全局查找(通过QApplication::allWidgets())
      • 使用

1. 创建UI

1.1 窗口样式创建

Qt::WindowType 是 Qt 框架中用于定义窗口行为和外观的枚举类型,通过设置不同的标志(Flag),可以控制窗口的样式、模态性、父窗口关系等。

核心分类

//窗口类型标识
Qt::Window          // 独立窗口(默认有标题栏和边框)
Qt::Dialog          // 对话框窗口(通常无边框,有关闭按钮)
Qt::Sheet           // macOS 风格的工作表窗口
Qt::Drawer          // macOS 风格的抽屉窗口
Qt::Popup           // 弹出窗口(无边框,点击外部自动关闭)
Qt::Tool            // 工具窗口(标题栏更简洁)
Qt::ToolTip         // 工具提示窗口(无边框,无焦点)
Qt::SplashScreen    // 启动画面(无边框,无按钮)
Qt::Desktop         // 桌面窗口
Qt::SubWindow       // 子窗口(如 MDI 应用中的内部窗口)//窗口提示标志
Qt::WindowTitleHint          // 显示标题栏
Qt::WindowSystemMenuHint     // 显示系统菜单
Qt::WindowMinimizeButtonHint // 显示最小化按钮
Qt::WindowMaximizeButtonHint // 显示最大化按钮
Qt::WindowCloseButtonHint    // 显示关闭按钮
Qt::WindowContextHelpButtonHint // 显示帮助按钮
Qt::WindowStaysOnTopHint     // 窗口始终置顶
Qt::WindowStaysOnBottomHint  // 窗口始终置底
Qt::CustomizeWindowHint      // 自定义窗口装饰(需配合其他标志)//特殊行为标志
Qt::FramelessWindowHint      // 无边框窗口
Qt::WindowFullscreen         // 全屏窗口
Qt::WindowMaximized          // 最大化窗口
Qt::WindowMinimized          // 最小化窗口
Qt::WindowShadeButtonHint    // 显示阴影按钮(用于折叠窗口)
Qt::WindowTransparentForInput // 窗口不接收输入事件
Qt::WindowOverridesSystemGestures // 覆盖系统手势

使用

  • 窗口构造时设置
#include <QDialog>class MyDialog : public QDialog {
public:MyDialog(QWidget *parent = nullptr) : QDialog(parent) {// 设置为无边框的弹出窗口setWindowFlags(Qt::Popup | Qt::FramelessWindowHint);}
};
  • 动态修改窗口标志
// 切换为全屏模式
void setFullscreen(bool fullscreen) {if (fullscreen) {setWindowFlags(windowFlags() | Qt::WindowFullscreen);} else {setWindowFlags(windowFlags() & ~Qt::WindowFullscreen);}show();  // 必须调用show()使标志生效
}

相关函数

函数作用
setWindowFlags(Qt::WindowFlags flags)设置窗口标志
windowFlags() const获取当前窗口标志
setWindowModality(Qt::WindowModality modality)设置窗口模态性(阻塞其他窗口)
isWindow() const判断是否为独立窗口

2. 获取UI对象

2.1 通过objectName获取控件

使用QObject::findChild()(推荐)

template <typename T>
T QObject::findChild(const QString &name = QString(),Qt::FindChildOptions options = Qt::FindChildrenRecursively) const
  • 参数说明:
  1. name:控件的objectName(空字符串表示匹配所有名称)。
  2. options:查找选项(递归查找或仅直接子控件)。
#include <QPushButton>
#include <QDebug>// 在QWidget或QMainWindow的子类中
void MyWidget::findButton() {// 查找名称为"myButton"的QPushButtonQPushButton *button = findChild<QPushButton*>("myButton");if (button) {button->setText("Found!");qDebug() << "找到按钮:" << button->objectName();} else {qDebug() << "未找到按钮";}
}

使用QObject::findChildren()(批量查找)

template <typename T>
QList<T> QObject::findChildren(const QString &name = QString(),Qt::FindChildOptions options = Qt::FindChildrenRecursively) const
// 查找所有名称以"edit"开头的QLineEdit
QList<QLineEdit*> editList = findChildren<QLineEdit*>(QRegularExpression("^edit"));
foreach (QLineEdit *edit, editList) {edit->setReadOnly(true);
}

全局查找(通过QApplication::allWidgets())

#include <QApplication>// 查找整个应用程序中名称为"mainWindow"的主窗口
QMainWindow *mainWindow = nullptr;
foreach (QWidget *widget, qApp->allWidgets()) {if (widget->objectName() == "mainWindow" && qobject_cast<QMainWindow*>(widget)) {mainWindow = qobject_cast<QMainWindow*>(widget);break;}
}

使用

// 在UI文件中设置了objectName为"usernameEdit"的QLineEdit
QLineEdit *usernameEdit = findChild<QLineEdit*>("usernameEdit");
if (usernameEdit) {usernameEdit->setPlaceholderText("请输入用户名");
}// 查找所有QPushButton并设置样式
QList<QPushButton*> buttons = findChildren<QPushButton*>();
foreach (QPushButton *button, buttons) {button->setStyleSheet("background-color: #4CAF50; color: white;");
}
  • 若不需要直接访问控件对象,可通过信号与槽机制实现松耦合:
// 在UI设计时连接信号与槽,无需手动查找控件
connect(ui->myButton, &QPushButton::clicked, this, &MyWidget::onButtonClicked);
http://www.xdnf.cn/news/7637.html

相关文章:

  • 动易私有知识库解决方案技术解析
  • 如何在WordPress网站上添加即时聊天功能
  • 游戏开发实战(三):Python复刻「崩坏星穹铁道」嗷呜嗷呜事务所---源码级解析该小游戏背后的算法与设计模式【纯原创】
  • 25.5.20学习总结
  • 算法与数据结构:质数、互质判定和裴蜀定理
  • Android 蓝牙开发 - 蓝牙相关权限(蓝牙基本权限、Android 12 蓝牙新增权限、位置权限)
  • matlab+opencv车道线识别
  • 目标检测DN-DETR(2022)详细解读
  • mysql的乐观锁与悲观锁
  • USB转TTL
  • 邂逅Node.js
  • 深度解析:AI知识库与LLM开发工具全景对比
  • Python基础学习-Day30
  • 基于R语言的贝叶斯网络建模:生态与环境因果推断实践
  • Mac如何允许安装任何来源软件?
  • srs-7.0 支持obs推webrtc流
  • LLM驱动下的软件工程再造:驾驭调试、测试与工程化管理的智能新范式
  • 高阶数据结构——AVL树的实现(详细解答)
  • vuejs处理后端返回数字类型精度丢失问题
  • ArcGIS操作16:添加经纬网
  • esp12f-实现远程控制
  • FPGA:基于Vivado的仿真流程与波形调试实践
  • 快速搭建DeepSeek本地RAG应用 - 超详细指南
  • AI无法解决的Bug系列(一)跨时区日期过滤问题
  • 【Code】Foundations 2017- Catalogue, List of Tables, List of Figures
  • 【Tools】neovim操作指南
  • 【nRF9160 常用prj.conf配置与AT指令介绍】
  • 建筑设备分散管理痛点如何解?楼宇自控系统给出破局之道
  • 编程日志5.13
  • 2025.05.20【Treemap】树图数据可视化技巧