from PyQt4 import QtGui from sextante.core.GeoAlgorithm import GeoAlgorithm from sextante.parameters.ParameterRaster import ParameterRaster from sextante.parameters.ParameterBoolean import ParameterBoolean import os from sextante.gdal.GdalUtils import GdalUtils from sextante.outputs.OutputHTML import OutputHTML class information(GeoAlgorithm): INPUT = "INPUT" OUTPUT = "OUTPUT" NOGCP = "NOGCP" NOMETADATA = "NOMETADATA" def getIcon(self): filepath = os.path.dirname(__file__) + "/icons/raster-info.png" return QtGui.QIcon(filepath) def defineCharacteristics(self): self.name = "information" self.group = "Miscellaneous" self.addParameter(ParameterRaster(information.INPUT, "Input layer", False)) self.addParameter(ParameterBoolean(information.NOGCP, "Suppress GCP info", False)) self.addParameter(ParameterBoolean(information.NOMETADATA, "Suppress metadata info", False)) self.addOutput(OutputHTML(information.OUTPUT, "Layer information")) def processAlgorithm(self, progress): commands = ["gdalinfo"] if self.getParameterValue(information.NOGCP): commands.append("-nogcp") if self.getParameterValue(information.NOMETADATA): commands.append("-nomd") commands.append(self.getParameterValue(information.INPUT)) GdalUtils.runGdal(commands, progress) output = self.getOutputValue(information.OUTPUT) f = open(output, "w") for s in GdalUtils.getConsoleOutput()[1:]: f.write("

" + str(s) + "

") f.close()