QT5多窗口跳转实现步骤详解

 更新时间:2024年12月30日 11:02:06   作者:有什么昵称不存在  
这篇文章主要介绍了使用Qt5实现多窗口界面跳转的过程,包括创建多个UI界面、设计按钮连接槽函数以及实现界面之间的导航,文中通过代码介绍的非常详细,需要的朋友可以参考下

前言

学习使用qt5完成多窗口(界面)跳转:从主界面可分别跳转至界面一和界面二,从界面一可以返回主界面和跳转至界面二,界面二可返回对应的父界面(从主界面跳转则返回主界面,从界面一跳转则返回界面一)。

一、环境

qt版本:5.12.7

windows 11 下的 Qt Designer (已搭建)

编译器:MingGW

二、步骤

1.在Designer 创建一个新的qt工程

2.选中工程选择Add New.. 添加两个新的ui界面page1window和page2window,界面模板使用MainWindow。

 3.在主界面创建两个button分别跳转至界面一和界面二。

4.在界面一创建两个button分别跳转至界面二和返回主界面。

5.在界面三创建一个button用于返回其父界面。

6.连接槽函数。

三、代码实现

mainwindow.h:

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>
#include <QPushButton>
#include <QHBoxLayout>

#include "page1window.h"
#include "page2window.h"

QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();

private slots:
    void on_page1_button_clicked();

    void on_page2_button_clicked();

private:
    Ui::MainWindow *ui;
    Page1Window *page1=NULL;
    Page2Window *page2=NULL;

    QPushButton *page1_button=NULL;
    QPushButton *page2_button=NULL;
    QHBoxLayout *btn_hlayout; //水平布局


};
#endif // MAINWINDOW_H

 mainwindow.cpp:

#include "mainwindow.h"
#include "ui_mainwindow.h"

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

    QWidget *widget=new QWidget(this);
    this->setCentralWidget(widget); // 设置为中心部件

    btn_hlayout = new QHBoxLayout(widget);

    page1=new Page1Window(this);
    page1_button =new QPushButton("前往页面一");
    page2_button =new QPushButton("前往页面二");
    btn_hlayout->addWidget(page1_button);
    btn_hlayout->addWidget(page2_button);

    // 跳转到子窗口
    connect(page1_button, &QPushButton::clicked, this, &MainWindow::on_page1_button_clicked);

    //接收返回信号显示当前窗口
    connect(page1,&Page1Window::goback,this,[=](){page1->close();this->show();});


    Page2Window *Page2FrommMin = new class Page2FromMain(this); // 使用匿名内部类
    connect(page2_button, &QPushButton::clicked, this, [=]() {Page2FrommMin->show();this->hide();});
}

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

void MainWindow::on_page1_button_clicked()
{
    this->hide();
    page1->show();
}

void MainWindow::on_page2_button_clicked()
{
    this->hide();
    page2->show();
}

 pgge1window.h:

#ifndef PAGE1WINDOW_H
#define PAGE1WINDOW_H

#include <QMainWindow>
#include <QPushButton>
#include <QHBoxLayout>

namespace Ui {
class Page1Window;
}

class Page1Window : public QMainWindow
{
    Q_OBJECT

public:
    explicit Page1Window(QWidget *parent = nullptr);
    ~Page1Window();

signals:
    void goback();

private slots:
    void on_return_btn_clicked();


private:
    Ui::Page1Window *ui;

    QPushButton *return_button=NULL;
    QPushButton *page2_button=NULL;
    QHBoxLayout *btn_hlayout; //水平布局
};

#endif // PAGE1WINDOW_H

pgge1window.cpp:

#include "page1window.h"
#include "ui_page1window.h"
#include "page2window.h"

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

    QWidget *widget=new QWidget(this);
    this->setCentralWidget(widget); // 设置为中心部件

    btn_hlayout = new QHBoxLayout(widget);


    return_button =new QPushButton("返回主页面");
    page2_button =new QPushButton("前往页面二");
    btn_hlayout->addWidget(return_button);
    btn_hlayout->addWidget(page2_button);


    connect(return_button, &QPushButton::clicked, this, &Page1Window::on_return_btn_clicked);

    Page2Window *Page2FrommPage1 = new class Page2FromPage1(this); // 使用匿名内部类
    connect(page2_button, &QPushButton::clicked, this, [=]() {Page2FrommPage1->show();this->hide();});
}

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

void Page1Window::on_return_btn_clicked()
{
    emit goback();
}

 pgge2window.h: 

#ifndef PAGE2WINDOW_H
#define PAGE2WINDOW_H

#include <QMainWindow>

#include <QPushButton>
#include <QHBoxLayout>


namespace Ui {
class Page2Window;
}

