C/C++ Qt TabWidget 實現多窗體建立

lyshark發表於2021-12-03

在開發窗體應用時通常會伴隨分頁,TabWidget元件配合自定義Dialog元件,可實現一個複雜的多窗體分頁結構,此類結構也是ERP等軟體通用的窗體佈局方案。

首先先來實現一個只有TabWidget分頁的簡單結構,如下窗體佈局,佈局中空白部分是一個TabWidget元件,下方是一個按鈕,當使用者點選按鈕時,自動將該窗體新增到TabWidget元件中。

該頁面關聯程式碼如下所示,當使用者點選on_pushButton_clicked()時自動新增一個窗體並將窗體的Tab設定為指定的IP地址。

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <iostream>

MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    ui->tabWidget->setVisible(false);
    ui->tabWidget->clear();//清除所有頁面
    ui->tabWidget->tabsClosable(); //Page有關閉按鈕,可被關閉
}

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

// 定義函式來獲取當前Table名字
QString MainWindow::GetTableNumber()
{
    QString ref = QString(ui->tabWidget->currentIndex());
    return ref;
}

// https://www.cnblogs.com/lyshark
void MainWindow::on_pushButton_clicked()
{
    FormDoc *ptr = new FormDoc(this);                // 新建選項卡
    ptr->setAttribute(Qt::WA_DeleteOnClose);         // 關閉時自動銷燬

    int cur = ui->tabWidget->addTab(ptr,QString::asprintf(" 192.168.1.%d",ui->tabWidget->count()));

    ui->tabWidget->setTabIcon(cur,QIcon(":/image/1.ico"));

    ui->tabWidget->setCurrentIndex(cur);
    ui->tabWidget->setVisible(true);
}

// 關閉Tab時執行
void MainWindow::on_tabWidget_tabCloseRequested(int index)
{
    if (index<0)
        return;
    QWidget* aForm=ui->tabWidget->widget(index);
    aForm->close();
}

// 在無Tab頁面是預設禁用
void MainWindow::on_tabWidget_currentChanged(int index)
{
    Q_UNUSED(index);
    bool en=ui->tabWidget->count()>0;
    ui->tabWidget->setVisible(en);
}

其中的每一個子窗體,都需要動態獲取父窗體指標根據指標對自身進行操作,子窗體程式碼如下.

#include "formdoc.h"
#include "ui_formdoc.h"
#include "mainwindow.h"

#include <QVBoxLayout>
#include <iostream>

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

    QVBoxLayout *Layout = new QVBoxLayout();
    Layout->setContentsMargins(2,2,2,2);
    Layout->setSpacing(2);
    this->setLayout(Layout);

    MainWindow *parWind = (MainWindow*)parentWidget(); //獲取父視窗指標
    QString ref = parWind->GetTableNumber();           // 獲取選中標籤索引
    std::cout << ref.toStdString().data() << std::endl;   // By: LyShark
}

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

程式碼執行效果如下:

Tab元件如果配合ToolBar元件可以實現更多有意思的功能,例如下面這個案例:

相關文章