Skip to content

Commit

Permalink
Port gdal tri alg to new API
Browse files Browse the repository at this point in the history
  • Loading branch information
nyalldawson committed Aug 13, 2017
1 parent ab2886d commit 1cbbbc4
Show file tree
Hide file tree
Showing 4 changed files with 49 additions and 47 deletions.
6 changes: 3 additions & 3 deletions python/plugins/processing/algs/gdal/GdalAlgorithmProvider.py
Expand Up @@ -35,6 +35,7 @@


from .AssignProjection import AssignProjection from .AssignProjection import AssignProjection
from .aspect import aspect from .aspect import aspect
from .tri import tri
from .warp import warp from .warp import warp
# from .nearblack import nearblack # from .nearblack import nearblack
# from .information import information # from .information import information
Expand All @@ -56,8 +57,6 @@
# from .gdal2xyz import gdal2xyz # from .gdal2xyz import gdal2xyz
# from .hillshade import hillshade # from .hillshade import hillshade
# from .slope import slope # from .slope import slope

# from .tri import tri
# from .tpi import tpi # from .tpi import tpi
# from .roughness import roughness # from .roughness import roughness
# from .ColorRelief import ColorRelief # from .ColorRelief import ColorRelief
Expand Down Expand Up @@ -145,6 +144,7 @@ def loadAlgorithms(self):
# information(), # information(),
AssignProjection(), AssignProjection(),
aspect(), aspect(),
tri(),
warp(), warp(),
# translate(), # translate(),
# rgb2pct(), # rgb2pct(),
Expand All @@ -164,7 +164,7 @@ def loadAlgorithms(self):
# gdal2xyz(), # gdal2xyz(),
# hillshade(), # hillshade(),
# slope(), # slope(),
# tri(), #
# tpi(), # tpi(),
# roughness(), # roughness(),
# ColorRelief(), # ColorRelief(),
Expand Down
6 changes: 3 additions & 3 deletions python/plugins/processing/algs/gdal/aspect.py
Expand Up @@ -29,7 +29,7 @@
import os import os


from qgis.core import (QgsProcessingParameterRasterLayer, from qgis.core import (QgsProcessingParameterRasterLayer,
QgsProcessingParameterNumber, QgsProcessingParameterBand,
QgsProcessingParameterBoolean, QgsProcessingParameterBoolean,
QgsProcessingParameterRasterDestination) QgsProcessingParameterRasterDestination)
from processing.algs.gdal.GdalAlgorithm import GdalAlgorithm from processing.algs.gdal.GdalAlgorithm import GdalAlgorithm
Expand All @@ -53,8 +53,8 @@ def __init__(self):


