QGIS API Documentation
3.26.3-Buenos Aires (65e4edfdad)
|
Go to the documentation of this file.
19 #ifndef QgsVectorLayerCache_H
20 #define QgsVectorLayerCache_H
22 #include "qgis_core.h"
27 #include <unordered_set>
57 class QgsCachedFeature
77 mCache->featureRemoved( mFeature->id() );
81 inline const QgsFeature *feature() {
return mFeature; }
281 sipRes = sipCpp->featureCount();
285 int __bool__()
const;
379 void onAttributeValueChanged(
QgsFeatureId fid,
int field,
const QVariant &value );
380 void onJoinAttributeValueChanged(
QgsFeatureId fid,
int field,
const QVariant &value );
383 void attributeAdded(
int field );
384 void attributeDeleted(
int field );
391 void connectJoinedLayers()
const;
396 mCache.insert( feat.
id(), cachedFeature );
397 if ( mCacheUnorderedKeys.find( feat.
id() ) == mCacheUnorderedKeys.end() )
399 mCacheUnorderedKeys.insert( feat.
id() );
400 mCacheOrderedKeys.emplace_back( feat.
id() );
405 QCache< QgsFeatureId, QgsCachedFeature > mCache;
410 std::unordered_set< QgsFeatureId > mCacheUnorderedKeys;
411 std::deque< QgsFeatureId > mCacheOrderedKeys;
413 bool mCacheGeometry =
true;
414 bool mFullCache =
false;
415 QList<QgsAbstractCacheIndex *> mCacheIndices;
421 friend class QgsCachedFeature;
433 friend class TestVectorLayerCache;
435 #endif // QgsVectorLayerCache_H
Uses another iterator as backend and writes features to the cache.
void setCacheSubsetOfAttributes(const QgsAttributeList &attributes)
Set the subset of attributes to be cached.
This class caches features of a given QgsVectorLayer.
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...
QgsVectorLayerCache(QgsVectorLayer *layer, int cacheSize, QObject *parent=nullptr)
~QgsVectorLayerCache() override
Container of fields for a vector layer.
QgsCoordinateReferenceSystem sourceCrs() const
Returns the coordinate reference system for features in the cache.
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.
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.
A rectangle specified with double values.
QgsFeature getFeature(QgsFeatureId fid)
Query the layer for the feature with the given id.
void attributeValueChanged(QgsFeatureId fid, int field, const QVariant &value)
Emitted when an attribute is changed.
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.
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.
long long featureCount() const
Returns the number of features contained in the source, or -1 if the feature count is unknown.
QgsVectorLayer * layer()
Returns the layer to which this cache belongs.
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).
void cachedLayerDeleted()
Is emitted when the cached layer is deleted.
Abstract base class for cache indices.
bool isFidCached(QgsFeatureId fid) const
Check if a certain feature id is cached.
void setFullCache(bool fullCache)
This enables or disables full caching.
bool hasFullCache() const
Returns true if the cache is complete, ie it contains all features.
int cacheSize()
Returns the maximum number of features this cache will hold.
Delivers features from the cache.
bool nextFeature(QgsFeature &f)
A geometry is the spatial representation of a feature.
Represents a vector layer which manages a vector based data sets.
friend class QgsCachedFeature
void setCacheGeometry(bool cacheGeometry)
Enable or disable the caching of geometries.
void setCacheSize(int cacheSize)
Sets the maximum number of features to keep in the cache.
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
QgsFeatureIterator getFeatures(const QString &expression)
Query the layer for features matching a given expression.
Wrapper for iterator of features from vector data provider or vector layer.
QgsFeatureIterator getFeatures(const QgsRectangle &rectangle)
Query the layer for the features which intersect the specified rectangle.
QgsFeatureIterator getFeatures(const QgsFeatureIds &fids)
Query the layer for the features with the given ids.
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
QgsFeatureIds cachedFeatureIds() const
Returns the set of feature IDs for features which are cached.