Qt提供了一套Model/View框架供开发者使用,那里我们简要介绍下怎么样运用自定义的数据模型皇冠现金app

让人侧目,Qt提供了一套Model/View框架供开发者使用,Model用来提供数据,
View则用来提供视觉层的显得。实际上那是一套遵从MVC设计情势的GUI框架,因为Qt还提供了暗中认可的Delegate作为Controller来作为控制器。

显著,Qt提供了一套Model/View框架供开发者使用,Model用来提供数据,
View则用来提供视觉层的显得。实际上那是一套坚守MVC设计情势的GUI框架,因为Qt还提供了暗许的Delegate作为Controller来作为控制器。

皇冠现金app 1

皇冠现金app 2

MVC的补益那里就不多说了,为了开发者使用方便,Qt还提供了依照项(Item)的Model/View达成—-QXxxWidget(QTableWidget、QListWidget等),对于有个别简约的选拔场景,那早已足足了并且利用起来尤其有益。那里大家大致介绍下什么选拔自定义的数据模型,来满意各样花式的渴求。

MVC的好处那里就不多说了,为了开发者使用方便,Qt还提供了基于项的Model/View完成—-QXxxWidget(QTableWidget、QListWidget等),对于部分简易的选拔场景,那早就够用了并且利用起来1贰分便于。那里大家大致介绍下什么样使用自定义的数据模型,来满足各个花式的要求。

一. 取舍适宜的Model继承

一. 选项合适的Model继承

一.一 标准数据模型

Qt落到实处了四类标准数据模型供大家在差别的光景下使用:

  1. QStringListModel:存储字符串列表
  2. QStandardItemModel:存储树状结构的任性数据
  3. QFileSystemModel:存储本土文件系统上的文本和目录音信
  4. QSqlQueryModel、QSqlRelationalTableModel、QSqlTableModel:存储关系型数据库中的数据

借使使用景况和上述情形之1比较一般,则足以思念继续对应的模型类,并再一次达成少数虚函数。

1.壹 标准数据模型

Qt兑现了肆类标准数据模型供大家在分歧的光景下行使:

  1. QStringListModel:存储字符串列表
  2. QStandardItemModel:存储树状结构的妄动数据
  3. QFileSystemModel:存储地面文件系统上的公文和目录新闻
  4. QSqlQueryModel、QSqlRelationalTableModel、QSqlTableModel:存储关系型数据库中的数据

即使选用情状和上述景况之一比较相似,则能够牵挂继续对应的模子类,并再次落成少数虚函数。

一.贰 抽象数据模型

抽象数据模型有③类:

  1. QAbstractItemModel:项模型,那是拥有数据模型的基类。
  2. QAbstractListModel:列表模型,结合QListView使用最合适。
  3. QAbstractTableModel:表模型,结合QTableView使用最合适。

  4. 后续抽象模型


Qt官方提供了全面包车型地铁文档来帮衬开发者来自定义模型类。根据官网,子类化模型要求开发者完成的效益(即要求再一次完成的虚函数)按成效来分能够分成三类:

  • 项数据处理:那又足以分为3类—-只读访问可编辑调动大小
  • 导航和下标创制。
  • 拖拽和MIME类型处理。

我们只必要遵照本人的效能须求来落到实处个中的有的虚函数。

一.2 抽象数据模型

空泛数据模型有叁类:

  1. QAbstractItemModel:项模型,那是拥有数据模型的基类。
  2. QAbstractListModel:列表模型,结合QListView使用最合适。
  3. QAbstractTableModel:表模型,结合QTableView使用最合适。

  4. 接轨抽象模型


Qt官方提供了完善的文书档案来赞助开发者来自定义模型类。遵照官网,子类化模型要求开发者实现的效益(即必要重新达成的虚函数)按效益来分能够分为3类:

  • 项数据处理:这又有什么不可分成叁类—-只读访问可编辑调整大小
  • 导航和下标创造。
  • 拖拽和MIME类型处理。

大家只要求服从本身的效果须要来促成个中的有的虚函数。

三. 完成贰个自定义模型

那边我们来兑现一个自定义模型,并在QTableView中应用它,由此大家选拔继续QAbstractTableModel,那样我们须求做的更动最少。但运用QTableModel并不意味着大家的数据结构就是Table状的,例如上面包车型地铁例子中咱们历来不须求中间数据结构。

上边大家要促成那样3个数据模型:

  • 中间不存款和储蓄数据结构
  • 表中的每2个单元拿到的多少是整型,并且值为列下标的平方
  • 模型中的数据为只读

3. 贯彻三个自定义模型

