(一) Qt Model/View 的简单说明
2015-07-16 23:42
597 查看
(一)使用Qt Model/View的好处
1、利用 Qt 的模型 / 视图架构,我们可以只从模型中获取实际在视图中显示所需要的数据。这样在处理非常大的数据集的时候,可以更加快速,而不至于降低性能。通过把一个模型注册到两个或多个视图,就可以让用户使用不同的方式查看数据以及和数据交互。 Qt 对于多个视图会自动保持同步,从而使对一个视图的改变会影响到全部视图。2、模型 / 视图架构的另外一个好处是:如果决定改变底层数据集的存储方式,只需要修改模型,而视图仍能够继续正常工作。
(二)预定义模型
为了充分使用Qt 模型 / 视图的好处,我们不想再采取 Qt 以前版本中的项视图简便类QListWidget、 QTableWidget、 QTreeWidget。它们需要读取要被设置到一个项视图窗口部件中的所有数据、使用项对象呈现数据元素并且回写数据源。Qt4使用预定义模型 划线的是Qt4.7 中已经不再推介的 Model 类
QStringListModel | 用于存储简单的字符串列表。 |
QStandardItemModel | 存储任意的分层次的数据,管理复杂的树型结构数据项,每项都可以包含任意数据。 |
QDirModel(最新版已经用QfileSystemModel代替这个类了) | 封装本地文件系统 |
QSqlQueryModel | 封装一个SQL数据集 |
QSqlTableModel | 封装一个SQL表 |
QSqlRelationTableModel | 利用外键封装一个SQL表 |
QSortFileterProxyModel | 排序和/或筛选另一个模型 |
假如这些标准Model不满足你的需要,你应该子类化QAbstractItemModel,QAbstractListModel或是QAbstractTableModel来定制。 |
(三)视图
Qt中视图类的继承关系如下图
(三)委托Delegate
Qt中委托的继承关系见下图来自http://qimo601.iteye.com/blog/1534309
相关文章推荐
- Qt连接Sql server错误ConnectionOpen (Connect()). QODBC3: Unable to connect"
- pyQt不同窗体间的值传递(二)——使用信号槽机制
- Qt通过ODBC来操作Excel
- Visual Studio下Qt调用IDL
- ubuntu下QT与opencv的配置安装
- QT POST/GET 发送/获取网页数据
- qt5 mouseless 多子页面切换测试
- Qt5 mouseless 测试
- Qt数据库:(一)简介
- win8 64bit/win7 32bit/winxp 32bit +QT+opencv环境配置教程,亲测成功
- ArcGIS QT开发:ArcGIS Runtime dll不能被QT识别问题
- mac osx上为qt应用生成debug symbol
- qt中qDebug()无法输出解决办法
- Qt读写INI配置文件
- Qt下 QString转char*
- QT 应用程序自动重启
- Qt学习之路之ODBC访问SQLserver数据库
- Qt浅谈之二十九Qt多线程
- QT IDE经验总结
- vs2010 qt创建自定义部件类比如MyLineEdit