把其他.ui文件拿到我的工程中使用

在Qt工程中使用工程外的ui文件的方式:作为一个类直接使用、包含到自己的类中或继承使用
将ui文件添加到工程中,作为一个类以直接使用

复制代码
注:这里指使用原本不属于该工程的ui文件

第一步:在工程文件.pro中添加UI文件

在.proj文件中添加:

复制代码
FORMS += PATH/ui_file_1.ui  \
         PATH/ui_file_2.ui
         
FORMS表示添加ui文件到本工程中
对于多个UI文件,使用续航符'\'来连接多行

注意:应该对UI文件执行uic命令,以生成UI对应的.h文件,在.h文件中有命名空间Ui及其内部包含的ui类名称,这个命名空间和类名称可以在源文件中用来引用UI对象
第二步:在代码中引用UI文件对象

复制代码
class MyClass : public QWidget
{
    Q_OBJECT
public:
    MyClass();

private:
    Ui_Foo ui;
};

第二步:在该类的构造函数中setupUi()

复制代码
MyClass::MyClass(QWidget* parent) : QWidget(parent)
{
    ui.setupUi(this);   //初始化并加载ui文件
    ...;
}

**实质:将UI文件对应的ui类(通过uic工具从ui文件转得.h文件)包含到自己的类里面作为private成员来使用

继承ui对象

注意:一般来说,为了软件架构良好设计,一般不使用多继承(避免耦合、复杂性等),非用不可,应该考虑使用多次单继承来替代。

复制代码
当类继承了ui类后,由于本身需要继承QWidget等类,因此为多继承。**

第一步:在自定义的类中继承Ui类

注意:Qt多继承必须将Qt库的类放到第一个,因为Qt默认要求第一个类为QObject的子类

复制代码
class MyClass : public QWidget , public Ui_Foo  //多重继承
{
    Q_OBJECT
public:
    MyCLass(QWidget * parent = 0);
...
};

第二步:在构造函数中增加ui.setupUi(this)初始化Ui文件
由于继承了Ui类,即Ui类的所有方法被继承,可以直接使用而不用加上实例名称:如使用setupUi(this)而不是ui.setupUi(this)。

总结

都需要利用uic文件来将ui文件转换为C++源文件

都是通过ui类来引用UI文件对象

都需要在工程文件.pro中添加FORMS表示添加ui文件

复制代码
                        版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

原文链接:https://blog.csdn.net/realdonaldtrump/article/details/78212095

相关推荐
北极糊的狐23 分钟前
光标放在引入的xxx组件行(import { xxx } from ‘element-ui‘;)出现标黄,显示报错:无法解析符号 ‘xxx‘ 解决办法
ui
子春一1 小时前
Flutter for OpenHarmony:构建一个 Flutter 习惯打卡应用,深入解析周视图交互、连续打卡逻辑与状态驱动 UI
flutter·ui·交互
我的xiaodoujiao2 小时前
使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 44--将自动化测试结果自动推送至钉钉工作群聊
前端·python·测试工具·ui·pytest
从此不归路3 小时前
Qt5 进阶【13】桌面 Qt 项目架构设计:从 MVC/MVVM 到模块划分
开发语言·c++·qt·架构·mvc
UI设计兰亭妙微4 小时前
UI 设计新范式:从国际案例看体验与商业的融合之道
人工智能·ui·b端设计
子春一4 小时前
Flutter for OpenHarmony:构建一个 Flutter 天气卡片组件,深入解析动态 UI、响应式布局与语义化设计
javascript·flutter·ui
雨季6664 小时前
Flutter 三端应用实战:OpenHarmony “极简文本行数统计器”
开发语言·前端·flutter·ui·交互
布兰妮甜4 小时前
Photoshop中通过图层混合模式实现图像元素透明度渐变过渡的完整指南
人工智能·ui·生活·photoshop·文化
AIGCmitutu4 小时前
Photoshop抠图插件2026选择指南,Ps抠图插件哪个好用?
人工智能·ui·ai绘画·photoshop·ps
雨季6664 小时前
Flutter 三端应用实战:OpenHarmony 简易“动态字体大小调节器”交互模式深度解析
开发语言·flutter·ui·交互·dart