MVC设计模式是起源于Smalltalk的一种与用户界面相关的设计模式。通过使用此模式,可以有效地分离数据和用户界面。MVC设计模式包括三个元素:表示数据的模型(Model)、表示用户界面的视图(View)和定义了用户在界面上操作的控制器(Controller)。

与MVC设计模式类似,Qt引入了模型/视图结构用于完成数据与界面的分离,即InterView框架。但不同的是,Qt的InterView框架把视图和控制器部件结合在一起,使得框架更为简洁。为了灵活地处理用户输入,InterView框架引入了代理(Delegate)。通过使用代理,能够自定义数据条目(Item)的显示和编辑方式。

Qt的模型/视图结构分为三部分:模式(Model)、视图(View)和代理(Delegate)。其中,模式与数据源通信,并为其他部件提供接口;而视图从模型中获得用来引用数据条目的模型索引(Model Index)。在视图中,代理负责绘制数据条目,当编辑条目时,代理和模型直接进行通信。模式/视图/代理之间通过信号和槽进行通信,如下图示:

学习QT之模型/视图结构_设计模式

  • 数据发生改变时,模型发出信号通知视图。
  • 用户对界面进行操作,视图发出信号。
  • 代理发出信号告知模型和视图编辑器目前的状态。

基本概念

1、模型(Model)

InterView框架中的所有模型都基于抽象基类QAbstractItemModel,此类由QProxyModel、QAbstractListModel、QAbstractTableModel、QAbstractProxyModel、QDirModel、QFileSystemModel、QHelpContentModel和QStandardItemModel类继承。其中,QAbstractListModel类和QAbstractTableModel类是列表和表格模型的抽象基类,如果需要实现列表或表格模型,则应从这两个类继承。完成QStringList存储的QStringListModel类继承自QAbstractListModel类,而与数据库有关的QSqlQueryModel类继承自QAbstractTableModel类;QAbstractProxyModel类是代理模型的抽象类;QDirModel类是文件和目录的存储模型。

2、视图(View)

InterView框架中的所有视图都基于抽象基类QAbstractItemView,此类有QColumnView、QHeaderView、QListView、QTableView和QTreeView类继承。其中QListView类由QUndoView类和QListWidget类继承;QTableView类由QTableWidget类继承;QTreeView类由QTreeWidget类继承。而QListWidget类、QTableWidget类和QTreeWidget类实际上已经包含了数据,是模型/视图继承在一起的类。

3、代理(Delegate)

InterView框架中的所有代理都基于QAbstractItemDelegate,此类由QItemDelegate和QStyledItemDelegate类继承,其中,QItemDelegate类由表示数据库中关系代理的QSqlRelationalDelegate类继承。