浅谈控件提升之stacked Widget

    • 概要
    • 效果
    • 方法
      • 操作过程图
      • 部分代码
    • 缺点

概要

stacked widget 是可以进行多个页面切换的, 每个页面都可以放自己的控件,然后实现相关的功能。

然而,如果页面过多,或者每个页面的功能都太过强大的话,那么在一个类里面要实现所有页面的功能,必然会让代码显得杂乱。这也会使这个.cpp文件的逻辑显得不那么清楚。

这时,如果通过控件的提升的话,可以使每个页面的代码在各自不同的文件里面,这样,就是代码的逻辑清晰很多。

效果

点击test1时
浅谈控件提升之stacked Widget_第1张图片

点击test2时
浅谈控件提升之stacked Widget_第2张图片

点击test3时
浅谈控件提升之stacked Widget_第3张图片

方法

操作过程图

浅谈控件提升之stacked Widget_第4张图片

浅谈控件提升之stacked Widget_第5张图片

部分代码

widget.cpp代码

#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::Widget)
{
    ui->setupUi(this);
}

Widget::~Widget()
{
    delete ui;
}

void Widget::on_toolButton_clicked()
{
    ui->stackedWidget->setCurrentIndex(0);
}

void Widget::on_toolButton2_clicked()
{
    ui->stackedWidget->setCurrentIndex(1);
}

void Widget::on_toolButton3_clicked()
{
    ui->stackedWidget->setCurrentIndex(2);
}

void Widget::on_toolButton_4_clicked()
{
    ui->stackedWidget->setCurrentIndex(3);
}

test1.cpp代码

#include "test1.h"
#include "ui_test1.h"

Test1::Test1(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::Test1)
{
    ui->setupUi(this);
}

Test1::~Test1()
{
    delete ui;
}

缺点

它要求我们每个页面需要有自己的ui文件, 头文件,和实现文件,这样会使项目文件的数量增加。如果是功能简单,后期不需要添加太多功能和维护的,这样就显得有些麻烦。

你可能感兴趣的:(QT学习之路)