QGIS API Documentation  2.99.0-Master (7d4f81d)
qgsfeaturestore.h
Go to the documentation of this file.
1 /***************************************************************************
2  qgsfeaturestore.h
3  --------------------------------------
4  Date : February 2013
5  Copyright : (C) 2013 by Radim Blazek
6  Email : [email protected]
7  ***************************************************************************
8  * *
9  * This program is free software; you can redistribute it and/or modify *
10  * it under the terms of the GNU General Public License as published by *
11  * the Free Software Foundation; either version 2 of the License, or *
12  * (at your option) any later version. *
13  * *
14  ***************************************************************************/
15 #ifndef QGSFEATURESTORE_H
16 #define QGSFEATURESTORE_H
17 
18 #include "qgis_core.h"
19 #include "qgis.h"
20 #include "qgsfeature.h"
21 #include "qgsfields.h"
22 #include "qgsfeaturesink.h"
24 #include <QList>
25 #include <QMetaType>
26 #include <QVariant>
27 
31 class CORE_EXPORT QgsFeatureStore : public QgsFeatureSink
32 {
33  public:
36 
38  QgsFeatureStore( const QgsFields &fields, const QgsCoordinateReferenceSystem &crs );
39 
44  QgsFields fields() const { return mFields; }
45 
50  void setFields( const QgsFields &fields );
51 
56  QgsCoordinateReferenceSystem crs() const { return mCrs; }
57 
62  void setCrs( const QgsCoordinateReferenceSystem &crs ) { mCrs = crs; }
63 
64  bool addFeature( QgsFeature &feature, QgsFeatureSink::Flags flags = 0 ) override;
65  bool addFeatures( QgsFeatureList &features, QgsFeatureSink::Flags flags = 0 ) override;
66 
70  int count() const { return mFeatures.size(); }
71 
72 #ifdef SIP_RUN
73 
77  int __len__() const;
78  % MethodCode
79  sipRes = sipCpp->count();
80  % End
81 #endif
82 
86  QgsFeatureList features() const { return mFeatures; }
87 
92  void setParams( const QMap<QString, QVariant> &parameters ) { mParams = parameters; }
93 
98  QMap<QString, QVariant> params() const { return mParams; }
99 
100  private:
101  QgsFields mFields;
102 
104 
105  QgsFeatureList mFeatures;
106 
107  // Optional parameters
108  QMap<QString, QVariant> mParams;
109 };
110 
111 typedef QList<QgsFeatureStore> QgsFeatureStoreList;
112 
114 
116 
117 #endif
A container for features with the same fields and crs.
virtual bool addFeatures(QgsFeatureList &features, QgsFeatureSink::Flags flags=0)=0
Adds a list of features to the sink.
QList< QgsFeatureStore > QgsFeatureStoreList
QList< QgsFeature > QgsFeatureList
Definition: qgsfeature.h:524
An interface for objects which accept features via addFeature(s) methods.
void setParams(const QMap< QString, QVariant > &parameters)
Sets a map of optional parameters for the store.
Container of fields for a vector layer.
Definition: qgsfields.h:41
The feature class encapsulates a single feature including its id, geometry and a list of field/values...
Definition: qgsfeature.h:61
Q_DECLARE_METATYPE(QModelIndex)
void setCrs(const QgsCoordinateReferenceSystem &crs)
Sets the store&#39;s crs.
virtual bool addFeature(QgsFeature &feature, QgsFeatureSink::Flags flags=0)
Adds a single feature to the sink.
QgsFields fields() const
Returns the store&#39;s field list.
This class represents a coordinate reference system (CRS).
QMap< QString, QVariant > params() const
Returns the map of optional parameters.
QgsCoordinateReferenceSystem crs() const
Returns the store&#39;s coordinate reference system.
QgsFeatureList features() const
Returns the list of features contained in the store.
int count() const
Returns the number of features contained in the store.