QGIS API Documentation 3.41.0-Master (af5edcb665c)
Loading...
Searching...
No Matches
qgsalgorithmhillshade.cpp
Go to the documentation of this file.
1/***************************************************************************
2 qgsalgorithmhillshade.cpp
3 ---------------------
4 begin : November 2019
5 copyright : (C) 2019 by Alexander Bruy
6 email : alexander dot bruy 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
19#include "qgsrasterfilewriter.h"
20#include "qgshillshadefilter.h"
21
23
24QString QgsHillshadeAlgorithm::name() const
25{
26 return QStringLiteral( "hillshade" );
27}
28
29QString QgsHillshadeAlgorithm::displayName() const
30{
31 return QObject::tr( "Hillshade" );
32}
33
34QStringList QgsHillshadeAlgorithm::tags() const
35{
36 return QObject::tr( "dem,hillshade,terrain" ).split( ',' );
37}
38
39QString QgsHillshadeAlgorithm::group() const
40{
41 return QObject::tr( "Raster terrain analysis" );
42}
43
44QString QgsHillshadeAlgorithm::groupId() const
45{
46 return QStringLiteral( "rasterterrainanalysis" );
47}
48
49QString QgsHillshadeAlgorithm::shortHelpString() const
50{
51 return QObject::tr( "This algorithm calculates the hillshade of the Digital Terrain Model in input." )
52 + QStringLiteral( "\n\n" )
53 + QObject::tr( "The shading of the layer is calculated according to the sun position (azimuth and elevation)." );
54}
55
56QgsHillshadeAlgorithm *QgsHillshadeAlgorithm::createInstance() const
57{
58 return new QgsHillshadeAlgorithm();
59}
60
61void QgsHillshadeAlgorithm::initAlgorithm( const QVariantMap & )
62{
63 addParameter( new QgsProcessingParameterRasterLayer( QStringLiteral( "INPUT" ), QObject::tr( "Elevation layer" ) ) );
64 addParameter( new QgsProcessingParameterNumber( QStringLiteral( "Z_FACTOR" ), QObject::tr( "Z factor" ), Qgis::ProcessingNumberParameterType::Double, 1, false, 0 ) );
65 addParameter( new QgsProcessingParameterNumber( QStringLiteral( "AZIMUTH" ), QObject::tr( "Azimuth (horizontal angle)" ), Qgis::ProcessingNumberParameterType::Double, 300, false, 0, 360 ) );
66 addParameter( new QgsProcessingParameterNumber( QStringLiteral( "V_ANGLE" ), QObject::tr( "Vertical angle" ), Qgis::ProcessingNumberParameterType::Double, 40, false, 0, 90 ) );
67
68 addParameter( new QgsProcessingParameterRasterDestination( QStringLiteral( "OUTPUT" ), QObject::tr( "Hillshade" ) ) );
69}
70
71QVariantMap QgsHillshadeAlgorithm::processAlgorithm( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback )
72{
73 QgsRasterLayer *inputLayer = parameterAsRasterLayer( parameters, QStringLiteral( "INPUT" ), context );
74
75 if ( !inputLayer )
76 throw QgsProcessingException( invalidRasterError( parameters, QStringLiteral( "INPUT" ) ) );
77
78 const double zFactor = parameterAsDouble( parameters, QStringLiteral( "Z_FACTOR" ), context );
79 const double azimuth = parameterAsDouble( parameters, QStringLiteral( "AZIMUTH" ), context );
80 const double vAngle = parameterAsDouble( parameters, QStringLiteral( "V_ANGLE" ), context );
81
82 const QString outputFile = parameterAsOutputLayer( parameters, QStringLiteral( "OUTPUT" ), context );
83 const QFileInfo fi( outputFile );
84 const QString outputFormat = QgsRasterFileWriter::driverForExtension( fi.suffix() );
85
86 QgsHillshadeFilter hillshade( inputLayer->source(), outputFile, outputFormat, azimuth, vAngle );
87 hillshade.setZFactor( zFactor );
88 hillshade.processRaster( feedback );
89
90 QVariantMap outputs;
91 outputs.insert( QStringLiteral( "OUTPUT" ), outputFile );
92 return outputs;
93}
94
A hillshade filter.
QString source() const
Returns the source for the layer.
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 parameter for processing algorithms.
A raster layer destination parameter, for specifying the destination path for a raster layer created ...
A raster layer parameter for processing algorithms.
static QString driverForExtension(const QString &extension)
Returns the GDAL driver name for a specified file extension.
Represents a raster layer.