Qt mvc学习一

来源:互联网 发布:sql删除某一行数据 编辑:程序博客网 时间:2024/05/21 06:48

 mvc是经典的三层结构,将数据,视图和逻辑分离。Qt中的Model/View框架,实现了这个模式。在Qt中这个模式设计到三个类,model类,view类和delegate类。model类保存数据,view复制显示,而delegate负责协调model和view之间的数据edit(编辑)和render(渲染)。

                  

这些在model子类中需要实现的方法可以分为三组。

项数据绑定:所有的model需要实现方法使视图和代理能够查询model...

Models能够提供各种程度的数据访问限制:read-onlyresizingedited

Read-Only access 只读访问

如果只读访问,只需要实现下面几个函数在继承的子类中

Flags,其他的组件可以通过这个得知每个Item的信息,在大多数的models中,包含Qt::ItemIsEnable,Qt::ItemIsSelectable

data,被用来提供数据给视图和代理,一般的,models只要提供Qt::DisplayRole和任何程序特殊的角色,也有一些特殊的Qt::ToolTipRole等,详细可以看Qt::ItemDataRole

headerData,为视图的头部提供信息数据。

rowCount提供这个model有多少行数据。

上述的四个函数在任何类型的model中都要实现,不管是QAbstractListModel还是QAbstractTableModel。另外,下面的函数必须被实现,在QAbstractTableModelQAbstractItemModel中,columnCount

编辑项目

可编辑的模型允许数据项被修改,和可以提供函数来插入数据在行和列。

Flags,必须包含Qt::ItemDataRole

setData,被用来修改和特殊的模型索引相关的项目。修改的数据必须是Qt::EditRole,发送一个dataChanged信号。

setHeaderData,用来修改水平和垂直的头信息,发出一个headerDataChanged信号。

改变modelssize

所有类型的model能够提供插入和移除行。Table Model和分级的model也支持列的插入和删除操作。


下面的例子是基于QAbstractListModel实现的一个QStringListModel

[cpp] view plaincopyprint?
  1. /************************************************ 
  2. * 
  3. *author:周翔 
  4. *e-mail:604487178@qq.com 
  5. *blog:http://blog.csdn.net/zhx6044 
  6. * 
  7. * 
  8. *************************************************/  
  9.   
  10. #ifndef STRINGLISTMODEL_HPP  
  11. #define STRINGLISTMODEL_HPP  
  12.   
  13. #include <QAbstractListModel>  
  14. #include <QStringList>  
  15.   
  16. class StringListModel : public QAbstractListModel  
  17. {  
  18.     Q_OBJECT  
  19. public:  
  20.     explicit StringListModel( const QStringList &stringList, QObject *parent = 0);  
  21.     //重新实现的函数  
  22.     int rowCount(const QModelIndex &parent) const;  
  23.     QVariant data(const QModelIndex &index, int role) const;  
  24.     QVariant headerData(int section, Qt::Orientation orientation, int role) const;  
  25.     Qt::ItemFlags flags(const QModelIndex &index) const;  
  26.     bool setData(const QModelIndex &index, const QVariant &value, int role);  
  27. signals:  
  28.       
  29. public slots:  
  30. private:  
  31.     QStringList m_slist;//存放数据的容器  
  32.       
  33. };  
  34.   
  35. #endif // STRINGLISTMODEL_HPP  
  36.   
  37. /************************************************ 
  38. * 
  39. *author:周翔 
  40. *e-mail:604487178@qq.com 
  41. *blog:http://blog.csdn.net/zhx6044 
  42. * 
  43. * 
  44. *************************************************/  
  45.   
  46. #include "stringlistmodel.hpp"  
  47. #include <QDebug>  
  48.   
  49. StringListModel::StringListModel(const QStringList &stringList, QObject *parent) :  
  50.     QAbstractListModel(parent),  
  51.     m_slist(stringList)  
  52. {  
  53. }  
  54. /** 
  55.  * @brief StringListModel::rowCount model数据的行数 
  56.  * @return  
  57.  */  
  58. int StringListModel::rowCount(const QModelIndex &/*parent*/const  
  59. {  
  60.     return m_slist.length();//就是链表的长度  
  61. }  
  62. /** 
  63.  * @brief StringListModel::data 获得对应index项的数据 
  64.  * @param index 
  65.  * @param role 数据的角色 
  66.  * @return  
  67.  */  
  68. QVariant StringListModel::data(const QModelIndex &index, int role) const  
  69. {  
  70.     if (!index.isValid()) {  
  71.         return QVariant();  
  72.     }  
  73.     //row从0开始,有效的范围为0~链表长度减1  
  74.     if (index.row() >= m_slist.length()) {  
  75.         return QVariant();  
  76.     }  
  77.     if (role == Qt::DisplayRole) {  
  78.         return m_slist.at(index.row());  
  79.     } else {  
  80.         return QVariant();  
  81.     }  
  82. }  
  83.   
  84. QVariant StringListModel::headerData(int section, Qt::Orientation orientation, int role) const  
  85. {  
  86.     if (role != Qt::DisplayRole) {  
  87.         return QVariant();  
  88.     }  
  89.     if (orientation == Qt::Horizontal) {  
  90.         return QString("col %1").arg(section);  
  91.     } else {  
  92.         return QString("row %1").arg(section);  
  93.     }  
  94. }  
  95. /** 
  96.  * @brief StringListModel::flags 被其他组件访问时获得每个Item的信息 
  97.  * @param index 
  98.  * @return  
  99.  */  
  100. Qt::ItemFlags StringListModel::flags(const QModelIndex &index) const  
  101. {  
  102.     if (!index.isValid()) {  
  103.         return Qt::ItemIsEnabled;  
  104.     }  
  105.     return QAbstractItemModel::flags(index) | Qt::ItemIsEditable;//可编辑的  
  106. }  
  107. /** 
  108.  * @brief StringListModel::setData 当视图的显示的数据被改变的时候,model也相应的改变 
  109.  * @param index 
  110.  * @param value 
  111.  * @param role 
  112.  * @return  
  113.  */  
  114. bool StringListModel::setData(const QModelIndex &index, const QVariant &value, int role)  
  115. {  
  116.     //这个index必须是有效的,必须还是可编辑的  
  117.     if (index.isValid() && role == Qt::EditRole) {  
  118.         m_slist.replace(index.row(),value.toString());  
  119.         emit dataChanged(index,index);//发出这个信号,外部使用这个信号没用  
  120.         return true;  
  121.     }  
  122.     return false;  
  123.   
  124. }  


使用这个model类


[cpp] view plaincopyprint?
  1. StringListModel *model = new StringListModel(QStringList() << "chenchen"  
  2.                                                  << "love"  
  3.                                                  << "zhou xiang",this);  
  4.     ui->listView->setModel(model);  
  5.     //这边的listView是一个QListView对象  


修改数据项


转自:http://blog.csdn.net/zhx6044/article/details/9009117

0 0
原创粉丝点击