QTableWidget 在 QTabWidget 中起作用
QTableWidget functions in a QTabWidget
如何在 QTabWidget 选项卡中选择 QTableWidget 单元格?
我如何实现:
Wbook
和Ssheet
表示工作簿和电子表格。我在容器类ExcelMockWidget
实现它们。一旦将Ssheet
单元格添加到Wbook
选项卡中,我就无法弄清楚如何访问它们。 我确实知道一旦我插入Wbook
Ssheet
就会被投射到QWidget
中,但这有关系吗?
这是我的ExcelView示例存储库。
这是我的课程:
ExcelMockWidget:
class ExcelMockWidget : public QWidget{
Q_OBJECT
public:
explicit ExcelMockWidget(QWidget *parent = 0);
~ExcelMockWidget();
void addCell(int row, int column, QVariant cell);
void addSheet(int index, QString title);
void setSheetProperties(int rows, int columns, QStringList headers);
signals:
void indexChanged(int);
public slots:
void emitIndexChange(int index);
void select(int row, int column);
private:
Wbook *book;
Ssheet *sheet;
};
ExcelMockWidget::ExcelMockWidget(QWidget *parent) : QWidget(parent) {
book = new Wbook;
QVBoxLayout *container;
container = new QVBoxLayout;
container->addWidget(book);
setLayout(container);
connect(book,SIGNAL(changedIndex(int)),this,SLOT(emitIndexChange(int)));
}
ExcelMockWidget::~ExcelMockWidget(){
}
void ExcelMockWidget::addCell(int row, int column, QVariant cell){
sheet->setCell(row,column,cell);
}
void ExcelMockWidget::addSheet(int index, QString title){
book->createTab(index, title, sheet);
}
void ExcelMockWidget::setSheetProperties(int rows, int columns, QStringList headers){
sheet = new Ssheet;
sheet->setSheetColumnSpan(columns);
sheet->setSheetRowSpan(rows);
sheet->setSheetHeaders(headers);
}
void ExcelMockWidget::emitIndexChange(int index){
emit indexChanged(index);
}
void ExcelMockWidget::select(int row, int column){
book->selectCell(row, column);
}
文书:
namespace Ui {
class Wbook;
}
class Wbook : public QWidget{
Q_OBJECT
public:
explicit Wbook(QWidget *parent = 0);
~Wbook();
void createTab(int index, QString title, Ssheet *worksheet);
void selectTab(int tab);
void selectCell(int row, int column);
signals:
void changedIndex(int);
public slots:
void emitIndexChange(int index);
protected:
private:
Ui::Wbook *ui;
};
Wbook::Wbook(QWidget *parent) : QWidget(parent), ui(new Ui::Wbook){
ui->setupUi(this);
connect(ui->tabWidget,SIGNAL(currentChanged(int)),this,SLOT(emitIndexChange(int)));
}
Wbook::~Wbook(){
delete ui;
}
void Wbook::createTab(int index, QString title, Ssheet *worksheet){
ui->tabWidget->insertTab(index, worksheet, title);
}
void Wbook::selectTab(int tab){
// 0 for no selection and 1 -> for created tabs.
ui->tabWidget->setCurrentIndex(tab);
}
void Wbook::selectCell(int row, int column){
ui->tabWidget->currentWidget()->childAt(row+1,column+1)->setFocus();
}
void Wbook::emitIndexChange(int index){
emit changedIndex(index);
}
表:
namespace Ui {
class Ssheet;
}
class Ssheet : public QWidget{
Q_OBJECT
public:
explicit Ssheet(QWidget *parent = 0);
~Ssheet();
void setSheetTitle(QString title);
void setSheetRowSpan(int n);
void setSheetColumnSpan(int n);
void setSheetHeaders(QStringList headers);
void setCell(int row, int column, QVariant cell);
void selectRow(int row);
void selectCell(int row, int column);
private:
Ui::Ssheet *ui;
};
Ssheet::Ssheet(QWidget *parent) : QWidget(parent), ui(new Ui::Ssheet){
ui->setupUi(this);
ui->table->verticalHeader()->setVisible(false);
ui->table->setEditTriggers(QAbstractItemView::NoEditTriggers);
ui->table->setSelectionBehavior(QAbstractItemView::SelectItems);
ui->table->setSelectionMode(QAbstractItemView::SingleSelection);
ui->table->setStyleSheet("QTableWidget {selection-background-color: black; selection-color: white}");
ui->table->setShowGrid(false);
}
Ssheet::~Ssheet(){
delete ui;
}
void Ssheet::setSheetTitle(QString title){
ui->table->setObjectName(title);
}
void Ssheet::setSheetRowSpan(int n){
ui->table->setRowCount(n);
}
void Ssheet::setSheetColumnSpan(int n){
ui->table->setColumnCount(n);
}
void Ssheet::setSheetHeaders(QStringList headers){
ui->table->setHorizontalHeaderLabels(headers);
}
void Ssheet::setCell(int row, int column, QVariant cell){
QTableWidgetItem *input = new QTableWidgetItem;
input->setData(0,cell);
ui->table->setItem(row-1,column,input);
}
void Ssheet::selectCell(int row, int column){
ui->table->setCurrentCell(row,column);
}
似乎您只有一个Ssheet
硬编码到ExcelMockWidget
类中。 猜猜您需要在每次调用Wbook::createTab()
时创建新Ssheet
。喜欢这个:
book->createTab(index, title, new Ssheet(this));
然后在需要时获得带有QTabWidget::widget()
的适当Ssheet
小部件:
sheet = static_cast<Ssheet*>(QTabWidget::widget(page));
而且......访问它的细胞!
相关文章:
- 我的神经网络不起作用 [XOR 问题]
- 在C++程序中输入的文本文件将不起作用,除非文本被复制和粘贴
- C++映射:具有自定义类的运算符[]不起作用(总是返回0)
- C++为什么尽管我调用了void函数,它却不起作用
- 为什么在保护模式下继承升级不起作用
- 循环在计数器中不起作用
- 在其他文件中创建类时在 c++ 项目中不起作用
- Visual studio代码重构似乎不起作用(例如,重命名符号-f2)
- 为什么二进制搜索在我的测试中不起作用
- 我的代码中有错误吗?使用BGI图形的C++代码对我不起作用
- 为什么 const std::p air<K,V>& 在 std::map 上基于范围的 for 循环不起作用?
- 带有指定长度字符* 参数的 std::regex_search 在 VS2017 中不起作用?
- Bjarne Stroustrup Book - std_lib_facilities.h - 不起作用(未知类型名称)
- 为什么简单的算术减法在"if"条件下不起作用?
- 为什么Stroustup书中的has_f不起作用
- 你能检查一下为什么在这个代码中从链接列表中删除项目不起作用吗
- 嵌套While循环不起作用(C++问题)
- C++Matching Brackets 2解决方案不起作用
- 为什么这段代码不起作用,我该如何解决?
- QTableWidget 在 QTabWidget 中起作用