QT-QStackedWidget多窗口应用

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

前言

多窗口应用例如某微信页面由123个布局组成。

1-基本流程
   页面1控制页面2通过选择页面1上的按钮或控件
   页面2控制页面3通过选择页面2上的按钮或控件

2-其中页面2中的页面很多是不同的页面3也同理那其实就是在同一个区域显示不同页面。

3-那么怎么快捷实现这个功能呢在qt中我们知道页面其实就是一个个widget然后qt有自带的控件来实现这个功能就是QStackedWidget这个控件可以保存我们的每一个页面然后可以选择显示某个页面。

4-我们实现一个例子

1-先看效果图这里实现页面选择用的下拉框看起来比较low做成微信列表那样原理也是一样的为了方便简单实现方便理解所以使用的下拉框。

基本思路

        1-首先布局主窗口,需要一个选择窗口里面放一个选择框一个显示窗口放一个QStackedWidget

        2-新建3个带ui的widget文件每个ui做好页面

        3-main函数初始化

                1-定义3个页面的对象放入QList中

                2-把3个页面添加到QStackedWidget控件中

                3-下拉框添加选择事件通过下拉框索引获取QList,或者直接用索引修改QStackedWidget当前页面

1-首先布局主窗口  

  2-新建三个带ui的widget

        带ui是为了方便后续设计页面内容如果用代码生成会比较累。

3个独立的页面自己设计一下。

3-材料都准备好了mainwindow添加代码很简单就几句。
头文件

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>
#include "form1.h"
#include "form2.h"
#include "form3.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_comboBox_currentIndexChanged(int index);

private:
    Ui::MainWindow *ui;

    QList<QWidget*> win_lits;
};
#endif // MAINWINDOW_H

源文件

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

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

    Form1 *fwin1= new Form1();
    Form2 *fwin2= new Form2();
    Form3 *fwin3= new Form3();

    win_lits.append((QWidget*)fwin1);
    win_lits.append((QWidget*)fwin2);
    win_lits.append((QWidget*)fwin3);

    ui->stackedWidget->addWidget(fwin1);
    ui->stackedWidget->addWidget(fwin2);
    ui->stackedWidget->addWidget(fwin3);

    ui->stackedWidget->setCurrentWidget(fwin2);

    ui->comboBox->addItem("fwin1");
    ui->comboBox->addItem("fwin2");
    ui->comboBox->addItem("fwin3");
}

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


void MainWindow::on_comboBox_currentIndexChanged(int index)
{
    ui->stackedWidget->setCurrentWidget(win_lits[index]);
    //或者直接用index
    //ui->stackedWidget->setCurrentIndex(index);
}

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6