2012-10-05 23:28:47 +02:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
"""
|
|
|
|
***************************************************************************
|
|
|
|
ParameterVector.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
|
|
|
import os
|
|
|
|
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
|
2013-10-01 20:52:22 +03:00
|
|
|
|
2012-09-15 18:25:25 +03:00
|
|
|
|
|
|
|
class ParameterVector(ParameterDataObject):
|
|
|
|
|
|
|
|
VECTOR_TYPE_POINT = 0
|
|
|
|
VECTOR_TYPE_LINE = 1
|
|
|
|
VECTOR_TYPE_POLYGON = 2
|
|
|
|
VECTOR_TYPE_ANY = -1
|
|
|
|
|
2013-10-01 20:52:22 +03:00
|
|
|
def __init__(self, name='', description='', shapetype=[-1],
|
|
|
|
optional=False):
|
2012-09-15 18:25:25 +03:00
|
|
|
ParameterDataObject.__init__(self, name, description)
|
|
|
|
self.optional = optional
|
2013-08-12 20:44:27 +02:00
|
|
|
if isinstance(shapetype, int):
|
|
|
|
shapetype = [shapetype]
|
2012-09-15 18:25:25 +03:00
|
|
|
self.shapetype = shapetype
|
|
|
|
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, QgsVectorLayer):
|
|
|
|
self.value = unicode(obj.source())
|
|
|
|
return True
|
|
|
|
else:
|
|
|
|
self.value = unicode(obj)
|
2013-09-12 13:19:00 +02:00
|
|
|
layers = dataobjects.getVectorLayers(self.shapetype)
|
2012-09-15 18:25:25 +03:00
|
|
|
for layer in layers:
|
2013-10-01 20:52:22 +03:00
|
|
|
if layer.name() == self.value or layer.source() == self.value:
|
2012-09-15 18:25:25 +03:00
|
|
|
self.value = unicode(layer.source())
|
|
|
|
return True
|
2013-02-03 10:27:42 +01:00
|
|
|
return os.path.exists(self.value)
|
2012-09-15 18:25:25 +03:00
|
|
|
|
|
|
|
def getSafeExportedLayer(self):
|
2013-10-01 20:52:22 +03:00
|
|
|
"""Returns not the value entered by the user, but a string with
|
|
|
|
a filename which contains the data of this layer, but saved in
|
|
|
|
a standard format (currently always a shapefile) so that it 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 not export at all and returns that value.
|
|
|
|
|
|
|
|
The layer is exported just the first time the method is called.
|
|
|
|
The method can be called several times and it will always
|
|
|
|
return the same file, performing the export only the first
|
|
|
|
time.
|
|
|
|
"""
|
|
|
|
|
2012-09-15 18:25:25 +03:00
|
|
|
if self.exported:
|
|
|
|
return self.exported
|
2013-09-12 13:19:00 +02:00
|
|
|
layer = dataobjects.getObjectFromUri(self.value, False)
|
2012-09-15 18:25:25 +03:00
|
|
|
if layer:
|
2013-09-12 13:19:00 +02:00
|
|
|
self.exported = dataobjects.exportVectorLayer(layer)
|
2012-09-15 18:25:25 +03:00
|
|
|
else:
|
|
|
|
self.exported = self.value
|
|
|
|
return self.exported
|
2013-03-26 14:15:12 +01:00
|
|
|
|
2013-03-23 01:06:39 +01:00
|
|
|
def getFileFilter(self):
|
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 + '|' + ','.join(str(t) for t in
|
|
|
|
self.shapetype) + '|' + 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 ParameterVector(tokens[1], tokens[2], [int(t) for t in
|
|
|
|
tokens[3].split(',')], str(True) == tokens[4])
|
2012-09-15 18:25:25 +03:00
|
|
|
|
|
|
|
def getAsScriptCode(self):
|
2013-10-01 20:52:22 +03:00
|
|
|
return '##' + self.name + '=vector'
|