QGIS API Documentation 4.1.0-Master (60fea48833c)
Loading...
Searching...
No Matches
qgsvectorlayerfeaturecounter.h
Go to the documentation of this file.
1/***************************************************************************
2 qgsvectorlayerfeaturecounter.h
3 ---------------------
4 begin : May 2017
5 copyright : (C) 2017 by Matthias Kuhn
6 email : matthias at opengis dot ch
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 QGSVECTORLAYERFEATURECOUNTER_H
16#define QGSVECTORLAYERFEATURECOUNTER_H
17
18#include "qgsfeatureid.h"
19#include "qgsrenderer.h"
20#include "qgstaskmanager.h"
22
33class CORE_EXPORT QgsVectorLayerFeatureCounter : public QgsTask
34{
35 Q_OBJECT
36
37 public:
44 QgsVectorLayerFeatureCounter( QgsVectorLayer *layer, const QgsExpressionContext &context = QgsExpressionContext(), bool storeSymbolFids = false );
46
50 bool run() override;
51
52 void cancel() override;
53
60 QHash<QString, long long> symbolFeatureCountMap() const SIP_SKIP;
61
66 long long featureCount( const QString &legendKey ) const;
67
76 QHash<QString, QgsFeatureIds> symbolFeatureIdMap() const SIP_SKIP;
77
84 QgsFeatureIds featureIds( const QString &symbolkey ) const;
85
86 signals:
87
92
93 private:
94 std::unique_ptr<QgsVectorLayerFeatureSource> mSource;
95 std::unique_ptr<QgsFeatureRenderer> mRenderer;
96 QgsExpressionContext mExpressionContext;
97 QHash<QString, long long> mSymbolFeatureCountMap;
98 QHash<QString, QgsFeatureIds> mSymbolFeatureIdMap;
99 std::unique_ptr< QgsFeedback > mFeedback;
100 bool mWithFids = false;
101 long mFeatureCount = 0;
102};
103
104#endif // QGSVECTORLAYERFEATURECOUNTER_H
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
Abstract base class for all 2D vector feature renderers.
Base class for feedback objects to be used for cancellation of something running in a worker thread.
Definition qgsfeedback.h:44
virtual bool run()=0
Performs the task's operation.
virtual void cancel()
Notifies the task that it should terminate.
QgsTask(const QString &description=QString(), QgsTask::Flags flags=AllFlags)
Constructor for QgsTask.
void symbolsCounted()
Emitted when the symbols have been counted.
~QgsVectorLayerFeatureCounter() override
QgsVectorLayerFeatureCounter(QgsVectorLayer *layer, const QgsExpressionContext &context=QgsExpressionContext(), bool storeSymbolFids=false)
Create a new feature counter for layer.
QHash< QString, long long > symbolFeatureCountMap() const
Returns the count for each symbol.
long long featureCount(const QString &legendKey) const
Returns the feature count for a particular legendKey.
QgsFeatureIds featureIds(const QString &symbolkey) const
Returns the feature Ids for a particular legendKey.
QHash< QString, QgsFeatureIds > symbolFeatureIdMap() const
Returns the QgsFeatureIds for each symbol.
Partial snapshot of vector layer's state (only the members necessary for access to features).
Represents a vector layer which manages a vector based dataset.
#define SIP_SKIP
Definition qgis_sip.h:133
QSet< QgsFeatureId > QgsFeatureIds