在開發窗體應用時通常會伴隨分頁,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元件可以實現更多有意思的功能,例如下面這個案例: