QT Layout中增删widget与切换界面

背景:以QGroupBox为father widget,用VBoxLayout的布局排版多个checkBox。接下来解决三个问题:
(1)在VBoxLayout中增添checkBox并显示
(2)从VBoxLayout中删除checkBox
(3)切换groupBox中的界面

在QGroupBox中以VBoxLayout添加子widget (checkBox)

失败的案例:


这里写图片描述

code:

    ui->setupUi(this);
    QVBoxLayout layout;

    QCheckBox box1("box1");
    QCheckBox box2("box2");
    QCheckBox box3("box3");

    layout.addStretch(1);
    layout.addWidget(&box1);
    layout.addStretch(1);
    layout.addWidget(&box2);
    layout.addStretch(1);
    layout.addWidget(&box3);
    layout.addStretch(1);

    wui->groupBox->setLayout(&layout);

关键点:
(1)需要在groupBox中加上一个father widget: widget
(2)设置widget的几何形状和groupBox保持一致,需注意的是widget设置geometry的时候QRect是相对于groupBox而言的。
(3)在widget中以VBoxLayout的方式添加子widget: checkBox ,且要注明checkBox的father widget是widget。
(4)最后要将widget show出来。

    ui->setupUi(this);
    QVBoxLayout layout;
    QWidget *widget = new QWidget(ui->groupBox);
    QRect rect = ui->groupBox->geometry();
    rect.setX(0);   // X and Y is related to parent widget
    rect.setY(0);

    widget->setGeometry(rect);
    widget->
Stacked Widget 是一个 Qt 的组件,可以用来实现多页面切换界面。它允许你在同一个位置上放置多个子组件,但只有一个子组件是可见的。通过切换可见的子组件,你可以实现多页面切换界面。 以下是一个简单的示例,演示如何使用 Stacked Widget 实现多页面切换界面: 1. 在 Qt Designer 创建一个 Stacked Widget,并在其添加多个子组件。 2. 在你的代码,使用 QStackedWidget 类的 setCurrentIndex() 方法来切换可见的子组件。例如,当用户点击一个按钮时,你可以调用 setCurrentIndex() 方法来切换到相应的子组件。 下面是一个示例代码: ```python from PyQt5.QtWidgets import QApplication, QMainWindow, QStackedWidget, QPushButton, QWidget, QVBoxLayout class MainWindow(QMainWindow): def __init__(self): super().__init__() # 创建一个 Stacked Widget self.stacked_widget = QStackedWidget(self) # 创建多个子组件 self.page1 = QWidget() self.page1_layout = QVBoxLayout() self.page1.setLayout(self.page1_layout) self.page1_button = QPushButton("切换到页面2") self.page1_button.clicked.connect(self.switch_to_page2) self.page1_layout.addWidget(self.page1_button) self.stacked_widget.addWidget(self.page1) self.page2 = QWidget() self.page2_layout = QVBoxLayout() self.page2.setLayout(self.page2_layout) self.page2_button = QPushButton("切换到页面1") self.page2_button.clicked.connect(self.switch_to_page1) self.page2_layout.addWidget(self.page2_button) self.stacked_widget.addWidget(self.page2) # 将 Stacked Widget 添加到主窗口 self.setCentralWidget(self.stacked_widget) def switch_to_page1(self): self.stacked_widget.setCurrentIndex(0) def switch_to_page2(self): self.stacked_widget.setCurrentIndex(1) if __name__ == "__main__": app = QApplication([]) window = MainWindow() window.show() app.exec_() ``` 在这个示例,我们创建了一个包含两个页面的 Stacked Widget。每个页面都包含一个按钮,点击按钮可以切换到另一个页面。我们使用 setCurrentIndex() 方法来切换页面。 注意,Stacked Widget 组件可以在 Qt Designer 直接拖拽和编辑子组件。你可以使用 Qt Designer 来创建和编辑你的界面,然后在代码使用它。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值