QGIS API Documentation 3.99.0-Master (18a1e75d814)
Loading...
Searching...
No Matches
qgsalgorithmcellstatistics.h
Go to the documentation of this file.
1/***************************************************************************
2 qgsalgorithmcellstatistics.h
3 ---------------------
4 begin : May 2020
5 copyright : (C) 2020 by Clemens Raffler
6 email : clemens dot raffler at gmail dot com
7 ***************************************************************************/
8
9/***************************************************************************
10 * *
11 * This program is free software; you can redistribute it and/or modify *
12 * it under the terms of the GNU General Public License as published by *
13 * the Free Software Foundation; either version 2 of the License, or *
14 * (at your option) any later version. *
15 * *
16 ***************************************************************************/
17
18#ifndef QGSALGORITHMCELLSTATISTICS_H
19#define QGSALGORITHMCELLSTATISTICS_H
20
21
22#include "qgis_sip.h"
23#include "qgsapplication.h"
26#include "qgsrasterprojector.h"
27
28#include <QString>
29
30#define SIP_NO_FILE
31
32using namespace Qt::StringLiterals;
33
35
36class QgsCellStatisticsAlgorithmBase : public QgsProcessingAlgorithm
37{
38 public:
39 QString group() const final;
40 QString groupId() const final;
41 void initAlgorithm( const QVariantMap &configuration = QVariantMap() ) final;
42
43
44 protected:
45 virtual void addSpecificAlgorithmParams() = 0;
46 virtual bool prepareSpecificAlgorithmParameters( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) = 0;
47 bool prepareAlgorithm( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) final;
48 QVariantMap processAlgorithm( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) final;
49 virtual void processRasterStack( QgsProcessingFeedback *feedback ) = 0;
50
51 std::vector<QgsRasterAnalysisUtils::RasterLogicInput> mInputs;
52 bool mIgnoreNoData = false;
54 double mNoDataValue = -9999;
55 int mLayerWidth = 0;
56 int mLayerHeight = 0;
57 QgsRectangle mExtent;
59 double mRasterUnitsPerPixelX = 0;
60 double mRasterUnitsPerPixelY = 0;
61 std::unique_ptr<QgsRasterDataProvider> mOutputRasterDataProvider;
62 double mMaxProgressDuringBlockWriting = 100;
63};
64
65class QgsCellStatisticsAlgorithm : public QgsCellStatisticsAlgorithmBase
66{
67 public:
68 QgsCellStatisticsAlgorithm() = default;
69 QIcon icon() const override { return QgsApplication::getThemeIcon( u"/algorithms/mAlgorithmCellStatistics.svg"_s ); }
70 QString svgIconPath() const override { return QgsApplication::iconPath( u"/algorithms/mAlgorithmCellStatistics.svg"_s ); }
71 QString name() const override;
72 QString displayName() const override;
73 QStringList tags() const override;
74 QString shortHelpString() const override;
75 QString shortDescription() const override;
76 QgsCellStatisticsAlgorithm *createInstance() const override SIP_FACTORY;
77
78 protected:
79 void addSpecificAlgorithmParams() override;
80 bool prepareSpecificAlgorithmParameters( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
81 void processRasterStack( QgsProcessingFeedback *feedback ) override;
82
83 private:
84 QgsRasterAnalysisUtils::CellValueStatisticMethods mMethod = QgsRasterAnalysisUtils::CellValueStatisticMethods::Sum;
85};
86
87
88class QgsCellStatisticsPercentileAlgorithm : public QgsCellStatisticsAlgorithmBase
89{
90 public:
91 QgsCellStatisticsPercentileAlgorithm() = default;
92 QIcon icon() const override { return QgsApplication::getThemeIcon( u"/algorithms/mAlgorithmCellStatisticsPercentile.svg"_s ); }
93 QString svgIconPath() const override { return QgsApplication::iconPath( u"/algorithms/mAlgorithmCellStatisticsPercentile.svg"_s ); }
94 QString name() const override;
95 QString displayName() const override;
96 QStringList tags() const override;
97 QString shortHelpString() const override;
98 QString shortDescription() const override;
99 QgsCellStatisticsPercentileAlgorithm *createInstance() const override SIP_FACTORY;
100
101 protected:
102 void addSpecificAlgorithmParams() override;
103 bool prepareSpecificAlgorithmParameters( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
104 void processRasterStack( QgsProcessingFeedback *feedback ) override;
105
106 private:
107 QgsRasterAnalysisUtils::CellValuePercentileMethods mMethod = QgsRasterAnalysisUtils::CellValuePercentileMethods::NearestRankPercentile;
108 double mPercentile = 0.0;
109};
110
111
112class QgsCellStatisticsPercentRankFromValueAlgorithm : public QgsCellStatisticsAlgorithmBase
113{
114 public:
115 QgsCellStatisticsPercentRankFromValueAlgorithm() = default;
116 QIcon icon() const override { return QgsApplication::getThemeIcon( u"/algorithms/mAlgorithmCellStatisticsPercentRank.svg"_s ); }
117 QString svgIconPath() const override { return QgsApplication::iconPath( u"/algorithms/mAlgorithmCellStatisticsPercentRank.svg"_s ); }
118 QString name() const override;
119 QString displayName() const override;
120 QStringList tags() const override;
121 QString shortHelpString() const override;
122 QString shortDescription() const override;
123 QgsCellStatisticsPercentRankFromValueAlgorithm *createInstance() const override SIP_FACTORY;
124
125 protected:
126 void addSpecificAlgorithmParams() override;
127 bool prepareSpecificAlgorithmParameters( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
128 void processRasterStack( QgsProcessingFeedback *feedback ) override;
129
130 private:
131 QgsRasterAnalysisUtils::CellValuePercentRankMethods mMethod = QgsRasterAnalysisUtils::CellValuePercentRankMethods::InterpolatedPercentRankInc;
132 double mValue = 0.0;
133};
134
135
136class QgsCellStatisticsPercentRankFromRasterAlgorithm : public QgsCellStatisticsAlgorithmBase
137{
138 public:
139 QgsCellStatisticsPercentRankFromRasterAlgorithm() = default;
140 QIcon icon() const override { return QgsApplication::getThemeIcon( u"/algorithms/mAlgorithmCellStatisticsPercentRank.svg"_s ); }
141 QString svgIconPath() const override { return QgsApplication::iconPath( u"/algorithms/mAlgorithmCellStatisticsPercentRank.svg"_s ); }
142 QString name() const override;
143 QString displayName() const override;
144 QStringList tags() const override;
145 QString shortHelpString() const override;
146 QString shortDescription() const override;
147 QgsCellStatisticsPercentRankFromRasterAlgorithm *createInstance() const override SIP_FACTORY;
148
149 protected:
150 void addSpecificAlgorithmParams() override;
151 bool prepareSpecificAlgorithmParameters( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
152 void processRasterStack( QgsProcessingFeedback *feedback ) override;
153
154 private:
155 QgsRasterAnalysisUtils::CellValuePercentRankMethods mMethod = QgsRasterAnalysisUtils::CellValuePercentRankMethods::InterpolatedPercentRankInc;
156 std::unique_ptr<QgsRasterInterface> mValueRasterInterface;
157 int mValueRasterBand = 1;
158};
159
160
162
163#endif // QGSALGORITHMCELLSTATISTICS_H
DataType
Raster data types.
Definition qgis.h:390
@ UnknownDataType
Unknown or unspecified type.
Definition qgis.h:391
static QIcon getThemeIcon(const QString &name, const QColor &fillColor=QColor(), const QColor &strokeColor=QColor())
Helper to get a theme icon.
static QString iconPath(const QString &iconFile)
Returns path to the desired icon file.
Represents a coordinate reference system (CRS).
Abstract base class for processing algorithms.
virtual QString group() const
Returns the name of the group this algorithm belongs to.
virtual bool prepareAlgorithm(const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback)
Prepares the algorithm to run using the specified parameters.
virtual QString groupId() const
Returns the unique ID of the group this algorithm belongs to.
virtual QVariantMap processAlgorithm(const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback)=0
Runs the algorithm using the specified parameters.
virtual void initAlgorithm(const QVariantMap &configuration=QVariantMap())=0
Initializes the algorithm using the specified configuration.
Contains information about the context in which a processing algorithm is executed.
Base class for providing feedback from a processing algorithm.
A rectangle specified with double values.
#define SIP_FACTORY
Definition qgis_sip.h:83