zoukankan      html  css  js  c++  java
  • Qt Designer设计 UI 文件并调用

    本文介绍的是Qt Designer设计 UI 文件并调用,在坛子里逛了一圈,关于UI方面的好像不怎多,本篇给大家分享一下。

    AD: 2013云计算架构师峰会超低价抢票中

    Qt Designer设计 UI 文件并调用是本篇内容将要介绍的内容,不多说,先来看内容。

    1、用designer设计一个UI.对象名保存为myui,基于QWidget类.(可以在此基础上随便添加一些控件之类。eg:pushButton)。保存窗体为myui,or others.

    2、为了明白其具体机制,我们可以用uic将此UI文件转换成头文件看看。uic -o ui_myui.h myui.ui.(事实上我们最后用qmake编译的时候,qmake会自动调用uic转换头文件),在此.h文件中有定义了一个类class Ui_myui,并且有一个myui以public的方式继承Ui_myui,class myui: public Ui_myui {}

    特别说明:myui即是我们用designer设计的UI实体类

    3、好了,轮到我们自己定义类了,为什么要自己定义类呢?是这样的,如果我们直接调用的话,有很大的弊端:当我们的工程很浩大的时候,如果我们要修改UI文件了,则要相应改很多源程序来继续当前的功能,而如果我们定义一个类来继承它的话,随你UI怎么变,跟我关系不是很大。废话少说,进入正题:

    写一个.h文件

    1. myclass.h  
    2. #include <QtGui/QtGui>   
    3. namespace Ui   
    4. {   
    5.     class myui;//注:designer生成的ui类为ui_DialogClass,而我们只是用它的派生类myui   
    6.     //即:myui是ui_DialogClass的一个实体   
    7. }   
    8.    
    9. class myclass : public QDialog//自定义一个类myclass,通过调用ui类   
    10. {   
    11.     Q_OBJECT   
    12.    
    13. public:   
    14.     myclass(QWidget *parent = 0);//最顶层父窗口为QWidget   
    15.     ~myclass();   
    16.    
    17. private:   
    18.     Ui::myui *ui;//创建一个ui指针对象,因为designer只是设计出来一个myui实体类,是个宏观概念,我们必须定义一个对象才能调用它   
    19. };  
    20. myclass.cpp  
    21. #include "myclass.h"   
    22. #include "ui_myui.h"   
    23. myclass::myclass(QWidget *parent)   
    24.         :QDialog(parent),ui(new Ui::myui)   
    25. {   
    26.     ui->setupUi(this);//使用ui类   
    27.     connect(ui->pushButton,SIGNAL(clicked()),this,SLOT(close()));   
    28. }   
    29. myclass::~myclass()   
    30. {   
    31.     delete ui;   

    4、OK!我们的类已经定义好,写main函数调用自定义的类

    1. #include<QtGui/QtGui> 

    #include"myclass.h"//注:为什么只要这个头文件就可以了呢?因为当我们创建一个myclass的对象的时//候,会自动调用它的构造函数,释放时自动调用其析构函数.事实上我们不止只用一个构造函数与析构函数,//这时候怎么办呢?在myclass.h中声明该函数,在myclass.cpp中写具体实现方法.

    1. int main(int argc,char *argv[])  
    2. {  
    3.     QApplication app(argc,argv);  
    4.     myclass window;  
    5.     window.show();  
    6.     return app.exec();  
    7. }  

    小结:关于Qt Designer设计 UI 文件并调用的内容介绍完了,希望本篇文章对你有帮助!

  • 相关阅读:
    PBR(基于物理的渲染)学习笔记
    iOS应用千万级架构开篇
    iOS应用千万级架构:性能优化与卡顿监控
    iOS应用千万级架构:自动埋点与曝光
    iOS应用千万级架构:存储持久化
    iOS应用千万级架构:MVVM框架
    Spring Boot入门系列(十七)整合Mybatis,创建自定义mapper 实现多表关联查询!
    Spring Boot入门系列(十六)使用pagehelper实现分页功能
    Spring Boot入门系列(十五)Spring Boot 开发环境热部署
    说迷茫
  • 原文地址:https://www.cnblogs.com/cainiaoaixuexi/p/3274976.html
Copyright © 2011-2022 走看看