def initAlgorithm(self, config=None): def initAlgorithm(self, config=None):
self.addParameter(QgsProcessingParameterRasterLayer(self.INPUT, self.tr('Input layer'))) self.addParameter(QgsProcessingParameterRasterLayer(self.INPUT, self.tr('Input layer')))
self.addParameter(QgsProcessingParameterNumber( self.addParameter(QgsProcessingParameterBand(
self.BAND, self.tr('Band number'), minValue=1, maxValue=99, defaultValue=1)) self.BAND, self.tr('Band number'), parentLayerParameterName=self.INPUT))
self.addParameter(QgsProcessingParameterBoolean( self.addParameter(QgsProcessingParameterBoolean(
self.COMPUTE_EDGES, self.tr('Compute edges'), defaultValue=False)) self.COMPUTE_EDGES, self.tr('Compute edges'), defaultValue=False))
self.addParameter(QgsProcessingParameterBoolean(self.ZEVENBERGEN, self.addParameter(QgsProcessingParameterBoolean(self.ZEVENBERGEN,
Expand Down
30 changes: 16 additions & 14 deletions python/plugins/processing/algs/gdal/tri.py
Expand Up @@ -29,11 +29,11 @@


import os import os


from qgis.core import (QgsProcessingParameterRasterLayer,
QgsProcessingParameterBand,
QgsProcessingParameterBoolean,
QgsProcessingParameterRasterDestination)
from processing.algs.gdal.GdalAlgorithm import GdalAlgorithm from processing.algs.gdal.GdalAlgorithm import GdalAlgorithm
from processing.core.parameters import ParameterRaster
from processing.core.parameters import ParameterBoolean
from processing.core.parameters import ParameterNumber
from processing.core.outputs import OutputRaster
from processing.algs.gdal.GdalUtils import GdalUtils from processing.algs.gdal.GdalUtils import GdalUtils


pluginPath = os.path.split(os.path.split(os.path.dirname(__file__))[0])[0] pluginPath = os.path.split(os.path.split(os.path.dirname(__file__))[0])[0]
Expand All @@ -50,13 +50,13 @@ def __init__(self):
super().__init__() super().__init__()


def initAlgorithm(self, config=None): def initAlgorithm(self, config=None):
self.addParameter(ParameterRaster(self.INPUT, self.tr('Input layer'))) self.addParameter(QgsProcessingParameterRasterLayer(self.INPUT, self.tr('Input layer')))
self.addParameter(ParameterNumber(self.BAND, self.addParameter(QgsProcessingParameterBand(self.BAND,
self.tr('Band number'), 1, 99, 1)) self.tr('Band number'), parentLayerParameterName=self.INPUT))
self.addParameter(ParameterBoolean(self.COMPUTE_EDGES, self.addParameter(QgsProcessingParameterBoolean(self.COMPUTE_EDGES,
self.tr('Compute edges'), False)) self.tr('Compute edges'), defaultValue=False))


self.addOutput(OutputRaster(self.OUTPUT, self.tr('Terrain Ruggedness Index'))) self.addParameter(QgsProcessingParameterRasterDestination(self.OUTPUT, self.tr('Terrain Ruggedness Index')))


def name(self): def name(self):
return 'triterrainruggednessindex' return 'triterrainruggednessindex'
Expand All @@ -69,13 +69,15 @@ def group(self):


def getConsoleCommands(self, parameters, context, feedback): def getConsoleCommands(self, parameters, context, feedback):
arguments = ['TRI'] arguments = ['TRI']
arguments.append(str(self.getParameterValue(self.INPUT))) inLayer = self.parameterAsRasterLayer(parameters, self.INPUT, context)
arguments.append(str(self.getOutputValue(self.OUTPUT))) arguments.append(inLayer.source())
out = self.parameterAsOutputLayer(parameters, self.OUTPUT, context)
arguments.append(out)


arguments.append('-b') arguments.append('-b')
arguments.append(str(self.getParameterValue(self.BAND))) arguments.append(str(self.parameterAsInt(parameters, self.BAND, context)))


if self.getParameterValue(self.COMPUTE_EDGES): if self.parameterAsBool(parameters, self.COMPUTE_EDGES, context):
arguments.append('-compute_edges') arguments.append('-compute_edges')


return ['gdaldem', GdalUtils.escapeAndJoin(arguments)] return ['gdaldem', GdalUtils.escapeAndJoin(arguments)]
54 changes: 27 additions & 27 deletions python/plugins/processing/tests/testdata/gdal_algorithm_tests.yaml
Expand Up @@ -482,33 +482,33 @@ tests:
# OUTPUT: # OUTPUT:
# hash: aba5167b8a2e97a93b22d406e0363f91c151fd353c0fc56ce24ac5fc # hash: aba5167b8a2e97a93b22d406e0363f91c151fd353c0fc56ce24ac5fc
# type: rasterhash # type: rasterhash
#
# - algorithm: gdal:triterrainruggednessindex - algorithm: gdal:triterrainruggednessindex
# name: standard TRI name: standard TRI
# params: params:
# BAND: 1 BAND: 1
# COMPUTE_EDGES: false COMPUTE_EDGES: false
# INPUT: INPUT:
# name: dem.tif name: dem.tif
# type: raster type: raster
# results: results:
# OUTPUT: OUTPUT:
# hash: c888764a08fae72a129dfff4947149c3185532373d33d4537ecf409c hash: c888764a08fae72a129dfff4947149c3185532373d33d4537ecf409c
# type: rasterhash type: rasterhash
#
# - algorithm: gdal:triterrainruggednessindex - algorithm: gdal:triterrainruggednessindex
# name: TRI with edges name: TRI with edges
# params: params:
# BAND: 1 BAND: 1
# COMPUTE_EDGES: true COMPUTE_EDGES: true
# INPUT: INPUT:
# name: dem.tif name: dem.tif
# type: raster type: raster
# results: results:
# OUTPUT: OUTPUT:
# hash: 07376c74de869323125ceacbb5e34438655ff73f63d4b3ff3e268f7f hash: 07376c74de869323125ceacbb5e34438655ff73f63d4b3ff3e268f7f
# type: rasterhash type: rasterhash
#
# - algorithm: gdal:nearblack # - algorithm: gdal:nearblack
# name: standard near black # name: standard near black
# params: # params:
Expand Down

0 comments on commit 1cbbbc4

Please sign in to comment.