实现步骤如下:
在QWidget窗口中添加两个QPushButton按钮,分别命名为“前进”和“后退”,并连接到对应的槽函数。
在QWidget窗口中添加一个QTableWidget,并交叉引用为成员变量ui_QTableWidget。
定义一个QStack
类型的成员变量stackIndex,用于存储tab的索引。 在每次切换tab时,将当前tab的索引压入stackIndex中。
在前进或后退按钮的槽函数中,根据按钮的不同,弹出或压入stackIndex中的索引,并使用setCurrentIndex()函数将ui_QTableWidget的当前tab切换到对应的索引位置。
为了支持多次前进功能,在前进或后退时需要判断stackIndex是否为空,以避免程序崩溃。
为了支持最多存20个表的历史记录,需要在每次压入索引时,判断stackIndex中元素的数量是否大于20,如果是,则弹出最早加入的元素。
示例代码如下:
#include <QStack>
#include <QWidget>
#include <QPushButton>
#include <QTableWidget>
class Widget : public QWidget
{
Q_OBJECT
public:
explicit Widget(QWidget *parent = nullptr);
private slots:
void on_btnForward_clicked();
void on_btnBackward_clicked();
void on_tabChanged(int index);
private:
QTableWidget *ui_QTableWidget;
QPushButton *ui_btnForward;
QPushButton *ui_btnBackward;
QStack<int> stackIndex;
};
Widget::Widget(QWidget *parent)
: QWidget(parent)
{
// 初始化界面
ui_QTableWidget = new QTableWidget(this);
ui_QTableWidget->setRowCount(3);
ui_QTableWidget->setColumnCount(3);
ui_btnForward = new QPushButton("前进", this);
ui_btnBackward = new QPushButton("后退", this);
QVBoxLayout *layout = new QVBoxLayout(this);
layout->addWidget(ui_QTableWidget);
layout->addWidget(ui_btnForward);
layout->addWidget(ui_btnBackward);
// 连接信号和槽函数
connect(ui_QTableWidget, &QTabWidget::currentChanged, this, &Widget::on_tabChanged);
connect(ui_btnForward, &QPushButton::clicked, this, &Widget::on_btnForward_clicked);
connect(ui_btnBackward, &QPushButton::clicked, this, &Widget::on_btnBackward_clicked);
}
void Widget::on_tabChanged(int index)
{
// 每次切换tab时,将当前tab的索引压入stackIndex中
stackIndex.push(index);
}
void Widget::on_btnForward_clicked()
{
if (!stackIndex.isEmpty())
{
// 弹出stackIndex中的最上层元素,并使用setCurrentIndex()函数切换tab到对应位置
int index = stackIndex.pop();
ui_QTableWidget->setCurrentIndex(index);
}
}
void Widget::on_btnBackward_clicked()
{
if (!stackIndex.isEmpty())
{
// 弹出stackIndex中的最上层元素,并使用setCurrentIndex()函数切换tab到对应位置
int index = stackIndex.top();
ui_QTableWidget->setCurrentIndex(index);
// 将index压入stackIndex中
stackIndex.push(index);
}
}