百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程字典 > 正文

Qt Designer中“放到前面”和“放到后面”,别傻傻分不清了

toyiye 2024-06-21 12:26 16 浏览 0 评论

一、导读

在Qt开发中,习惯使用Qt Designer来对界面中的组成元素进行布局和设计。当我们使用鼠标点击一个界面控件后,右键单击,在弹出的菜单中会有两个选项:放在前面放在后面。如下图所示:

这两个选项对于界面控件来说,有什么作用呢?在实际开发过程中,哪些情况下会使用到这两个选项呢?其背后的机制又是什么呢?文本将一探究竟。

二、探秘开始

从字面意思上理解,则是当两个控件出现了重叠,这时候就需要考虑哪个控件在前面,哪个控件在后面。假如一个QWidget中包含了一个QLabel(用于显示文本)和一个QLineEdit(用于用户输入文本):

当他们两个不相遇的情况下,那一切都好说。如果把他们移动到一起(几乎完全重叠),这时候就成了下面的样子:

很明显,QLineEdit在前面清晰可见,边框后面还看得见Qlabel边缘部分的文字信息。

如果将QLineEdit放到后面,则会出现下面的效果:

能完整看见QLabel的文字信息,也能看见QLineEdit输入边框,且能正常输入文字。

综上,当两个控件重叠后,对控件设置放在前面和放在后面在界面显示上会出现不同的效果。

(2-1)实际应用场景

在实际Qt应用开发中,利用这一机制,可以组合实现很多效果,例如如果想在一张局部背景图上放置一个下拉选项框,使用QLabel+QComboxBox实现,如果不设置控件的显示次序,那么设置的背景图片则会将QComboxBox遮盖住,这时候就需要将QComboxBox放到前面,然后下图所示的效果才是预期效果:

综上,放到前面放到后面两个选项在应用界面贴图开发的时候会经常使用到。

(2-2)背后的机制

在这篇文章《玩Qt,这三种使用ui文件的方式不得不知!)》中,写到了界面描述文件xxx.ui在编译构建过程中,会被uic读取,然后生成C++代码,生成的代码位于ui_xxx.h中。假如一个QWidget中包含了一个QComboxBox和一个QLabel(用于设置一张背景图),如下图所示:

如果没有设置放到前面或者放到后面,编译生成的C++代码如下:

#ifndef UI_WIDGET_H
#define UI_WIDGET_H

#include <QtCore/QVariant>
#include <QtWidgets/QApplication>
#include <QtWidgets/QComboBox>
#include <QtWidgets/QLabel>
#include <QtWidgets/QWidget>

QT_BEGIN_NAMESPACE

class Ui_Widget
{
public:
    QComboBox *comboBox;
    QLabel *label_2;

    void setupUi(QWidget *Widget)
    {
        if (Widget->objectName().isEmpty())
            Widget->setObjectName(QString::fromUtf8("Widget"));
        Widget->resize(770, 493);
        comboBox = new QComboBox(Widget);
        comboBox->addItem(QString());
        comboBox->addItem(QString());
        comboBox->addItem(QString());
        comboBox->addItem(QString());
        comboBox->setObjectName(QString::fromUtf8("comboBox"));
        comboBox->setGeometry(QRect(670, 30, 87, 26));
        label_2 = new QLabel(Widget);
        label_2->setObjectName(QString::fromUtf8("label_2"));
        label_2->setGeometry(QRect(0, 0, 773, 91));

        retranslateUi(Widget);

        QMetaObject::connectSlotsByName(Widget);
    } // setupUi

    void retranslateUi(QWidget *Widget)
    {
        Widget->setWindowTitle(QCoreApplication::translate("Widget", "Widget", nullptr));
        comboBox->setItemText(0, QCoreApplication::translate("Widget", "1", nullptr));
        comboBox->setItemText(1, QCoreApplication::translate("Widget", "2", nullptr));
        comboBox->setItemText(2, QCoreApplication::translate("Widget", "3", nullptr));
        comboBox->setItemText(3, QCoreApplication::translate("Widget", "4", nullptr));

        label_2->setText(QCoreApplication::translate("Widget", "TextLabel", nullptr));
    } // retranslateUi

};

namespace Ui {
    class Widget: public Ui_Widget {};
} // namespace Ui

QT_END_NAMESPACE

#endif // UI_WIDGET_H

此时QLabel背景图将覆盖QComboxBox下拉框,不是想要的效果。这时候要么将QLabel放到后面,或者将QComboxBox放到前面,那么生成的C++代码如下:

#ifndef UI_WIDGET_H
#define UI_WIDGET_H

#include <QtCore/QVariant>
#include <QtWidgets/QApplication>
#include <QtWidgets/QComboBox>
#include <QtWidgets/QLabel>
#include <QtWidgets/QWidget>

QT_BEGIN_NAMESPACE

class Ui_Widget
{
public:
    QComboBox *comboBox;
    QLabel *label_2;

    void setupUi(QWidget *Widget)
    {
        if (Widget->objectName().isEmpty())
            Widget->setObjectName(QString::fromUtf8("Widget"));
        Widget->resize(770, 493);
        comboBox = new QComboBox(Widget);
        comboBox->addItem(QString());
        comboBox->addItem(QString());
        comboBox->addItem(QString());
        comboBox->addItem(QString());
        comboBox->setObjectName(QString::fromUtf8("comboBox"));
        comboBox->setGeometry(QRect(670, 30, 87, 26));
        label_2 = new QLabel(Widget);
        label_2->setObjectName(QString::fromUtf8("label_2"));
        label_2->setGeometry(QRect(0, 0, 773, 91));
        label_2->raise();
        comboBox->raise();

        retranslateUi(Widget);

        QMetaObject::connectSlotsByName(Widget);
    } // setupUi

