QGIS API Documentation  2.99.0-Master (6a61179)
Public Types | Public Slots | Signals | Public Member Functions | Protected Slots | Protected Member Functions | Protected Attributes | List of all members
QgsAttributeTableModel Class Reference

A model backed by a QgsVectorLayerCache which is able to provide feature/attribute information to a QAbstractItemView. More...

#include <qgsattributetablemodel.h>

Inheritance diagram for QgsAttributeTableModel:
Inheritance graph
[legend]

Public Types

enum  Role { SortRole = Qt::UserRole + 1, FeatureIdRole, FieldIndexRole, UserRole }
 

Public Slots

void fieldConditionalStyleChanged (const QString &fieldName)
 Handles updating the model when the conditional style for a field changes. More...
 
virtual void loadLayer ()
 Loads the layer into the model Preferably to be called, before using this model as source for any other proxy model. More...
 

Signals

void finished ()
 
void modelChanged ()
 Model has been changed. More...
 
void progress (int i, bool &cancel)
 

Public Member Functions

 QgsAttributeTableModel (QgsVectorLayerCache *layerCache, QObject *parent=nullptr)
 Constructor. More...
 
int columnCount (const QModelIndex &parent=QModelIndex()) const override
 Returns the number of columns. More...
 
virtual QVariant data (const QModelIndex &index, int role) const override
 Returns data on the given index. More...
 
const QgsAttributeEditorContexteditorContext () const
 Returns the context in which this table is shown. More...
 
void executeAction (const QUuid &action, const QModelIndex &idx) const
 Execute an action. More...
 
void executeMapLayerAction (QgsMapLayerAction *action, const QModelIndex &idx) const
 Execute a QgsMapLayerAction. More...
 
int extraColumns () const
 Empty extra columns to announce from this model. More...
 
QgsFeature feature (const QModelIndex &idx) const
 Return the feature attributes at given model index. More...
 
int fieldCol (int idx) const
 get column from field index More...
 
int fieldIdx (int col) const
 get field index from column More...
 
Qt::ItemFlags flags (const QModelIndex &index) const override
 Returns item flags for the index. More...
 
QVariant headerData (int section, Qt::Orientation orientation, int role=Qt::DisplayRole) const override
 Returns header data. More...
 
QModelIndex idToIndex (QgsFeatureId id) const
 
QModelIndexList idToIndexList (QgsFeatureId id) const
 
int idToRow (QgsFeatureId id) const
 Maps feature id to table row. More...
 
QgsVectorLayerlayer () const
 Returns the layer this model uses as backend. More...
 
QgsVectorLayerCachelayerCache () const
 Returns the layer cache this model uses as backend. More...
 
void prefetchColumnData (int column)
 Caches the entire data for one column. More...
 
void prefetchSortData (const QString &expression)
 Prefetches the entire data for one expression. More...
 
void reload (const QModelIndex &index1, const QModelIndex &index2)
 Reloads the model data between indices. More...
 
bool removeRows (int row, int count, const QModelIndex &parent=QModelIndex()) override
 Remove rows. More...
 
const QgsFeatureRequestrequest () const
 Get the the feature request. More...
 
void resetModel ()
 Resets the model. More...
 
virtual int rowCount (const QModelIndex &parent=QModelIndex()) const override
 Returns the number of rows. More...
 
QgsFeatureId rowToId (int row) const
 Maps row to feature id. More...
 
virtual bool setData (const QModelIndex &index, const QVariant &value, int role=Qt::EditRole) override
 Updates data on given index. More...
 
void setEditorContext (const QgsAttributeEditorContext &context)
 Sets the context in which this table is shown. More...
 
void setExtraColumns (int extraColumns)
 Empty extra columns to announce from this model. More...
 
void setRequest (const QgsFeatureRequest &request)
 Set a request that will be used to fill this attribute table model. More...
 
QString sortCacheExpression () const
 The expression which was used to fill the sorting cache. More...
 
void swapRows (QgsFeatureId a, QgsFeatureId b)
 Swaps two rows. More...
 

Protected Slots

virtual void attributeValueChanged (QgsFeatureId fid, int idx, const QVariant &value)
 Launched when attribute value has been changed. More...
 
virtual void featureAdded (QgsFeatureId fid)
 Launched when a feature has been added. More...
 
virtual void featuresDeleted (const QgsFeatureIds &fids)
 Launched when eatures have been deleted. More...
 
virtual void layerDeleted ()
 Launched when layer has been deleted. More...
 

Protected Member Functions

