简介
QStandardItemModel 是标准的以项数据(item data)为基础的标准数据模型类,通常与 QTableView 组合成 Model/View 结构,实现通用的二维数据的管理功能。
QStandardItemModel:基于项数据的标准数据模型,可以处理二维数据。维护一个二维的项数据数组,每个项是一个 QStandardltem 类的变量,用于存储项的数据、字体格式、对齐方式等。
设置表格控件
QStandardItemModel::QStandardItemModel(int rows, int columns, QObject *parent = nullptr)
构造一个新的项目模型,该模型最初具有行,行和列,并且具有给定的父项。
创建表格
首先要创建数据模型,再界面上创建一个tableView,并设置该数据模型
QStandardItemModel *m_model; // 数据模型
m_model = new QStandardItemModel(10, 5, this); //创建数据模型-设置10行5列的表
ui->tableView->setModel(m_model); //设置数据模型
显示表格的内容
QStandardItem *QStandardItemModel::itemFromIndex(const QModelIndex &index) const
返回指向与给定索引关联的QStandardItem的指针。
通常,从视图处理基于QModelIndex的信号(例如QAbstractItemView :: activated())时,调用此函数是第一步。 在你的插槽中,以信号携带的QModelIndex作为参数调用itemFromIndex(),以获得指向相应QStandardItem的指针。
请注意,此函数将懒惰地为索引创建一个项(使用itemPrototype()),如果该索引处尚无项,则在父项的子表中进行设置。
如果index是无效索引,则此函数返回nullptr。
itemFromIndex()可以应用获取项目目前的索引视图。
当你收到信号时,你在给定的模型索引上调用itemFromIndex(),以获取指向该项目的指针,当你希望调用以索引为参数的模型/视图函数时,你必须获得项目的QModelIndex。
QStandardItemModel *m_model; //数据模型
QItemSelectionModel *m_seleModel; //item选择模型
m_model = new QStandardItemModel(10, 5, this); //创建数据模型
m_seleModel = new QItemSelectionModel(m_model); //Item选择模型
connect(m_seleModel,SIGNAL(currentChanged(QModelIndex,QModelIndex)), this,SLOT(on_currentChanged(QModelIndex,QModelIndex)));
ui->tableView->setModel(m_model);
ui->tableView->setSelectionModel(m_seleModel);
//状态栏的显示
void CustomMainWin::on_currentChanged(const QModelIndex ¤t, const QModelIndex &previous)
{
if(current.isValid())
{
QStandardItem *item;
item = m_model->itemFromIndex(current); //获取项数据
m_labCellText->setText("单元格内容:" + item->text()); //显示获取的数据
}
}