QGIS API Documentation
3.16.0-Hannover (43b64b13f3)
|
Go to the documentation of this file.
33 connect( mLayer, &QgsVectorLayer::destroyed,
this, &QgsVectorLayerCache::layerDeleted );
44 connectJoinedLayers();
49 qDeleteAll( mCacheIndices );
50 mCacheIndices.clear();
60 return mCache.maxCost();
66 bool mustInvalidate = shouldCacheGeometry && !mCacheGeometry;
67 mCacheGeometry = shouldCacheGeometry;
84 mCachedAttributes = attributes;
89 mFullCache = fullCache;
98 .setSubsetOfAttributes( mCachedAttributes )
111 if ( t.elapsed() > 1000 )
130 mCacheIndices.append( cacheIndex );
135 if ( cacheAddedAttributes )
147 bool featureFound =
false;
153 cachedFeature = mCache[ featureId ];
158 feature =
QgsFeature( *cachedFeature->feature() );
162 .setFilterFid( featureId )
163 .setSubsetOfAttributes( mCachedAttributes )
165 .nextFeature( feature ) )
167 cacheFeature( feature );
176 return mCache.remove( fid );
186 return mLayer->
crs();
207 if ( fids.count() <= mCache.size() )
209 for (
const auto &idx : qgis::as_const( mCacheIndices ) )
211 idx->requestCompleted( featureRequest, fids );
223 const auto constMCacheIndices = mCacheIndices;
226 idx->flushFeature( fid );
230 void QgsVectorLayerCache::onAttributeValueChanged(
QgsFeatureId fid,
int field,
const QVariant &value )
236 cachedFeat->mFeature->setAttribute(
field, value );
242 void QgsVectorLayerCache::onJoinAttributeValueChanged(
QgsFeatureId fid,
int field,
const QVariant &value )
244 const QgsVectorLayer *joinLayer = qobject_cast<const QgsVectorLayer *>( sender() );
246 const auto constVectorJoins = mLayer->
vectorJoins();
249 if ( joinLayer == info.joinLayer() )
253 const QString fieldName = info.prefixedFieldName( joinLayer->
fields().
field(
field ) );
256 if ( feature.
isValid() && fieldIndex != -1 )
258 onAttributeValueChanged( feature.
id(), fieldIndex, value );
265 void QgsVectorLayerCache::featureDeleted(
QgsFeatureId fid )
267 mCache.remove( fid );
270 void QgsVectorLayerCache::onFeatureAdded(
QgsFeatureId fid )
285 void QgsVectorLayerCache::attributeAdded(
int field )
288 mCachedAttributes.append(
field );
292 void QgsVectorLayerCache::attributeDeleted(
int field )
295 mCachedAttributes.clear();
297 const auto constAttrs = attrs;
298 for (
int attr : constAttrs )
301 mCachedAttributes << attr;
302 else if ( attr >
field )
303 mCachedAttributes << attr - 1;
313 cachedFeat->mFeature->setGeometry( geom );
317 void QgsVectorLayerCache::layerDeleted()
323 void QgsVectorLayerCache::invalidate()
333 const auto constMCacheIndices = mCacheIndices;
336 if ( idx->getCacheIterator( it, featureRequest ) )
347 if ( mCache.contains( featureRequest.
filterFid() ) )
356 if ( qgis::listToSet( mCache.keys() ).contains( featureRequest.
filterFids() ) )
381 bool requiresWriterIt =
true;
389 requiresWriterIt =
false;
394 requiresWriterIt = !canUseCacheForRequest( featureRequest, it );
401 requiresWriterIt =
false;
411 if ( mCacheGeometry && mLayer->
isSpatial() )
415 QSet<int> attrs = qgis::listToSet( featureRequest.
subsetOfAttributes() ) + qgis::listToSet( mCachedAttributes );
426 return mCache.contains( fid );
443 const auto constRequestedAttributes = requestedAttributes;
444 for (
int attr : constRequestedAttributes )
446 if ( !mCachedAttributes.contains( attr ) )
454 && !mCacheGeometry );
457 void QgsVectorLayerCache::connectJoinedLayers()
const
459 const auto constVectorJoins = mLayer->
vectorJoins();
@ NoGeometry
Geometry is not required. It may still be returned if e.g. required for a filter condition.
QgsFeatureIterator getFeatures(const QgsFeatureRequest &request=QgsFeatureRequest()) const FINAL
Queries the layer for features specified in request.
QgsCoordinateReferenceSystem crs
@ FilterFid
Filter using feature ID.
void setCacheSubsetOfAttributes(const QgsAttributeList &attributes)
Set the subset of attributes to be cached.
Q_INVOKABLE QgsWkbTypes::Type wkbType() const FINAL
Returns the WKBType or WKBUnknown in case of error.
const QgsFeatureIds & filterFids() const
Gets feature IDs that should be fetched.
void requestCompleted(const QgsFeatureRequest &featureRequest, const QgsFeatureIds &fids)
Gets called, whenever the full list of feature ids for a certain request is known.
QgsWkbTypes::Type wkbType() const
Returns the geometry type for features in the cache.
void setCacheAddedAttributes(bool cacheAddedAttributes)
If this is enabled, the subset of cached attributes will automatically be extended to also include ne...
QgsFeatureId filterFid() const
Gets the feature ID that should be fetched.
QgsVectorLayerCache(QgsVectorLayer *layer, int cacheSize, QObject *parent=nullptr)
const Flags & flags() const
const QgsRectangle & filterRect() const
Returns the rectangle from which features will be taken.
~QgsVectorLayerCache() override
FilterType filterType() const
Returns the filter type which is currently set on this request.
Container of fields for a vector layer.
@ FilterFids
Filter using feature IDs.
QgsCoordinateReferenceSystem sourceCrs() const
Returns the coordinate reference system for features in the cache.
void attributeDeleted(int idx)
Will be emitted, when an attribute has been deleted from this vector layer.
bool isSpatial() const FINAL
Returns true if this is a geometry layer and false in case of NoGeometry (table only) or UnknownGeome...
QgsFeature targetedFeatureOf(const QgsVectorLayerJoinInfo *info, const QgsFeature &feature) const
Returns the targeted feature corresponding to the joined feature.
bool removeCachedFeature(QgsFeatureId fid)
Removes the feature identified by fid from the cache if present.
Type
The WKB type describes the number of dimensions a geometry has.
void featureDeleted(QgsFeatureId fid)
Emitted when a feature has been deleted.
QgsFeatureRequest & setSubsetOfAttributes(const QgsAttributeList &attrs)
Set a subset of attributes that will be fetched.
QgsFeatureIterator getFeatures(const QgsFeatureRequest &featureRequest=QgsFeatureRequest())
Query this VectorLayerCache for features.
void invalidated()
The cache has been invalidated and cleared.
QList< int > QgsAttributeList
bool checkInformationCovered(const QgsFeatureRequest &featureRequest)
Checks if the information required to complete the request is cached.
long featureCount(const QString &legendKey) const
Number of features rendered with specified legend key.
@ SubsetOfAttributes
Fetch only a subset of attributes (setSubsetOfAttributes sets this flag)
QgsAttributeList attributeList() const
Returns list of attribute indexes.
void attributeValueChanged(QgsFeatureId fid, int field, const QVariant &value)
Emitted when an attribute is changed.
QgsFields fields() const FINAL
Returns the list of fields of this layer.
This class wraps a request for features to a vector layer (or directly its vector data provider).
void finished()
When filling the cache, this signal gets emitted once the cache is fully initialized.
QgsFields fields() const
Returns the fields associated with features in the cache.
void progress(int i, bool &cancel)
When filling the cache, this signal gets emitted periodically to notify about the progress and to be ...
void addCacheIndex(QgsAbstractCacheIndex *cacheIndex)
Adds a QgsAbstractCacheIndex to this cache.
bool isValid() const
Returns the validity of this feature.
bool contains(const QgsRectangle &rect) const
Returns true when rectangle contains other rectangle.
const QList< QgsVectorLayerJoinInfo > vectorJoins() const
void attributeValueChanged(QgsFeatureId fid, int idx, const QVariant &value)
Emitted whenever an attribute value change is done in the edit buffer.
void featureAdded(QgsFeatureId fid)
Emitted when a new feature has been added to the layer and this cache.
void featureRemoved(QgsFeatureId fid)
Gets called, whenever a feature has been removed.
friend class QgsCachedFeatureWriterIterator
QgsVectorLayer * layer()
Returns the layer to which this cache belongs.
Defines left outer join from our vector layer to some other vector layer.
@ FilterExpression
Filter using expression.
bool featureAtId(QgsFeatureId featureId, QgsFeature &feature, bool skipCache=false)
Gets the feature at the given feature id.
QSet< QgsFeatureId > QgsFeatureIds
This class represents a coordinate reference system (CRS).
QgsField field(int fieldIdx) const
Gets field at particular index (must be in range 0..N-1)
void cachedLayerDeleted()
Is emitted when the cached layer is deleted.
QgsRectangle extent() const FINAL
Returns the extent of the layer.
Abstract base class for cache indices.
bool isFidCached(QgsFeatureId fid) const
Check if a certain feature id is cached.
void dataChanged()
Data of layer changed.
void setFullCache(bool fullCache)
This enables or disables full caching.
int cacheSize()
Returns the maximum number of features this cache will hold.
bool nextFeature(QgsFeature &f)
A geometry is the spatial representation of a feature.
Represents a vector layer which manages a vector based data sets.
void geometryChanged(QgsFeatureId fid, const QgsGeometry &geometry)
Emitted whenever a geometry change is done in the edit buffer.
friend class QgsCachedFeature
long featureCount() const
Returns the number of features contained in the source, or -1 if the feature count is unknown.
QgsAttributeList subsetOfAttributes() const
Returns the subset of attributes which at least need to be fetched.
void setCacheGeometry(bool cacheGeometry)
Enable or disable the caching of geometries.
QgsVectorDataProvider * dataProvider() FINAL
Returns the layer's data provider, it may be nullptr.
void setCacheSize(int cacheSize)
Sets the maximum number of features to keep in the cache.
@ FilterNone
No filter is applied.
The feature class encapsulates a single feature including its id, geometry and a list of field/values...
void updatedFields()
Emitted whenever the fields available from this layer have been changed.
QgsFeature getFeature(QgsFeatureId fid) const
Queries the layer for the feature with the given id.
void attributeAdded(int idx)
Will be emitted, when a new attribute has been added to this vector layer.
Wrapper for iterator of features from vector data provider or vector layer.
QgsFeatureRequest & setFlags(QgsFeatureRequest::Flags flags)
Sets flags that affect how features will be fetched.
bool isNull() const
Test if the rectangle is null (all coordinates zero or after call to setMinimal()).
int indexFromName(const QString &fieldName) const
Gets the field index from the field name.
QgsVectorLayerJoinBuffer * joinBuffer()
Returns the join buffer object.
friend class QgsCachedFeatureIterator
bool cacheGeometry() const
Returns true if the cache will fetch and cache feature geometries.
qint64 QgsFeatureId
64 bit feature ids negative numbers are used for uncommitted/newly added features
void featureAdded(QgsFeatureId fid)
Emitted when a new feature has been added to the layer.