22QString QgsRasterMinMaxAlgorithm::name()
const
24 return QStringLiteral(
"rasterminmax" );
27QString QgsRasterMinMaxAlgorithm::displayName()
const
29 return QObject::tr(
"Raster minimum/maximum" );
32QStringList QgsRasterMinMaxAlgorithm::tags()
const
34 return QObject::tr(
"dem,statistics,value,extrema,extremes,largest,smallest" ).split(
',' );
37QString QgsRasterMinMaxAlgorithm::group()
const
39 return QObject::tr(
"Raster analysis" );
42QString QgsRasterMinMaxAlgorithm::groupId()
const
44 return QStringLiteral(
"rasteranalysis" );
47void QgsRasterMinMaxAlgorithm::initAlgorithm(
const QVariantMap & )
50 QObject::tr(
"Input layer" ) ) );
52 QObject::tr(
"Band number" ), 1, QStringLiteral(
"INPUT" ) ) );
54 QObject::tr(
"Extract extrema" ), QStringList()
55 << QObject::tr(
"Minimum and Maximum" )
56 << QObject::tr(
"Minimum" )
57 << QObject::tr(
"Maximum" ),
false, 0 ) );
66QString QgsRasterMinMaxAlgorithm::shortHelpString()
const
68 return QObject::tr(
"This algorithm extracts extrema (minimum and maximum) values from a given band of the raster layer.\n\n"
69 "The output is a vector layer containing point features for the selected extrema, at the center of the associated pixel.\n\n"
70 "If multiple pixels in the raster share the minimum or maximum value, then only one of these pixels will be included in the output." );
73QString QgsRasterMinMaxAlgorithm::shortDescription()
const
75 return QObject::tr(
"Calculates the minimum and maximum pixel in a raster layer." );
78QgsRasterMinMaxAlgorithm *QgsRasterMinMaxAlgorithm::createInstance()
const
80 return new QgsRasterMinMaxAlgorithm();
85 QgsRasterLayer *layer = parameterAsRasterLayer( parameters, QStringLiteral(
"INPUT" ), context );
90 mBand = parameterAsInt( parameters, QStringLiteral(
"BAND" ), context );
91 if ( mBand < 1 || mBand > layer->
bandCount() )
92 throw QgsProcessingException( QObject::tr(
"Invalid band number for BAND (%1): Valid values for input raster are 1 to %2" ).arg( mBand )
97 mLayerWidth = layer->
width();
98 mLayerHeight = layer->
height();
109 std::unique_ptr< QgsFeatureSink > sink;
110 if ( parameters.value( QStringLiteral(
"OUTPUT" ) ).isValid() )
113 outFields.
append(
QgsField( QStringLiteral(
"value" ), QMetaType::Type::Double, QString(), 20, 8 ) );
114 outFields.
append(
QgsField( QStringLiteral(
"extremum_type" ), QMetaType::Type::QString ) );
115 sink.reset( parameterAsSink( parameters, QStringLiteral(
"OUTPUT" ), context, dest, outFields,
Qgis::WkbType::Point, mCrs ) );
120 const int extractType = parameterAsInt( parameters, QStringLiteral(
"EXTRACT" ), context );
123 iter.startRasterRead( mBand, mLayerWidth, mLayerHeight, mExtent );
129 std::unique_ptr< QgsRasterBlock > rasterBlock;
131 double rasterMinimum = std::numeric_limits< double >::quiet_NaN();
132 double rasterMaximum = std::numeric_limits< double >::quiet_NaN();
139 blockExtent.
yMaximum() - mRasterUnitsPerPixelY * ( row + 0.5 ) );
143 while ( iter.readNextRasterPart( mBand, iterCols, iterRows, rasterBlock, iterLeft, iterTop, &blockExtent ) )
148 double blockMinimum = std::numeric_limits< double >::quiet_NaN();
149 double blockMaximum = std::numeric_limits< double >::quiet_NaN();
154 switch ( extractType )
158 if ( rasterBlock->minimumMaximum( blockMinimum, blockMinRow, blockMinCol, blockMaximum, blockMaxRow, blockMaxCol ) )
160 if ( std::isnan( rasterMinimum ) || blockMinimum < rasterMinimum )
162 rasterMinimum = blockMinimum;
163 rasterMinPoint = blockRowColToXY( blockExtent, blockMinRow, blockMinCol );
165 if ( std::isnan( rasterMaximum ) || blockMaximum > rasterMaximum )
167 rasterMaximum = blockMaximum;
168 rasterMaxPoint = blockRowColToXY( blockExtent, blockMaxRow, blockMaxCol );
176 if ( rasterBlock->minimum( blockMinimum, blockMinRow, blockMinCol ) )
178 if ( std::isnan( rasterMinimum ) || blockMinimum < rasterMinimum )
180 rasterMinimum = blockMinimum;
181 rasterMinPoint = blockRowColToXY( blockExtent, blockMinRow, blockMinCol );
189 if ( rasterBlock->maximum( blockMaximum, blockMaxRow, blockMaxCol ) )
191 if ( std::isnan( rasterMaximum ) || blockMaximum > rasterMaximum )
193 rasterMaximum = blockMaximum;
194 rasterMaxPoint = blockRowColToXY( blockExtent, blockMaxRow, blockMaxCol );
202 feedback->
setProgress( 100 * iter.progress( mBand ) );
209 if ( !std::isnan( rasterMinimum ) )
217 if ( !std::isnan( rasterMaximum ) )
224 outputs.insert( QStringLiteral(
"OUTPUT" ), dest );
226 outputs.insert( QStringLiteral(
"MINIMUM" ), !std::isnan( rasterMinimum ) ? QVariant::fromValue( rasterMinimum ) : QVariant() );
227 outputs.insert( QStringLiteral(
"MAXIMUM" ), !std::isnan( rasterMaximum ) ? QVariant::fromValue( rasterMaximum ) : QVariant() );
@ VectorPoint
Vector point layers.
@ FastInsert
Use faster inserts, at the cost of updating the passed features to reflect changes made at the provid...
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
void setAttributes(const QgsAttributes &attrs)
Sets the feature's attributes.
void setGeometry(const QgsGeometry &geometry)
Set the feature's geometry.
bool isCanceled() const
Tells whether the operation has been canceled already.
void setProgress(double progress)
Sets the current progress for the feedback object.
Encapsulate a field in an attribute table or data source.
Container of fields for a vector layer.
bool append(const QgsField &field, Qgis::FieldOrigin origin=Qgis::FieldOrigin::Provider, int originIndex=-1)
Appends a field.
static QgsGeometry fromPointXY(const QgsPointXY &point)
Creates a new geometry from a QgsPointXY object.
virtual QgsRectangle extent() const
Returns the extent of the layer.
QgsCoordinateReferenceSystem crs
A class to represent a 2D point.
Contains information about the context in which a processing algorithm is executed.
Custom exception class for processing related exceptions.
Base class for providing feedback from a processing algorithm.
A numeric output for processing algorithms.
A raster band parameter for Processing algorithms.
An enum based parameter for processing algorithms, allowing for selection from predefined values.
A feature sink output for processing algorithms.
A raster layer parameter for processing algorithms.
QgsRasterDataProvider * clone() const override=0
Clone itself, create deep copy.
virtual bool sourceHasNoDataValue(int bandNo) const
Returns true if source band has no data value.
Iterator for sequentially processing raster cells.
Represents a raster layer.
int height() const
Returns the height of the (unclipped) raster.
int bandCount() const
Returns the number of bands in this layer.
double rasterUnitsPerPixelX() const
Returns the number of raster units per each raster pixel in X axis.
QgsRasterDataProvider * dataProvider() override
Returns the source data provider.
double rasterUnitsPerPixelY() const
Returns the number of raster units per each raster pixel in Y axis.
int width() const
Returns the width of the (unclipped) raster.
A rectangle specified with double values.