virtual void loadAttributes ()
 Gets mFieldCount, mAttributes and mValueMaps. More...
 

Protected Attributes

QgsAttributeList mAttributes
 
QVector< QVariant > mAttributeWidgetCaches
 
QgsExpressionContext mExpressionContext
 
QgsFeature mFeat
 
int mFieldCount
 
QHash< QgsFeatureId, int > mIdRowMap
 
QgsVectorLayerCachemLayerCache
 
QHash< int, QgsFeatureIdmRowIdMap
 
QHash< int, QList< QgsConditionalStyle > > mRowStylesMap
 
QVector< QgsEditorWidgetConfigmWidgetConfigs
 
QVector< QgsEditorWidgetFactory * > mWidgetFactories
 

Detailed Description

A model backed by a QgsVectorLayerCache which is able to provide feature/attribute information to a QAbstractItemView.

Is able to generate editor widgets for its QModelIndexes as well. Is mostly referred to as "master model" within this doc and the source.

See also
Qt Model View Programming

Definition at line 46 of file qgsattributetablemodel.h.

Member Enumeration Documentation

§ Role

Enumerator
SortRole 

Role used for sorting.

FeatureIdRole 

Get the feature id of the feature in this row.

FieldIndexRole 

Get the field index of this column.

UserRole 

Start further roles starting from this role.

Definition at line 51 of file qgsattributetablemodel.h.

Constructor & Destructor Documentation

§ QgsAttributeTableModel()

QgsAttributeTableModel::QgsAttributeTableModel ( QgsVectorLayerCache layerCache,
QObject *  parent = nullptr 
)

Constructor.

Parameters
layerCacheA layer cache to use as backend
parentThe parent QObject (owner)

Definition at line 40 of file qgsattributetablemodel.cpp.

Member Function Documentation

§ attributeValueChanged

void QgsAttributeTableModel::attributeValueChanged ( QgsFeatureId  fid,
int  idx,
const QVariant &  value 
)
protectedvirtualslot

Launched when attribute value has been changed.

Parameters
fidfeature id
idxattribute index
valuenew value

Definition at line 268 of file qgsattributetablemodel.cpp.

§ columnCount()

int QgsAttributeTableModel::columnCount ( const QModelIndex &  parent = QModelIndex()) const
override

Returns the number of columns.

Parameters
parentparent index

Definition at line 526 of file qgsattributetablemodel.cpp.

§ data()

QVariant QgsAttributeTableModel::data ( const QModelIndex &  index,
int  role 
) const
overridevirtual

Returns data on the given index.

Parameters
indexmodel index
roledata role

Definition at line 572 of file qgsattributetablemodel.cpp.

§ editorContext()

const QgsAttributeEditorContext& QgsAttributeTableModel::editorContext ( ) const
inline

Returns the context in which this table is shown.

Will be forwarded to any editor widget created when editing data on this model.

Returns
The context

Definition at line 238 of file qgsattributetablemodel.h.

§ executeAction()

void QgsAttributeTableModel::executeAction ( const QUuid &  action,
const QModelIndex &  idx 
) const

Execute an action.

Definition at line 740 of file qgsattributetablemodel.cpp.

§ executeMapLayerAction()

void QgsAttributeTableModel::executeMapLayerAction ( QgsMapLayerAction action,
const QModelIndex &  idx 
) const

Execute a QgsMapLayerAction.

Definition at line 746 of file qgsattributetablemodel.cpp.

§ extraColumns()

int QgsAttributeTableModel::extraColumns ( ) const

Empty extra columns to announce from this model.

Any extra columns need to be implemented by proxy models in front of this model.

Definition at line 85 of file qgsattributetablemodel.cpp.

§ feature()

QgsFeature QgsAttributeTableModel::feature ( const QModelIndex &  idx) const

Return the feature attributes at given model index.

Returns
feature attributes at given model index

Definition at line 752 of file qgsattributetablemodel.cpp.

§ featureAdded

void QgsAttributeTableModel::featureAdded ( QgsFeatureId  fid)
protectedvirtualslot

Launched when a feature has been added.

Parameters
fidfeature id

Definition at line 202 of file qgsattributetablemodel.cpp.

§ featuresDeleted

void QgsAttributeTableModel::featuresDeleted ( const QgsFeatureIds fids)
protectedvirtualslot

Launched when eatures have been deleted.

Parameters
fidsfeature ids

Definition at line 96 of file qgsattributetablemodel.cpp.

§ fieldCol()