    void retranslateUi(QWidget *Widget)
    {
        Widget->setWindowTitle(QCoreApplication::translate("Widget", "Widget", nullptr));
        comboBox->setItemText(0, QCoreApplication::translate("Widget", "1", nullptr));
        comboBox->setItemText(1, QCoreApplication::translate("Widget", "2", nullptr));
        comboBox->setItemText(2, QCoreApplication::translate("Widget", "3", nullptr));
        comboBox->setItemText(3, QCoreApplication::translate("Widget", "4", nullptr));

        label_2->setText(QCoreApplication::translate("Widget", "TextLabel", nullptr));
    } // retranslateUi

};

namespace Ui {
    class Widget: public Ui_Widget {};
} // namespace Ui

QT_END_NAMESPACE

#endif // UI_WIDGET_H

对比两种方式下生成的代码,发现多出了以下两行:

label_2->raise();
comboBox->raise();

raise()QWidget提供的一个槽函数,用于将小部件提升到父小部件堆栈的顶部,调用这个函数后,小部件将在任何重叠的兄弟小部件的前面。与之对应的还有一个槽函数:lower(),将小部件降低到父小部件堆栈的底部。调用后,小部件将在任何重叠的兄弟小部件的后面(因此被遮蔽)。

综上,在Qt Designer中设置的放到前面或者放到后面操作,本质上则是uic生成了调用raise函数的代码实现的。

相关推荐

Python第三课3. Python 的非正式介绍

3.Python的非正式介绍?在下面的例子中,通过提示符(>>>与...)的出现与否来区分输入和输出:如果你想复现这些例子,当提示符出现后,你必须在提示符后键入例子中的每...

如何使用 Python 构建一个“谷歌搜索”系统?| 内附代码

来源|hackernoon编译|武明利,责编|Carol出品|AI科技大本营(ID:rgznai100)在这篇文章中,我将向您展示如何使用Python构建自己的答案查找系统。基本上,这...

Python 模拟微博登陆,亲测有效!(如何用python爬微博)

今天想做一个微博爬个人页面的工具,满足一些不可告人的秘密。那么首先就要做那件必做之事!模拟登陆……代码是参考了:https://www.douban.com/note/201767245/,我对代码进...

Python 驱动的 AI 艺术批量创作: 免费的Bing 绘图代码解析

这篇文章将深入分析一段Python代码,该代码利用Bing的AI绘图功能,即bing的images/create,根据用户提供的文本提示生成图像。我们将详细探讨其工作原理、代码结构、...

Python爬虫Scrapy库的使用入门?(python scrapy爬虫)

Scrapy是一个开源的并且支持高度可扩展的Python爬虫框架,主要被用来实现从网站提取数据。出现之初就是为网页抓取而设计,但是现在它也可以被用于从APIs中抓取数据或通用的Web抓取任务。Sc...

Python3 标准库概览(python标准库有什么)

操作系统接口os模块提供了不少与操作系统相关联的函数。>>>importos>>>os.getcwd()#返回当前的工作目录'C:\\Python34...

零基础入门学习Python(三):变量和字符串

分享兴趣,传播快乐,增长见闻,留下美好!亲爱的您,这里是LearningYard新学苑。今天小编为大家带来的是...

Python读写docx文件(python读写word)

Python读写docx文件Python读写word文档有现成的库可以处理pipinstallpython-docx安装一下。https://python-docx.readthedocs.io/...

如何利用Xpath抓取京东网商品信息

前几小编分别利用Python正则表达式和BeautifulSoup爬取了京东网商品信息,今天小编利用Xpath来为大家演示一下如何实现京东商品信息的精准匹配~~HTML文件其实就是由一组尖括号构成的标...

如何利用Xpath选择器抓取京东网商品信息

前几小编分别利用Python正则表达式和BeautifulSoup爬取了京东网商品信息,今天小编利用Xpath来为大家演示一下如何实现京东商品信息的精准匹配~~HTML文件其实就是由一组尖括号构成的标...

python之Scrapy爬虫案例:豆瓣(python爬虫书籍豆瓣评分)

python模块之Scrapy爬虫框架...

Python编程入门学习:最常见加密方式和Python实现

前言我们所说的加密方式,都是对二进制编码的格式进行加密的,对应到Python中,则是我们的Bytes。所以当我们在Python中进行加密操作的时候,要确保我们操作的是Bytes,否则就会报错。将字符串...

一日一技:Python中的string.rindex()方法

string.rindex()方法string.rindex()方法返回字符串内子字符串的最高索引(如果找到)。如果未找到子字符串,则会引发异常。rindex()的语法为:...

Asterisk-ARI对通道中的DTMF事件处理

Asterisk通道中关于DTMF处理是一个非常重要的功能。通过DTMF可以实现很多的业务处理。现在我们介绍一下关于ARI对通道中的DTMF处理,我们通过自动话务员实例来说明Asterisk如何创建一...

PyQt5 初次使用(pyqt5下载官网)

本篇文章默认已安装Python3,本篇文章默认使用虚拟环境。安装pipinstallPyQt5PyQt一些图形界面开发工具QtDesigner、国际化翻译工具Liguist需要另外...

取消回复欢迎 发表评论:

请填写验证码