本文主要总结用QStackedLayout类的用法,主要通过新建一个实例,体现QStackedLaout类可以应用在切换菜单上。QStackedLaout类是属于布局管理器中的一个常用类。
下面是一个实例,该实例是顶部两个菜单按钮,分别点击两个按钮,将会切换不同页面。比如点击pageOne按钮,则切换到第一页;点击pageTwo按钮,则切换到第二页。
1.1新建一个widget工程,以及两个类,类名分别为PageOne和PageTwo。然后在如下文件添加代码:
pageone.h
class PageOne : public QWidget
{
Q_OBJECT
public:
explicit PageOne(QWidget *parent = nullptr);
signals:
public slots:
private:
QVBoxLayout *pageOneLayout;
QPushButton *m_pushButton;
};
// PAGEONE_H
pageone.cpp
PageOne::PageOne(QWidget *parent) : QWidget(parent)
{
pageOneLayout = new QVBoxLayout(this); //注意,this表示在这个widget窗口显示
m_pushButton = new QPushButton;
m_pushButton->setText(tr("成功切换到第一页!"));
pageOneLayout->addWidget(m_pushButton);
}
pagetwo.h
class PageTwo : public QWidget
{
Q_OBJECT
public:
explicit PageTwo(QWidget *parent = nullptr);
signals:
public slots:
private:
QVBoxLayout *pageOneLayout;
QPushButton *m_pushButton;
};
// PAGETWO_H
pagetwo.cpp
PageTwo::PageTwo(QWidget *parent) : QWidget(parent)
{
pageOneLayout = new QVBoxLayout(this); //注意,this表示在这个widget窗口显示
m_pushButton = new QPushButton;
m_pushButton->setText(tr("成功切换到第二页!"));
pageOneLayout->addWidget(m_pushButton);
}
widget.h
class Widget : public QWidget
{
Q_OBJECT
public:
Widget(QWidget *parent = 0);
~Widget();
private slots:
void On_PushButton1Result();
void On_PushButton2Result();
private:
QVBoxLayout *mainLayout;
QHBoxLayout *topLayout;
QStackedLayout *stackLayout;
QPushButton *m_pushButton1,*m_pushButton2;
PageOne *m_pageOne;
PageTwo *m_pageTwo;
};
// WIDGET_H
widget.cpp
Widget::Widget(QWidget *parent)
: QWidget(parent)
{
//初始化
this->setObjectName("mainWidget");
this->setStyleSheet("#mainWidget{background-color:rgb(10,90,130);}");
mainLayout = new QVBoxLayout;
topLayout = new QHBoxLayout;
stackLayout = new QStackedLayout;
m_pushButton1 = new QPushButton;
m_pushButton1->setText("pageOne");
m_pushButton1->setFixedHeight(50); //设定按钮固定高度
// m_pushButton1->setStyleSheet("color:rgb(255,0,0);border:none"); //设置按钮字体颜色,无边框
// m_pushButton1->setFlat(true); //祛除边框
m_pushButton2 = new QPushButton;
m_pushButton2->setText("pageTwo");
m_pageOne = new PageOne;
m_pageTwo = new PageTwo;
//窗口布局
// topLayout->addWidget(m_pushButton1,0,Qt::AlignLeft | Qt::AlignCenter);
topLayout->setMargin(0); //控件与窗体左右间距
topLayout->setSpacing(0); //Layout内部控件间距
topLayout->addWidget(m_pushButton1);
topLayout->addWidget(m_pushButton2);
stackLayout->addWidget(m_pageOne); //第一页
stackLayout->addWidget(m_pageTwo); //第二页
stackLayout->setCurrentIndex(0); //默认stackLayout显示第0页
mainLayout->addLayout(topLayout); //顶部界面
mainLayout->addLayout(stackLayout); //中间界面
mainLayout->setMargin(0); //控件与窗体左右间距
mainLayout->setSpacing(0); //Layout内部控件间距
mainLayout->setStretchFactor(topLayout,1);
mainLayout->setStretchFactor(stackLayout,10);
setLayout(mainLayout); //设置唯一布局 这句也可以用mainLayout = new QVBoxLayout(this);替代
connect(m_pushButton1,SIGNAL(clicked(bool)),this,SLOT(On_PushButton1Result()));
connect(m_pushButton2,SIGNAL(clicked(bool)),this,SLOT(On_PushButton2Result()));
}
Widget::~Widget()
{
}
void Widget::On_PushButton1Result()
{
//按钮1槽函数
stackLayout->setCurrentIndex(0); //切换到stackLayout第一页
}
void Widget::On_PushButton2Result()
{
//按钮2槽函数
stackLayout->setCurrentIndex(1); //切换到stackLayout第二页
}
main.c
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
Widget w;
w.show();
return a.exec();
}