int QgsAttributeTableModel::fieldCol ( int  idx) const

get column from field index

Definition at line 515 of file qgsattributetablemodel.cpp.

§ fieldConditionalStyleChanged

void QgsAttributeTableModel::fieldConditionalStyleChanged ( const QString &  fieldName)
slot

Handles updating the model when the conditional style for a field changes.

Parameters
fieldNamename of field whose conditional style has changed
Note
added in QGIS 2.12

Definition at line 426 of file qgsattributetablemodel.cpp.

§ fieldIdx()

int QgsAttributeTableModel::fieldIdx ( int  col) const

get field index from column

Definition at line 510 of file qgsattributetablemodel.cpp.

§ finished

void QgsAttributeTableModel::finished ( )
signal

§ flags()

Qt::ItemFlags QgsAttributeTableModel::flags ( const QModelIndex &  index) const
override

Returns item flags for the index.

Parameters
indexmodel index

Definition at line 714 of file qgsattributetablemodel.cpp.

§ headerData()

QVariant QgsAttributeTableModel::headerData ( int  section,
Qt::Orientation  orientation,
int  role = Qt::DisplayRole 
) const
override

Returns header data.

Parameters
sectionrequired section
orientationhorizontal or vertical orientation
roledata role

Definition at line 532 of file qgsattributetablemodel.cpp.

§ idToIndex()

QModelIndex QgsAttributeTableModel::idToIndex ( QgsFeatureId  id) const

Definition at line 478 of file qgsattributetablemodel.cpp.

§ idToIndexList()

QModelIndexList QgsAttributeTableModel::idToIndexList ( QgsFeatureId  id) const

Definition at line 483 of file qgsattributetablemodel.cpp.

§ idToRow()

int QgsAttributeTableModel::idToRow ( QgsFeatureId  id) const

Maps feature id to table row.

Parameters
idfeature id

Definition at line 467 of file qgsattributetablemodel.cpp.

§ layer()

QgsVectorLayer* QgsAttributeTableModel::layer ( ) const
inline

Returns the layer this model uses as backend.

Retrieved from the layer cache.

Definition at line 164 of file qgsattributetablemodel.h.

§ layerCache()

QgsVectorLayerCache* QgsAttributeTableModel::layerCache ( ) const
inline

Returns the layer cache this model uses as backend.

Definition at line 169 of file qgsattributetablemodel.h.

§ layerDeleted

void QgsAttributeTableModel::layerDeleted ( )
protectedvirtualslot

Launched when layer has been deleted.

Definition at line 258 of file qgsattributetablemodel.cpp.

§ loadAttributes()

void QgsAttributeTableModel::loadAttributes ( )
protectedvirtual

Gets mFieldCount, mAttributes and mValueMaps.

Definition at line 324 of file qgsattributetablemodel.cpp.

§ loadLayer

void QgsAttributeTableModel::loadLayer ( )
virtualslot

Loads the layer into the model Preferably to be called, before using this model as source for any other proxy model.

Definition at line 381 of file qgsattributetablemodel.cpp.

§ modelChanged

void QgsAttributeTableModel::modelChanged ( )
signal

Model has been changed.

§ prefetchColumnData()

void QgsAttributeTableModel::prefetchColumnData ( int  column)

Caches the entire data for one column.

This should be called prior to sorting, so the data does not have to be fetched for every single comparison. Specify -1 as column to invalidate the cache

Parameters
columnThe column index of the field to catch

Definition at line 765 of file qgsattributetablemodel.cpp.

§ prefetchSortData()

void QgsAttributeTableModel::prefetchSortData ( const QString &  expression)

Prefetches the entire data for one expression.

Based on this cached information the sorting can later be done in a performant way.

Parameters
expressionThe expression to cache

Definition at line 777 of file qgsattributetablemodel.cpp.

§ progress

void QgsAttributeTableModel::progress ( int  i,
bool &  cancel 
)
signal
Note
not available in python bindings

§ reload()

void QgsAttributeTableModel::reload ( const QModelIndex &  index1,
const QModelIndex &  index2 
)

Reloads the model data between indices.

Parameters
index1start index
index2end index

Definition at line 733 of file qgsattributetablemodel.cpp.

§ removeRows()

bool QgsAttributeTableModel::removeRows ( int  row,
int  count,
const QModelIndex &  parent = QModelIndex() 
)
override

Remove rows.

Definition at line 152 of file qgsattributetablemodel.cpp.

§ request()

const QgsFeatureRequest & QgsAttributeTableModel::request ( ) const

