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);});
这样一个简单的栈界面就做好了显示效果如下: