2012-09-15 18:25:25 +03:00
|
|
|
import os
|
|
|
|
from sextante.lidar.lastools.LasToolsUtils import LasToolsUtils
|
|
|
|
from sextante.lidar.lastools.LasToolsAlgorithm import LasToolsAlgorithm
|
|
|
|
from sextante.parameters.ParameterFile import ParameterFile
|
|
|
|
from sextante.outputs.OutputFile import OutputFile
|
|
|
|
from sextante.parameters.ParameterVector import ParameterVector
|
|
|
|
|
|
|
|
class lasclip(LasToolsAlgorithm):
|
|
|
|
|
|
|
|
INPUT = "INPUT"
|
|
|
|
OUTPUT = "OUTPUT"
|
|
|
|
POLYGON = "POLYGON"
|
|
|
|
|
|
|
|
def defineCharacteristics(self):
|
|
|
|
self.name = "lasclip"
|
|
|
|
self.group = "Tools"
|
|
|
|
self.addParameter(ParameterFile(lasclip.INPUT, "Input las layer"))
|
|
|
|
self.addParameter(ParameterVector(lasclip.POLYGON, "Input polygons", ParameterVector.VECTOR_TYPE_POLYGON))
|
|
|
|
self.addOutput(OutputFile(lasclip.OUTPUT, "Output classified las file"))
|
|
|
|
self.addCommonParameters()
|
|
|
|
|
|
|
|
def processAlgorithm(self, progress):
|
|
|
|
commands = [os.path.join(LasToolsUtils.LasToolsPath(), "bin", "lasclip.exe")]
|
|
|
|
commands.append("-i")
|
|
|
|
commands.append(self.getParameterValue(lasclip.INPUT))
|
|
|
|
commands.append("-poly")
|
|
|
|
commands.append(self.getParameterValue(lasclip.POLYGON))
|
|
|
|
commands.append("-o")
|
|
|
|
commands.append(self.getOutputValue(lasclip.OUTPUT))
|
|
|
|
self.addCommonParameterValuesToCommand(commands)
|
|
|
|
|
|
|
|
LasToolsUtils.runLasTools(commands, progress)
|