Get the the feature request.

Definition at line 848 of file qgsattributetablemodel.cpp.

§ resetModel()

void QgsAttributeTableModel::resetModel ( )
inline

Resets the model.

Alias to loadLayer()

Definition at line 126 of file qgsattributetablemodel.h.

§ rowCount()

int QgsAttributeTableModel::rowCount ( const QModelIndex &  parent = QModelIndex()) const
overridevirtual

Returns the number of rows.

Parameters
parentparent index

Definition at line 520 of file qgsattributetablemodel.cpp.

§ rowToId()

QgsFeatureId QgsAttributeTableModel::rowToId ( int  row) const

Maps row to feature id.

Parameters
rowrow number

Definition at line 498 of file qgsattributetablemodel.cpp.

§ setData()

bool QgsAttributeTableModel::setData ( const QModelIndex &  index,
const QVariant &  value,
int  role = Qt::EditRole 
)
overridevirtual

Updates data on given index.

Parameters
indexmodel index
valuenew data value
roledata role

Definition at line 677 of file qgsattributetablemodel.cpp.

§ setEditorContext()

void QgsAttributeTableModel::setEditorContext ( const QgsAttributeEditorContext context)
inline

Sets the context in which this table is shown.

Will be forwarded to any editor widget created when editing data on this model.

Parameters
contextThe context

Definition at line 230 of file qgsattributetablemodel.h.

§ setExtraColumns()

void QgsAttributeTableModel::setExtraColumns ( int  extraColumns)

Empty extra columns to announce from this model.

Any extra columns need to be implemented by proxy models in front of this model.

Definition at line 90 of file qgsattributetablemodel.cpp.

§ setRequest()

void QgsAttributeTableModel::setRequest ( const QgsFeatureRequest request)

Set a request that will be used to fill this attribute table model.

In contrast to a filter, the request will constrain the data shown without the possibility to dynamically adjust it.

Parameters
requestThe request to use to fill this table model.

Definition at line 841 of file qgsattributetablemodel.cpp.

§ sortCacheExpression()

QString QgsAttributeTableModel::sortCacheExpression ( ) const

The expression which was used to fill the sorting cache.

Definition at line 833 of file qgsattributetablemodel.cpp.

§ swapRows()

void QgsAttributeTableModel::swapRows ( QgsFeatureId  a,
QgsFeatureId  b 
)

Swaps two rows.

Parameters
afirst row
bsecond row

Definition at line 444 of file qgsattributetablemodel.cpp.

Member Data Documentation

§ mAttributes

QgsAttributeList QgsAttributeTableModel::mAttributes
protected

Definition at line 329 of file qgsattributetablemodel.h.

§ mAttributeWidgetCaches

QVector<QVariant> QgsAttributeTableModel::mAttributeWidgetCaches
protected

Definition at line 331 of file qgsattributetablemodel.h.

§ mExpressionContext

QgsExpressionContext QgsAttributeTableModel::mExpressionContext
mutableprotected

Definition at line 338 of file qgsattributetablemodel.h.

§ mFeat

QgsFeature QgsAttributeTableModel::mFeat
mutableprotected

Definition at line 327 of file qgsattributetablemodel.h.

§ mFieldCount

int QgsAttributeTableModel::mFieldCount
protected

Definition at line 325 of file qgsattributetablemodel.h.

§ mIdRowMap

QHash<QgsFeatureId, int> QgsAttributeTableModel::mIdRowMap
protected

Definition at line 334 of file qgsattributetablemodel.h.

§ mLayerCache

QgsVectorLayerCache* QgsAttributeTableModel::mLayerCache
protected

Definition at line 324 of file qgsattributetablemodel.h.

§ mRowIdMap

QHash<int, QgsFeatureId> QgsAttributeTableModel::mRowIdMap
protected

Definition at line 335 of file qgsattributetablemodel.h.

§ mRowStylesMap

QHash<int, QList<QgsConditionalStyle> > QgsAttributeTableModel::mRowStylesMap
mutableprotected

Definition at line 336 of file qgsattributetablemodel.h.

§ mWidgetConfigs

QVector<QgsEditorWidgetConfig> QgsAttributeTableModel::mWidgetConfigs
protected

Definition at line 332 of file qgsattributetablemodel.h.

§ mWidgetFactories

QVector<QgsEditorWidgetFactory*> QgsAttributeTableModel::mWidgetFactories
protected

Definition at line 330 of file qgsattributetablemodel.h.


The documentation for this class was generated from the following files: