Qstackwidget研究

stackqidget是将多个界面重叠在一块,根据选择显示想要的界面,里面放的都是qwidget页面(qwidget *),很容易理解

接下来就是初步的尝试

我们设定左边有一个导航栏都是按钮,用一个groupbox装起来,右边是stackwidget,根据我们选择的按钮显示指定的页面就是用的信号绑定。

ui设计里面都有,就不手搓代码了,直接用吧,布局如图:

 

手搓代码的话其实就是new一个qstackwidget,new的qwidget用addwidget加入这个容器,再用connect与相应的按钮做一个绑定就行了,用组件库就方便许多,布局好后直接做一个信号绑定,本来是想写一个槽函数,但感觉写槽函数一个个绑就很麻烦,改用c++的lambda函数

connect(ui->btn1, &QPushButton::clicked, this, [this]() {
        ui->stack->setCurrentWidget(ui->page);
    });
    connect(ui->btn2, &QPushButton::clicked, this, [this]() {
        ui->stack->setCurrentWidget(ui->page_2);
    });

 这样一个简单的栈界面就做好了显示效果如下:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值