QAbstractTableModel Class Reference
The QAbstractTableModel class provides an abstract model that can be subclassed to create table models. More...
Inherited by: QSqlQueryModel.
|QAbstractTableModel ( QObject * parent = 0 )|
Reimplemented Public Functions
|virtual bool||dropMimeData ( const QMimeData * data, Qt::DropAction action, int row, int column, const QModelIndex & parent )|
|virtual QModelIndex||index ( int row, int column, const QModelIndex & parent = QModelIndex() ) const|
Additional Inherited Members
- 1 property inherited from QObject
- 2 public slots inherited from QAbstractItemModel
- 1 public slot inherited from QObject
- 18 signals inherited from QAbstractItemModel
- 1 signal inherited from QObject
- 7 static public members inherited from QObject
- 21 protected functions inherited from QAbstractItemModel
- 8 protected functions inherited from QObject
- 1 protected slot inherited from QAbstractItemModel
The QAbstractTableModel class provides an abstract model that can be subclassed to create table models.
QAbstractTableModel provides a standard interface for models that represent their data as a two-dimensional array of items. It is not used directly, but must be subclassed.
Since the model provides a more specialized interface than QAbstractItemModel, it is not suitable for use with tree views, although it can be used to provide data to a QListView. If you need to represent a simple list of items, and only need a model to contain a single column of data, subclassing the QAbstractListModel may be more appropriate.
The rowCount() and columnCount() functions return the dimensions of the table. To retrieve a model index corresponding to an item in the model, use index() and provide only the row and column numbers.
When subclassing QAbstractTableModel, you must implement rowCount(), columnCount(), and data(). Default implementations of the index() and parent() functions are provided by QAbstractTableModel. Well behaved models will also implement headerData().
Models that provide interfaces to resizable data structures can provide implementations of insertRows(), removeRows(), insertColumns(), and removeColumns(). When implementing these functions, it is important to call the appropriate functions so that all connected views are aware of any changes:
- An insertRows() implementation must call beginInsertRows() before inserting new rows into the data structure, and it must call endInsertRows() immediately afterwards.
- An insertColumns() implementation must call beginInsertColumns() before inserting new columns into the data structure, and it must call endInsertColumns() immediately afterwards.
- A removeRows() implementation must call beginRemoveRows() before the rows are removed from the data structure, and it must call endRemoveRows() immediately afterwards.
- A removeColumns() implementation must call beginRemoveColumns() before the columns are removed from the data structure, and it must call endRemoveColumns() immediately afterwards.
Note: Some general guidelines for subclassing models are available in the Model Subclassing Reference.
Member Function Documentation
QAbstractTableModel::QAbstractTableModel ( QObject * parent = 0 )
Constructs an abstract table model for the given parent.
Destroys the abstract table model.
bool QAbstractTableModel::dropMimeData ( const QMimeData * data, Qt::DropAction action, int row, int column, const QModelIndex & parent ) [virtual]
Reimplemented from QAbstractItemModel::dropMimeData().
QModelIndex QAbstractTableModel::index ( int row, int column, const QModelIndex & parent = QModelIndex() ) const [virtual]
Reimplemented from QAbstractItemModel::index().
Returns the index of the data in row and column with parent.
See also parent().