使用Qt Designer开发


本章将简介使用 Qt Creator 里自带的 Qt Designer,使用 Qt Designer 比较方便的构造 UI 界面。特点是方便布局,比较形象。

一、使用UI设计器开发程序

Qt Designer 是属于 Qt Creator 的一个功能而已,大家不要搞混了。Qt Designer 也叫 UI 设计师或者 UI 设计器,这都是指的同一个东西而已。下面就简单介绍使用 UI 设计器开发程序,以连接信号与槽为例,简单的介绍这个开发流程。最后我们思考一下这种开发方式的好处以及不便之处。

1. 在UI文件添加一个按钮

新建一个项目为 01_designer_example。

在这里插入图片描述
在左边找到 Push Button,然后拖拽到中间的显示窗体里,如下图。
在这里插入图片描述
并将这个 PushButton 的 text 属性(文本属性)改为“关闭程序”。
我们要设计点击这个按钮将关闭这个窗口,关闭这个程序。
在这里插入图片描述

2. 在UI文件里连接信号与槽

在 UI 设计器里有两种方法可以连接信号与槽。初学者可能不了解什么是 Qt 的信号与槽。
这里先简单的介绍一下信号与槽的功能。所谓信号即是一个对象发出的信号,槽即是当这个对象发出这个信号时,对应连接的槽就发被执行或者触发。

以上为非专业术语解释,在下一章节可以学到 Qt 信号与槽机制。现在我们只要了基本的去了解一下这个信号与槽即可。可以说信号与槽在 Qt 里是必不可少的。要想事件做出对应的动作就必须用到信号与槽。

1. UI 设计器里 信号与槽的连接 方法一:

在主窗体的上面部分,我们可以看到一些小小的按钮,如下图框框部分。用鼠标放在这些按钮上面可以查看这个按钮是什么作用。信号槽连接的按钮也在上面。
在这里插入图片描述

点击信号槽连接的按钮如下,如下图①处,点击进入信号槽连接模式(若想退出信号槽连接模式,则点击①处左边的按钮),进入信号与槽的连接模式后,将鼠标选中我们的“关闭程序”按钮,按住按钮,然后用鼠标向外拖动,如②处。此时就会出现信号槽连接的符号。

在这里插入图片描述
之后按如下图步骤选择,左边的“关闭程序”pushButton 按钮的信号,可以看到一个对象的信号可以有多种。右边的 QMainWindow 的槽函数,如果有其他对象,右边不一定只有MainWidnow 的槽函数(槽),也有可能是其他对象的槽。我们选择按钮的 clicked()信号,将其连接 MainWindow 对象的 close()槽。这样就完成了信号与槽的连接,非常简单。我们也可以预知这个信号与槽的功能,当“关闭程序”pushButton 发出了 clicked()信号(也就是单击信号)。这个信号由“关闭程序”pushButton 被单击时发出。它就会触发 MainWindow 的 close()。进而使整个程序关闭。MainWindow 的 close()就是退出关闭程序,退出程序的意思。
在这里插入图片描述

完成信号槽连接,如下图。要想返回编辑部件模式点击如下图标注位置的按钮。下图就是信号与槽连接的图示了。在编辑部件模式下我们是看不见的,只有信号槽模式才能看见这样的图示。
在这里插入图片描述

2. UI 设计器里 信号与槽的连接 方法 二:

选中“关闭程序”pushButton 按钮,然后右键,如下图。选择“转到槽”。
在这里插入图片描述
点击“转到槽”后,弹出下面的窗口,这一步是先让我们选择信号。按如下图选择。如果细心的同学,我们还发现这个 clicked()信号并不是 pushButton 的,而是 QAbstactButton 的。只是 pusbButton 继承了 QAbstracButton,同时把这个信号也继承了下来。除此之外我们还看到其他信号也是不是属于 pushButton 的,也是被继承下来了。所以我们在C++基础部分学过的继承。在 Qt 里的作用表现的淋漓尽致!根本不用重写 pushButton 的 clicked()事件。pushButton 只需要继承父类的 clicked()事件即可!
在这里插入图片描述
点击 OK 后,就会跳转到槽函数里,这个代码由 Qt Creator 自动生成。
在这里插入图片描述
同时在 mainwindow.h 里声明了这个槽函数。
在这里插入图片描述
如果我们学过 C#,这就好像 C#里的跳转到事件一样。其实这种便捷的编程方式很多编程的 IDE 都非常类似。只要我们对这种 IDE 有一定的了解,学习起来就不会觉得难。
返回到 mainwindow.cpp 找到 on_pushButton_clicked 这个槽函数里。在这个槽数里写上this->close();调用 close()方法关闭整个程序。
在这里插入图片描述

3. 编译及运行创建的UI项目

直接按 Ctrl + r 或者点击左下角的第一个绿色三角符号,编译且运行这个项目。运行的结果如下。点击“关闭程序”按钮,看看是不是整个程序关闭退出了呢?如果细心的同学还会思考,
我们在上面用了两种方法连接信号与槽。那他们是如何连接的呢?他们两者同时连接会有影响吗?在哪里连接的呢?这些都是我们需要探讨的问题?难道第二种方法写上槽函数就会自动被触发?下一节我们继续学习 Qt 信号与槽了解信号与槽的写法就能解开这个谜了!

直接按 Ctrl + r 或者点击左下角的第一个绿色三角符号,编译且运行这个项目。运行的结果
如下。点击“关闭程序”按钮,看看是不是整个程序关闭退出了呢?如果细心的同学还会思考,
我们在上面用了两种方法连接信号与槽。那他们是如何连接的呢?他们两者同时连接会有影响吗?在哪里连接的呢?这些都是我们需要探讨的问题?难道第二种方法写上槽函数就会自动被触发?下一节我们继续学习 Qt 信号与槽了解信号与槽的写法就能解开这个谜了!

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值