QGIS/python/plugins/processing/gui/BatchInputSelectionPanel.py

177 lines
6.9 KiB
Python
Raw Normal View History

2012-10-05 23:28:47 +02:00
# -*- coding: utf-8 -*-
"""
***************************************************************************
BatchInputSelectionPanel.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. *
* *
***************************************************************************
"""
2016-09-21 18:24:26 +02:00
from builtins import str
from builtins import range
2012-10-05 23:28:47 +02:00
__author__ = 'Victor Olaya'
__date__ = 'August 2012'
__copyright__ = '(C) 2012, Victor Olaya'
2012-10-05 23:28:47 +02:00
# This will get replaced with a git SHA1 when you do a git archive
2012-10-05 23:28:47 +02:00
__revision__ = '$Format:%H$'
import os
from qgis.PyQt.QtCore import pyqtSignal
2016-04-22 10:38:48 +02:00
from qgis.PyQt.QtWidgets import QWidget, QHBoxLayout, QMenu, QPushButton, QLineEdit, QSizePolicy, QAction, QFileDialog
from qgis.PyQt.QtGui import QCursor
from qgis.core import QgsMapLayer, QgsSettings
from processing.gui.MultipleInputDialog import MultipleInputDialog
from processing.core.parameters import ParameterMultipleInput
from processing.core.parameters import ParameterRaster
from processing.core.parameters import ParameterVector
from processing.core.parameters import ParameterTable
2012-09-15 18:25:25 +03:00
from processing.tools import dataobjects
2012-09-15 18:25:25 +03:00
class BatchInputSelectionPanel(QWidget):
2012-09-15 18:25:25 +03:00
valueChanged = pyqtSignal()
def __init__(self, param, row, col, dialog):
super(BatchInputSelectionPanel, self).__init__(None)
2012-09-15 18:25:25 +03:00
self.param = param
self.dialog = dialog
2012-09-15 18:25:25 +03:00
self.row = row
self.col = col
self.horizontalLayout = QHBoxLayout(self)
self.horizontalLayout.setSpacing(0)
2012-09-15 18:25:25 +03:00
self.horizontalLayout.setMargin(0)
self.text = QLineEdit()
self.text.setObjectName('text')
self.text.setMinimumWidth(300)
self.setValue('')
self.text.editingFinished.connect(self.textEditingFinished)
self.text.setSizePolicy(QSizePolicy.Expanding,
QSizePolicy.Expanding)
2012-09-15 18:25:25 +03:00
self.horizontalLayout.addWidget(self.text)
self.pushButton = QPushButton()
self.pushButton.setText('...')
2014-04-19 22:04:24 +02:00
self.pushButton.clicked.connect(self.showPopupMenu)
2012-09-15 18:25:25 +03:00
self.horizontalLayout.addWidget(self.pushButton)
self.setLayout(self.horizontalLayout)
2014-04-19 22:04:24 +02:00
def _panel(self):
return self.dialog.mainWidget
def _table(self):
return self._panel().tblParameters
def showPopupMenu(self):
popupmenu = QMenu()
if not (isinstance(self.param, ParameterMultipleInput) and
self.param.datatype == dataobjects.TYPE_FILE):
selectLayerAction = QAction(
self.tr('Select from open layers'), self.pushButton)
selectLayerAction.triggered.connect(self.showLayerSelectionDialog)
popupmenu.addAction(selectLayerAction)
selectFileAction = QAction(
self.tr('Select from filesystem'), self.pushButton)
selectFileAction.triggered.connect(self.showFileSelectionDialog)
popupmenu.addAction(selectFileAction)
popupmenu.exec_(QCursor.pos())
2012-09-15 18:25:25 +03:00
def showLayerSelectionDialog(self):
if (isinstance(self.param, ParameterRaster) or
(isinstance(self.param, ParameterMultipleInput) and
self.param.datatype == dataobjects.TYPE_RASTER)):
2014-04-19 22:04:24 +02:00
layers = dataobjects.getRasterLayers()
elif isinstance(self.param, ParameterTable):
2014-04-19 22:04:24 +02:00
layers = dataobjects.getTables()
else:
if isinstance(self.param, ParameterVector):
datatype = self.param.datatype
else:
datatype = [self.param.datatype]
2014-04-19 22:04:24 +02:00
layers = dataobjects.getVectorLayers(datatype)
dlg = MultipleInputDialog([layer.name() for layer in layers])
dlg.exec_()
2014-04-19 22:04:24 +02:00
if dlg.selectedoptions is not None:
selected = dlg.selectedoptions
if len(selected) == 1:
self.setValue(layers[selected[0]])
2014-04-19 22:04:24 +02:00
else:
if isinstance(self.param, ParameterMultipleInput):
self.text.setText(';'.join(layers[idx].name() for idx in selected))
else:
rowdif = len(selected) - (self._table().rowCount() - self.row)
for i in range(rowdif):
self._panel().addRow()
for i, layeridx in enumerate(selected):
self._table().cellWidget(i + self.row,
self.col).setValue(layers[layeridx])
2014-04-19 22:04:24 +02:00
def showFileSelectionDialog(self):
settings = QgsSettings()
2016-09-21 18:24:26 +02:00
text = str(self.text.text())
if os.path.isdir(text):
path = text
elif os.path.isdir(os.path.dirname(text)):
path = os.path.dirname(text)
elif settings.contains('/Processing/LastInputPath'):
2016-09-21 18:24:26 +02:00
path = str(settings.value('/Processing/LastInputPath'))
else:
path = ''
2013-03-26 14:15:12 +01:00
ret, selected_filter = QFileDialog.getOpenFileNames(self, self.tr('Open file'), path,
self.tr('All files(*.*);;') + self.param.getFileFilter())
2013-03-26 14:15:12 +01:00
if ret:
files = list(ret)
settings.setValue('/Processing/LastInputPath',
2016-09-21 18:24:26 +02:00
os.path.dirname(str(files[0])))
for i, filename in enumerate(files):
2015-01-22 20:53:45 +01:00
files[i] = dataobjects.getRasterSublayer(filename, self.param)
if len(files) == 1:
self.text.setText(files[0])
self.textEditingFinished()
2012-09-15 18:25:25 +03:00
else:
if isinstance(self.param, ParameterMultipleInput):
2016-09-21 18:24:26 +02:00
self.text.setText(';'.join(str(f) for f in files))
2012-09-15 18:25:25 +03:00
else:
rowdif = len(files) - (self._table().rowCount() - self.row)
2012-09-15 18:25:25 +03:00
for i in range(rowdif):
self._panel().addRow()
for i, f in enumerate(files):
self._table().cellWidget(i + self.row,
self.col).setValue(f)
def textEditingFinished(self):
self._value = self.text.text()
self.valueChanged.emit()
def value(self):
return self._value
def setValue(self, value):
self._value = value
if isinstance(value, QgsMapLayer):
self.text.setText(value.name())
else: # should be basestring
self.text.setText(value)
self.valueChanged.emit()