【问题标题】:Is there a way to create two independent layouts in Qt Designer?有没有办法在 Qt Designer 中创建两个独立的布局?
【发布时间】:2021-02-11 15:50:54
【问题描述】:

我是 Qt Designer 的新手,所以这个问题可能很愚蠢,但我真的很困惑。

我正在使用 Qt Designer 和 PyQt5 创建一个应用程序。我的应用包含几个屏幕,我想通过单击按钮在它们之间切换。

第一个屏幕由一个按钮 (button_1) 和一个放置在垂直布局中的标签 (label_1) 组成。第二个屏幕也由一个按钮 (button_2) 和一个标签 (label_2) 组成,但它们是具有不同大小和内容的不同小部件。我想将 button_2 和 label_2 放置在水平布局中。

以前我没有使用布局。我刚刚创建了一个 .ui 文件并将 button_2 和 label_2 放在 button_1 和 label_1 上方。它们是重叠的,但并不影响性能,因为当显示 button_1 和 label_1 时,我使 button_2 和 label_2 不可见,反之亦然。但现在我需要调整窗口大小,并且需要将小部件放入布局中。

首先想到的是创建两个单独的 .ui 文件,并在屏幕之间切换时使用 loadUi 命令设置它们。但我只需要使用一个 .ui 文件。这可能吗?如何创建两个独立的布局?或者也许还有另一种方法可以解决我的问题。非常感谢任何帮助。

【问题讨论】:

  • 您可以使用addLayout()将2个布局添加到1个父布局中,但这是在代码中,我认为它应该也可以在设计器中使用。
  • @NgocMinhNguyen 这样我就不能重叠小部件,例如我无法将 button_2 放在 button_1 上方。
  • 那是我的错。我没有仔细阅读你的问题。为此,您可以考虑将QTabWidgetQStackedWidget 一起使用。
  • @NgocMinhNguyen 没关系,谢谢你的建议。我可以使用 QTabWidget 或 QStackedWidget,但我希望用户仅使用我的小部件(button_1 和 button_2)在屏幕之间切换。我的想法是用户不应该看到 QStackedWidget 中的箭头或 QTabWidget 中的标签栏。如果有办法隐藏它们,那么这个解决方案将是完美的。

标签: qt layout pyqt5 widget


【解决方案1】:

我认为在这种情况下,您最好的选择是使用QStackedWidget 作为标签和按钮的容器。要在 Qt Designer 中创建堆叠的小部件,您可以将堆叠的小部件从左侧的容器组拖动到父小部件。这将创建一个包含两个页面的堆栈。然后可以独立设置每个页面。您添加到特定页面的任何布局和小部件仅在显示该页面时才可见。如果您愿意,可以通过右键单击堆叠的小部件并从上下文菜单中选择“插入页面”来添加其他页面。

要在 Qt Designer 中的页面之间导航,您可以在 Object Inspector 的树中选择正确的小部件,使用堆叠小部件右上角的两个黑色箭头,或使用堆叠小部件的上下文菜单.要在 python 脚本中的页面之间导航,您需要使用 QStackedWidget.setCurrentIndex()

【讨论】:

  • 我认为使用 QStackedWidget 对我有用,但是当应用程序运行时,我想仅使用我的小部件(button_1 和 button_2)在页面(例如我的屏幕)之间切换并隐藏那些黑色箭头.我可以这样做吗?搜索 QStackedWidget 的 StyleSheet 选项,但没有找到任何解决方案。无论如何,非常感谢。
  • 那些箭头应该只出现在 Qt Designer 本身,而不是最终应用程序中。
  • 不知道,当我在 Qt Designer 中预览 .ui 文件时,箭头是可见的。但是当我运行应用程序时,它们被隐藏了。完美运行。谢谢!
猜你喜欢
  • 1970-01-01
  • 2020-12-20
  • 2015-03-23
  • 1970-01-01
  • 1970-01-01
  • 2021-10-23
  • 2023-03-07
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多