Qt4中ui文件深度解析与使用技巧

需积分: 10 6 下载量 59 浏览量 更新于2024-09-14 收藏 31KB DOC 举报
在Qt4中,ui文件的使用方法相较于Qt3发生了显著变化,设计师工具(Designer)的角色被重新定位为纯粹的界面设计工具,不再承担工程管理功能。这是Trolltech的战略调整,旨在区分设计和工程管理,为后续的Qt Creator等工具铺平道路。 使用ui文件的第一步是通过Qt Designer创建所需的界面,并将其保存为myform.ui或其他自定义名称,例如MyCustomForm.ui。在设计过程中,关键点需要注意: 1. 保存ui文件的名称至关重要,因为UIC编译器会根据这个名字生成相应的头文件,如ui_myform.h。确保文件名的唯一性有助于代码的组织和查找。 2. 主窗口的objectname(控件标识符)同样重要,因为ui文件提供的类名将基于这个名称。正确的objectname不仅方便代码编写,还能确保在后续代码中的引用准确无误。 3. 选择与代码中窗体类相匹配的基础类是非常重要的。不兼容的基类可能导致编译错误或功能实现问题。 4. 对于需要在代码中访问的控件,确保给予它们有意义且易记的objectname。这样有助于提升代码的可读性和维护性。 除了文档中提供的详细指南,实践中还有些隐藏的细节需要关注,比如正确处理控件信号和槽函数的连接,以及如何在MVC模式下管理和调用ui组件。在实际应用中,可能还需要了解如何导入ui文件到工程中,如何在源代码中包含生成的.h和.cpp文件,以及如何处理ui文件的更新和版本控制。 虽然Qt4对ui文件的使用进行了简化,但理解和掌握这些变化对于有效利用设计师工具和编写高质量的Qt应用程序至关重要。通过理解并遵循上述步骤和注意事项,开发者能够顺利过渡到Qt4的新工作模式,并充分利用ui文件的优势。
2012-08-10 上传
Qt中怎么用Ui文件 第一步, 制作ui文件。 首先应该用Qt Designer绘制一个自己的界面,并存为myform.ui(这里的myform可以用自己喜欢的名字代替)。 在制作自己的界面文件时要注意以下几个要点: 1、要记住ui文件的名字,因为uic生成的代码会存在ui_myform.h里 2、要记住主窗体的object name, 因为ui文件提供的类名将以这个form的名字来命名 3、要特别注意你的form选择的基类要和你代码中的窗体类兼容 4、要记得给每个后面需要访问到的控件起一个有意义并且好记的object name, 因为ui文件提供的控件将以这些object name来命名 清楚了以上几点,在代码中使用你的ui文件就会变得非常简单。 第二步,将ui文件加入工程 这一步最简单,只需要修改pro文件,加入FORMS+=myform.ui qmake -project命令也可以识别后缀名为ui的文件,并将之加入工程。 第三步,在代码中引用ui文件 官方介绍的使用ui文件的方法有三种,一个是直接引用,二是单继承,三是多继承。 第一种方法其实很不实用,大家去看一下文档中的例子就可以了;第二种和第三种没有本质的差别,可以并作一类,这里做重点介绍。 ui文件最终会被翻译成标准的C++代码,并存入一个.h文件中,这个过程在调用make之后才进行,所以初始情况下你是看不到这个ui_myform.h文件的,只有经过了make过程该头文件才生成。不过没关系,没有这个文件我们照样能写出正确的代码。 单继承方式简单来说就是在代码中首先要自定义一个子类(后文称为MyForm),该类要从form对应的窗体类(或其兼容的子类)派生;并用ui生成的类定义一个类里的成员变量(后文成文myui)。这样在MyForm的构造函数中可以直接调用myui和myui中的变量和函数,使用起来很方便。 举例说明, 比如这里有一个ui文件叫myform.ui, ui文件里定义的窗体名字为BigWidget,上面摆放了一个单行编辑控件叫lineeditName: //myform.h #include “ui_myform.h” class MyForm: public QWidget { Q_OBJECT public: MyForm(QWidget*parent) { myui.setupUi(this); } private: Ui::BigWidget myui; private: void my_function(); }; 上面这段简单的类的声明是前文所述前三点要点的最佳例证,请对照要点的文字描述和具体的代码体会其中的含义。这里还有一点比较有意思的地方,就是ui文件提供的类被包含在了名为Ui的name space里,这样做的目的是将ui文件的命名空间与用户的代码分离,避免两者出现命名冲突的情况。相应的,我们写代码的时候也要注意在使用ui文件中的类时要用“Ui::”的方式进行引用。 再来看cpp文件 //myform.cpp #include #include “myform.h” void my_function(void) { QMessageBox::information(this, “Name”, myui.lineeditName->text()); } 这里随便写了一个函数,为了说明如何在窗体类里调用ui文件中定义的控件。这段代码非常简单,就不多作说明了。 有了单继承的基础,学习多继承是小菜一碟。来段代码看一下就明白了。 //myform.h #include “ui_myform.h” class MyForm: public QWidget, public Ui::BigWidget { Q_OBJECT public: MyForm(QWidget*parent) { setupUi(this); } private: void my_function(); }; //myform.cpp #include #include “myform.h” void my_function(void) { QMessageBox::information(this, “Name”, lineeditName->text()); } 是不是不用说明大家也能明白呢?多继承其实就是不仅从form需要的窗体类去派生,还要加上ui提供的类本身。这样带来的好处是你的窗体类继承了ui里的所有控件和方法,调用时就可以少写一些字。 单继承和多继承这两种方法没有好坏之分,大家可以根据自己的编程习惯取舍。 第四步,编译、验证在pro文件包含正确FORMS信息的情况下,运行qmake; make就可以编译工程了。 make时如果你认真看一下输出就会发现,make在最开始编译的时候就会自动调用uic去生成需要的代码。经过make之后ui_myform.h文件就生成了,建议大家去看一下这个文件的内容。