Функции QTableWidget в QTabWidget

Как выбрать ячейку QTableWidget на вкладке QTabWidget?

Как я реализую:

Wbook а также Ssheet представлять рабочую книгу и электронную таблицу. Я реализую их под ExcelMockWidget контейнерный класс. Я не могу понять, как получить доступ к моей Ssheet клетки, как только они были добавлены к Wbook Вкладка. я понимаю Ssheet брошен в QWidget как только я вставляю в свой Wbook, но будет ли это иметь значение?

Вот мой репозиторий для Пример 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);
}

Wbook:

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);
}

Ssheet:

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);
}

0

Решение

Кажется, у вас есть только один Ssheet закодировано в ExcelMockWidget учебный класс. Думаю, вам нужно создать новый Ssheet на каждый звонок Wbook::createTab(), Как это:

book->createTab(index, title, new Ssheet(this));

Тогда получите правильное Ssheet виджет с QTabWidget::widget() когда вам это нужно:

sheet = static_cast<Ssheet*>(QTabWidget::widget(page));

И … получить доступ к его ячейкам!

1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]