class Page2Window : public QMainWindow
{
    Q_OBJECT

public:
    explicit Page2Window(QWidget *parent = nullptr);
    ~Page2Window();

    virtual void on_return_btn_clicked() = 0; // 纯虚函数,需要在子类中实现

private:
    Ui::Page2Window *ui;

    QWidget *Widget;
    QPushButton *return_button;
    QHBoxLayout *btn_hlayout; //水平布局

};


//页面二(从主页面跳转)
class Page2FromMain : public Page2Window {
    QWidget *parentWindow1;
public:
    Page2FromMain(QWidget *parent = nullptr) : Page2Window(parent), parentWindow1(parent) {
    }

    void on_return_btn_clicked() override {
        parentWindow1->show();
        this->hide();
    }
};

//页面二(从页面一跳转)
class Page2FromPage1 : public Page2Window {
    QWidget *parentWindow2;
public:
    Page2FromPage1(QWidget *parent = nullptr) : Page2Window(parent), parentWindow2(parent) {
    }

    void on_return_btn_clicked() override {
        parentWindow2->show();
        this->hide();
    }
};

#endif // PAGE2WINDOW_H

  pgge2window.cpp: 

#include "page2window.h"
#include "ui_page2window.h"

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

    QWidget *widget=new QWidget(this);
    this->setCentralWidget(widget); // 设置为中心部件

    btn_hlayout = new QHBoxLayout(widget);

    return_button =new QPushButton("返回父页面");
    btn_hlayout->addWidget(return_button);

    connect(return_button, &QPushButton::clicked, this, &Page2Window::on_return_btn_clicked);

}

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

四、效果图

总结

通过qt5实现了多页面之间的跳转,在此过程中使用了虚函数(c语言没有),看来学习的任务依旧任重而道远。另外,使用此方式进行界面跳转时Page2Window的基类貌似只能使用MainWindow而不能是widget。

到此这篇关于QT5多窗口跳转实现的文章就介绍到这了,更多相关QT5多窗口跳转内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • VC实现五子棋游戏的一个算法示例

    VC实现五子棋游戏的一个算法示例

    这篇文章主要介绍了VC实现五子棋游戏的一个算法示例,对于学习数据结构与算法的朋友有一定的借鉴价值,需要的朋友可以参考下
    2014-08-08
  • unsigned中无符号是什么详析

    unsigned中无符号是什么详析

    unsigned为“无符号”的意思,unsigned,zerofill既为非负数,用此类型可以增加数据长度,下面这篇文章主要给大家介绍了关于unsigned中无符号是什么的相关资料,需要的朋友可以参考下
    2023-01-01
  • 数据结构之位图(bitmap)详解

    数据结构之位图(bitmap)详解

    这篇文章主要介绍了数据结构之位图详解,本文讲解了位图的基本知识、位图的实现方法、位图的应用等内容,需要的朋友可以参考下
    2014-08-08
  • 如何使用C++获取指定的重载函数地址

    如何使用C++获取指定的重载函数地址

    重载函数是完全不同的几个函数,有不同的函数地址,下面这篇文章主要给大家介绍了关于如何使用C++获取指定的重载函数地址的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-06-06
  • C++中COM组件初始化方法实例分析

    C++中COM组件初始化方法实例分析

    这篇文章主要介绍了C++中COM组件初始化方法,涉及C++中COM组件的使用技巧,需要的朋友可以参考下
    2015-05-05
  • C++ 中二分查找递归非递归实现并分析

    C++ 中二分查找递归非递归实现并分析

    这篇文章主要介绍了C++ 中二分查找递归非递归实现并分析的相关资料,需要的朋友可以参考下
    2017-06-06
  • Python扩展C/C++库的方法(C转换为Python)

    Python扩展C/C++库的方法(C转换为Python)

    这篇文章主要介绍了Python扩展C/C++库的方法(C转换为Python),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-10-10
  • C++成员函数如何当作回调函数同时传递this指针

    C++成员函数如何当作回调函数同时传递this指针

    这篇文章主要介绍了C++成员函数如何当作回调函数同时传递this指针,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • VC中CDC、HDC、pDC区别与联系及相互转换

    VC中CDC、HDC、pDC区别与联系及相互转换

    这篇文章主要介绍了VC中CDC、HDC、pDC区别与联系及相互转换的方法,非常的详细,有需要的小伙伴可以参考下,希望对大家学习VC能够有所帮助。
    2015-11-11
  • Ubuntu16.04下配置VScode的C/C++开发环境

    Ubuntu16.04下配置VScode的C/C++开发环境

    这篇文章主要介绍了Ubuntu16.04下配置VScode的C/C++开发环境的教程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-03-03

最新评论