2012-10-05 23:28:47 +02:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
"""
|
|
|
|
***************************************************************************
|
|
|
|
ParameterMultipleInput.py
|
|
|
|
---------------------
|
|
|
|
Date : August 2012
|
|
|
|
Copyright : (C) 2012 by Victor Olaya
|
|
|
|
Email : volayaf at gmail dot com
|
|
|
|
***************************************************************************
|
|
|
|
* *
|
|
|
|
* This program is free software; you can redistribute it and/or modify *
|
|
|
|
* it under the terms of the GNU General Public License as published by *
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or *
|
|
|
|
* (at your option) any later version. *
|
|
|
|
* *
|
|
|
|
***************************************************************************
|
|
|
|
"""
|
|
|
|
|
|
|
|
__author__ = 'Victor Olaya'
|
|
|
|
__date__ = 'August 2012'
|
|
|
|
__copyright__ = '(C) 2012, Victor Olaya'
|
2013-10-01 20:52:22 +03:00
|
|
|
|
2012-10-05 23:28:47 +02:00
|
|
|
# This will get replaced with a git SHA1 when you do a git archive
|
2013-10-01 20:52:22 +03:00
|
|
|
|
2012-10-05 23:28:47 +02:00
|
|
|
__revision__ = '$Format:%H$'
|
|
|
|
|
2013-10-01 20:52:22 +03:00
|
|
|
from qgis.core import *
|
2013-08-12 20:44:27 +02:00
|
|
|
from processing.parameters.ParameterDataObject import ParameterDataObject
|
2013-09-12 13:19:00 +02:00
|
|
|
from processing.tools import dataobjects
|
2012-09-15 18:25:25 +03:00
|
|
|
|
|
|
|
|
|
|
|
class ParameterMultipleInput(ParameterDataObject):
|
2013-10-01 20:52:22 +03:00
|
|
|
"""A parameter representing several data objects.
|
|
|
|
|
|
|
|
Its value is a string with substrings separated by semicolons,
|
|
|
|
each of which represents the data source location of each element.
|
|
|
|
"""
|
2012-09-15 18:25:25 +03:00
|
|
|
|
|
|
|
exported = None
|
|
|
|
|
|
|
|
TYPE_VECTOR_ANY = -1
|
|
|
|
TYPE_VECTOR_POINT = 0
|
|
|
|
TYPE_VECTOR_LINE = 1
|
|
|
|
TYPE_VECTOR_POLYGON = 2
|
|
|
|
TYPE_RASTER = 3
|
|
|
|
|
2013-10-01 20:52:22 +03:00
|
|
|
def __init__(self, name='', description='', datatype=-1, optional=False):
|
2012-09-15 18:25:25 +03:00
|
|
|
ParameterDataObject.__init__(self, name, description)
|
|
|
|
self.datatype = datatype
|
|
|
|
self.optional = optional
|
|
|
|
self.value = None
|
|
|
|
self.exported = None
|
|
|
|
|
|
|
|
def setValue(self, obj):
|
|
|
|
self.exported = None
|
2013-10-01 20:52:22 +03:00
|
|
|
if obj is None:
|
2012-09-15 18:25:25 +03:00
|
|
|
if self.optional:
|
|
|
|
self.value = None
|
|
|
|
return True
|
|
|
|
else:
|
|
|
|
return False
|
|
|
|
|
|
|
|
if isinstance(obj, list):
|
|
|
|
if len(obj) == 0:
|
|
|
|
if self.optional:
|
|
|
|
return True
|
|
|
|
else:
|
|
|
|
return False
|
2013-10-01 20:52:22 +03:00
|
|
|
s = ''
|
2012-09-15 18:25:25 +03:00
|
|
|
idx = 0
|
|
|
|
for layer in obj:
|
|
|
|
s += self.getAsString(layer)
|
|
|
|
if idx < len(obj) - 1:
|
2013-10-01 20:52:22 +03:00
|
|
|
s += ';'
|
|
|
|
idx = idx + 1
|
|
|
|
self.value = s
|
2012-09-15 18:25:25 +03:00
|
|
|
return True
|
|
|
|
else:
|
|
|
|
self.value = unicode(obj)
|
|
|
|
return True
|
|
|
|
|
|
|
|
def getSafeExportedLayers(self):
|
2013-10-01 20:52:22 +03:00
|
|
|
"""Returns not the value entered by the user, but a string with
|
|
|
|
semicolon-separated filenames which contains the data of the
|
|
|
|
selected layers, but saved in a standard format (currently
|
|
|
|
shapefiles for vector layers and GeoTiff for raster) so that
|
|
|
|
they can be opened by most external applications.
|
|
|
|
|
|
|
|
If there is a selection and QGIS is configured to use just the
|
|
|
|
selection, if exports the layer even if it is already in a
|
|
|
|
suitable format.
|
|
|
|
|
|
|
|
Works only if the layer represented by the parameter value is
|
|
|
|
currently loaded in QGIS. Otherwise, it will not perform any
|
|
|
|
export and return the current value string.
|
|
|
|
|
|
|
|
If the current value represents a layer in a suitable format,
|
|
|
|
it does no export at all and returns that value.
|
|
|
|
|
|
|
|
Currently, it works just for vector layer. In the case of
|
|
|
|
raster layers, it returns the parameter value.
|
|
|
|
|
|
|
|
The layers are exported just the first time the method is
|
|
|
|
called. The method can be called several times and it will
|
|
|
|
always return the same string, performing the export only the
|
|
|
|
first time.
|
|
|
|
"""
|
|
|
|
|
2012-09-15 18:25:25 +03:00
|
|
|
if self.exported:
|
|
|
|
return self.exported
|
|
|
|
self.exported = self.value
|
2013-10-01 20:52:22 +03:00
|
|
|
layers = self.value.split(';')
|
|
|
|
if layers is None or len(layers) == 0:
|
2012-09-15 18:25:25 +03:00
|
|
|
return self.value
|
|
|
|
if self.datatype == ParameterMultipleInput.TYPE_RASTER:
|
|
|
|
for layerfile in layers:
|
2013-09-12 13:19:00 +02:00
|
|
|
layer = dataobjects.getObjectFromUri(layerfile, False)
|
2012-09-15 18:25:25 +03:00
|
|
|
if layer:
|
2013-09-12 13:19:00 +02:00
|
|
|
filename = dataobjects.exportRasterLayer(layer)
|
2012-09-15 18:25:25 +03:00
|
|
|
self.exported = self.exported.replace(layerfile, filename)
|
|
|
|
return self.exported
|
|
|
|
else:
|
|
|
|
for layerfile in layers:
|
2013-09-12 13:19:00 +02:00
|
|
|
layer = dataobjects.getObjectFromUri(layerfile, False)
|
2012-09-15 18:25:25 +03:00
|
|
|
if layer:
|
2013-09-12 13:19:00 +02:00
|
|
|
filename = dataobjects.exportVectorLayer(layer)
|
2012-09-15 18:25:25 +03:00
|
|
|
self.exported = self.exported.replace(layerfile, filename)
|
|
|
|
return self.exported
|
|
|
|
|
2013-10-01 20:52:22 +03:00
|
|
|
def getAsString(self, value):
|
2012-09-15 18:25:25 +03:00
|
|
|
if self.datatype == ParameterMultipleInput.TYPE_RASTER:
|
|
|
|
if isinstance(value, QgsRasterLayer):
|
|
|
|
return unicode(value.dataProvider().dataSourceUri())
|
|
|
|
else:
|
|
|
|
s = unicode(value)
|
2013-09-12 13:19:00 +02:00
|
|
|
layers = dataobjects.getRasterLayers()
|
2012-09-15 18:25:25 +03:00
|
|
|
for layer in layers:
|
|
|
|
if layer.name() == s:
|
|
|
|
return unicode(layer.dataProvider().dataSourceUri())
|
|
|
|
return s
|
|
|
|
else:
|
|
|
|
if isinstance(value, QgsVectorLayer):
|
|
|
|
return unicode(value.source())
|
|
|
|
else:
|
|
|
|
s = unicode(value)
|
2013-09-12 13:19:00 +02:00
|
|
|
layers = dataobjects.getVectorLayers(self.datatype)
|
2012-09-15 18:25:25 +03:00
|
|
|
for layer in layers:
|
|
|
|
if layer.name() == s:
|
|
|
|
return unicode(layer.source())
|
|
|
|
return s
|
|
|
|
|
2013-03-23 01:06:39 +01:00
|
|
|
def getFileFilter(self):
|
|
|
|
if self.datatype == ParameterMultipleInput.TYPE_RASTER:
|
2013-09-12 13:19:00 +02:00
|
|
|
exts = dataobjects.getSupportedOutputRasterLayerExtensions()
|
2013-03-23 01:06:39 +01:00
|
|
|
else:
|
2013-09-12 13:19:00 +02:00
|
|
|
exts = dataobjects.getSupportedOutputVectorLayerExtensions()
|
2013-03-23 01:06:39 +01:00
|
|
|
for i in range(len(exts)):
|
2013-10-01 20:52:22 +03:00
|
|
|
exts[i] = exts[i].upper() + ' files(*.' + exts[i].lower() + ')'
|
|
|
|
return ';;'.join(exts)
|
2012-09-15 18:25:25 +03:00
|
|
|
|
|
|
|
def serialize(self):
|
2013-10-01 20:52:22 +03:00
|
|
|
return self.__module__.split('.')[-1] + '|' + self.name + '|' \
|
|
|
|
+ self.description + '|' + str(self.datatype) + '|' \
|
|
|
|
+ str(self.optional)
|
2012-09-15 18:25:25 +03:00
|
|
|
|
|
|
|
def deserialize(self, s):
|
2013-10-01 20:52:22 +03:00
|
|
|
tokens = s.split('|')
|
|
|
|
return ParameterMultipleInput(tokens[1], tokens[2], float(tokens[3]),
|
|
|
|
tokens[4] == str(True))
|
2012-09-15 18:25:25 +03:00
|
|
|
|
|
|
|
def getAsScriptCode(self):
|
|
|
|
if self.datatype == ParameterMultipleInput.TYPE_RASTER:
|
2013-10-01 20:52:22 +03:00
|
|
|
return '##' + self.name + '=multiple raster'
|
2012-09-15 18:25:25 +03:00
|
|
|
else:
|
2013-10-01 20:52:22 +03:00
|
|
|
return '##' + self.name + '=multiple vector'
|