日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

qt MVC(一)

發布時間:2025/3/15 c/c++ 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 qt MVC(一) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

mvc是經典的三層結構,將數據,視圖和邏輯分離。Qt中的Model/View框架,實現了這個模式。在Qt中這個模式設計到三個類,model類,view類和delegate類。model類保存數據,view負責顯示,而delegate負責協調model和view之間的數據edit(編輯)和render(渲染)。

模型與視圖結構:
模型與數據通信,并提供接口
視圖從模型中獲取數據條目索引
代理繪制數據條目
通信方式:信號&槽
工作過程:
數據改變時,模型發出信號通知視圖;
用戶對界面操作時,視圖發出信號;
代理發出信號告知模型和視圖編輯器目前的狀態;

模型model(表示數據)
抽象基類QAbstractItemModel
列表的抽象基類QAbstractListModel、表格的抽象基類QAbstractTableModel
QDirModel類是文件與目錄的存儲模型
QStandardItemModel類 :
管理更復雜的樹結構件,其中每一個項目可以包含任意數據。
QStringListModel類:用于存儲簡單的QString的列表項。
QFileSystemModel:提供有關本地文件系統的文件和目錄信息。
QSqlQueryModel、QSqlTableModel、QSqlRelationalTableModel:使用模型/視圖約定來訪問數據庫
如果這些標準模型不能滿足要求,則可以繼承化QAbstractItemModel、QAbstractListModel或QAbstractTableModel來創建自定義模型。
視圖view(表示用戶界面)
抽象基類QAbstractItemView
QListView—QListWidget\QUndoView
QTableView—QTableWidget
QTreeView—QTreeWidget
QColumnView
QHeaderView
實際上:QListWidget、QTableWidget、QTreeWidget已經包含數據,是模型與視圖集成的類
雖然這些類是準備使用的實現,他們也可以被子類化,以提供自定義的視圖。
代理delegate(自定義數據條目item的顯示與編輯方式)
抽象基類QAbstractItemDelegate
QItemDelegate/QStyleItemDelegate
類QItemDelegate 由類QSqlRelationDelegate繼承

排序
在模型/視圖結構中有兩種接近的排序方式,選擇哪種方式取決于你的基礎模型。
如果你的模型是可排序的,也就是說,如果重新實現了QAbstractItemModel::sort()方法,QTableView和QTreeView都提供了一個API,允許以編程方式排序來排序模型數據。此外,可以啟用交互式排序(即允許用戶將數據通過單擊視圖的標題進行排序),由QHeaderView::sortIndicatorChanged()信號分別連接到QTableView:: sortByColumn()槽或QTreeView::sortByColumn()槽。
另一種方法,如果模型沒有所需的接口,或者如果想使用一個列表視圖來顯示數據,使用代理模型呈現數據視圖之前應轉換模型的結構。 項數據綁定:所有的model需要實現方法使視圖和代理能夠查詢model Models能夠提供各種程度的數據訪問限制:read-onlyresizingedited

如果只讀訪問,只需要實現下面幾個函數在繼承的子類中

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也支持列的插入和刪除操作。

#ifndef STRINGLISTNODEL_HPP #define STRINGLISTNODEL_HPP #include <QAbstractListModel> #include <QStringList>class StringListModel :public QAbstractListModel {Q_OBJECT public:StringListModel(const QStringList& stringList,QObject* parent = 0);~StringListModel();//重現實現的函數int rowCount(const QModelIndex&parent)const;QVariant data(const QModelIndex& index,int role)const;QVariant headerData(int section,Qt::Orientation orientation,int role)const;Qt::ItemFlags flags(const QModelIndex &index)const;bool setData(const QModelIndex& index, const QVariant& value, int role);private:QStringList m_slist;//存放數據的容器 };#endif #include "StringListModel.h" #include <QDebug>StringListModel::StringListModel(const QStringList& stringList, QObject* parent /*= 0*/) :QAbstractListModel(parent), m_slist(stringList) {}StringListModel::~StringListModel() { }//數據的行數 int StringListModel::rowCount(const QModelIndex&parent) const {return m_slist.length();//鏈表的長度 }//獲得對應index項的數據 QVariant StringListModel::data(const QModelIndex& index, int role)const {if (!index.isValid()){return QVariant();}//row從0開始,有效的范圍為0~鏈表長度減一if (index.row()>=m_slist.length()){return QVariant();}if (role==Qt::DisplayRole){return m_slist.at(index.row());}else{return QVariant();} }QVariant StringListModel::headerData(int section, Qt::Orientation orientation, int role) const {if (role!=Qt::DisplayRole){return QVariant();}if (orientation==Qt::Horizontal){return QString("col %1").arg(section);}else{return QString("row %1").arg(section);} }//被其他組件訪問時獲得每個item的信息 Qt::ItemFlags StringListModel::flags(const QModelIndex &index)const {if (!index.isValid()){return Qt::ItemIsEnabled;}return QAbstractItemModel::flags(index) | Qt::ItemIsEditable;//可編輯的 }//當視圖的顯示的數據被改變的時候,model也相應的改變 bool StringListModel::setData(const QModelIndex& index, const QVariant& value, int role) {//這個index必須是index的,必須還是可以編輯的if (index.isValid()&&role==Qt::EditRole){m_slist.replace(index.row(), value.toString());emit dataChanged(index, index);//發出這個信號,外部使用這信號沒用return true;}return false; }
QSplitter* mainSpliter = new QSplitter(Qt::Horizontal, 0); QListView* view = new QListView(mainSpliter);StringListModel * model = new StringListModel(QStringList() << "sss" << "yyyy" << "ffff", view); view->setModel(model); mainSpliter->show();





總結

以上是生活随笔為你收集整理的qt MVC(一)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。