18#ifndef QGSALGORITHMCELLSTATISTICS_H
19#define QGSALGORITHMCELLSTATISTICS_H
32using namespace Qt::StringLiterals;
39 QString
group()
const final;
41 void initAlgorithm(
const QVariantMap &configuration = QVariantMap() )
final;
45 virtual void addSpecificAlgorithmParams() = 0;
51 std::vector<QgsRasterAnalysisUtils::RasterLogicInput> mInputs;
52 bool mIgnoreNoData =
false;
54 double mNoDataValue = -9999;
59 double mRasterUnitsPerPixelX = 0;
60 double mRasterUnitsPerPixelY = 0;
61 std::unique_ptr<QgsRasterDataProvider> mOutputRasterDataProvider;
62 double mMaxProgressDuringBlockWriting = 100;
65class QgsCellStatisticsAlgorithm :
public QgsCellStatisticsAlgorithmBase
68 QgsCellStatisticsAlgorithm() =
default;
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;
79 void addSpecificAlgorithmParams() override;
80 bool prepareSpecificAlgorithmParameters( const QVariantMap ¶meters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
81 void processRasterStack( QgsProcessingFeedback *feedback ) override;
84 QgsRasterAnalysisUtils::CellValueStatisticMethods mMethod = QgsRasterAnalysisUtils::CellValueStatisticMethods::Sum;
88class QgsCellStatisticsPercentileAlgorithm : public QgsCellStatisticsAlgorithmBase
91 QgsCellStatisticsPercentileAlgorithm() =
default;
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;
102 void addSpecificAlgorithmParams() override;
103 bool prepareSpecificAlgorithmParameters( const QVariantMap ¶meters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
104 void processRasterStack( QgsProcessingFeedback *feedback ) override;
107 QgsRasterAnalysisUtils::CellValuePercentileMethods mMethod = QgsRasterAnalysisUtils::CellValuePercentileMethods::NearestRankPercentile;
108 double mPercentile = 0.0;
112class QgsCellStatisticsPercentRankFromValueAlgorithm : public QgsCellStatisticsAlgorithmBase
115 QgsCellStatisticsPercentRankFromValueAlgorithm() =
default;
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;
126 void addSpecificAlgorithmParams() override;
127 bool prepareSpecificAlgorithmParameters( const QVariantMap ¶meters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
128 void processRasterStack( QgsProcessingFeedback *feedback ) override;
131 QgsRasterAnalysisUtils::CellValuePercentRankMethods mMethod = QgsRasterAnalysisUtils::CellValuePercentRankMethods::InterpolatedPercentRankInc;
136class QgsCellStatisticsPercentRankFromRasterAlgorithm : public QgsCellStatisticsAlgorithmBase
139 QgsCellStatisticsPercentRankFromRasterAlgorithm() =
default;
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;
150 void addSpecificAlgorithmParams() override;
151 bool prepareSpecificAlgorithmParameters( const QVariantMap ¶meters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
152 void processRasterStack( QgsProcessingFeedback *feedback ) override;
155 QgsRasterAnalysisUtils::CellValuePercentRankMethods mMethod = QgsRasterAnalysisUtils::CellValuePercentRankMethods::InterpolatedPercentRankInc;
156 std::unique_ptr<QgsRasterInterface> mValueRasterInterface;
157 int mValueRasterBand = 1;
DataType
Raster data types.
@ UnknownDataType
Unknown or unspecified type.
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 ¶meters, 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 ¶meters, 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.