此间大家来落到实处一个自定义模型,并在QTableView中选用它,由此大家采纳继续QAbstractTableModel,那样大家供给做的改变最少。但利用QTableModel并不表示我们的数据结构正是Table状的,例如上边包车型大巴例证中我们平素不必要中间数据结构。

上边我们要兑现那样一个数据模型:

  • 其间不存款和储蓄数据结构
  • 表中的每3个单元得到的多少是整型,并且值为列下标的平方
  • 模型中的数据为只读

3.1 实现CustomeModel

该模型继承自QAbstractTableModel,作为只读模型,大家只须要贯彻以下多少个虚函数:

virtual Qt::ItemFlags flags(const QModelIndex &index) const;
virtual QVariant data(const QModelIndex &index, int role) const;
virtual QVariant headerData(int section, Qt::Orientation orientation, int role) const;
virtual int rowCount(const QModelIndex &parent) const;
virtual int columnCount(const QModelIndex &parent) const;

data()函数与项数据有关,那里数据有壹些种剧中人物(role),最中央的正是Qt::DisplayRole,那里为了促成居中成效,大家还处理了Qt::TextAlignmentRole角色:

QVariant MyTableModel::data(const QModelIndex &index, int role) const
{
    if (role == Qt::DisplayRole) {
        return index.column() * index.column();
    }
    if (role == Qt::TextAlignmentRole) {
        return Qt::AlignCenter;
    }
    return QVariant();
}

headerData()函数提供表头数据,包含多少个方向(垂直、水平)的表头。同样,那里的数码也有几许种剧中人物,我们只处理Qt::DisplayRole

QVariant MyTableModel::headerData(int section, Qt::Orientation orientation, int role) const
{
    if (orientation == Qt::Vertical) {
        if (role == Qt::DisplayRole)    return QVariant("row:" + QString::number(section));
        else                            return QVariant();
    }
    if (orientation == Qt::Horizontal) {
        if (role == Qt::DisplayRole)    return QVariant("column:" + QString::number(section));
        else                            return QVariant();
    }
}

rowCount()columnCount()回来数据模父下标(QModelIndex)的行和列数量,那里我们要甄别下标是或不是可行:因为全套表模型的父下标为无效下标,我们再次来到表模型的行列数量;当下标有效时,我们再次回到的是父下标指向处的子表的行列

//  if `parent` is invalid, return the whole table row count!
//  else return the children row count of the `parent`
int MyTableModel::rowCount(const QModelIndex &parent) const
{
    if (parent.isValid())
        return 0;
    else
        return 10;
}

3.1 实现CustomeModel

该模型继承自QAbstractTableModel,作为只读模型,大家只要求贯彻以下多少个虚函数:

virtual Qt::ItemFlags flags(const QModelIndex &index) const;virtual QVariant data(const QModelIndex &index, int role) const;virtual QVariant headerData(int section, Qt::Orientation orientation, int role) const;virtual int rowCount(const QModelIndex &parent) const;virtual int columnCount(const QModelIndex &parent) const;

data()函数与项数据有关,那里数据有几许种剧中人物,最大旨的便是Qt::DisplayRole,那里为了兑现居中效果,大家还处理了Qt::TextAlignmentRole角色:

QVariant MyTableModel::data(const QModelIndex &index, int role) const{    if (role == Qt::DisplayRole) {        return index.column() * index.column();    }    if (role == Qt::TextAlignmentRole) {        return Qt::AlignCenter;    }    return QVariant();}

headerData()函数提供表头数据,包罗四个方向的表头。同样,这里的数目也有1些种角色,大家只处理Qt::DisplayRole

QVariant MyTableModel::headerData(int section, Qt::Orientation orientation, int role) const{    if (orientation == Qt::Vertical) {        if (role == Qt::DisplayRole)    return QVariant("row:" + QString::number;        else                            return QVariant();    }    if (orientation == Qt::Horizontal) {        if (role == Qt::DisplayRole)    return QVariant("column:" + QString::number;        else                            return QVariant();    }}

rowCount()columnCount()回到数据模父下标(QModelIndex)的行和列数量,这里大家要辨别下标是不是有效:因为整整表模型的父下标为无效下标,我们重回表模型的行列数量;当下标有效时,大家回去的是父下标指向处的子表的连串

//  if `parent` is invalid, return the whole table row count!//  else return the children row count of the `parent`int MyTableModel::rowCount(const QModelIndex &parent) const{    if (parent.isValid        return 0;    else        return 10;}

3.2 运营结果

皇冠现金app 3

完全代码见此处

三.贰 运维结果

皇冠现金app 4

完整代码见此处。

相关文章