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

92 lines
2.9 KiB
Python
Raw Normal View History

2012-10-05 23:28:47 +02:00
# -*- coding: utf-8 -*-
"""
***************************************************************************
RangePanel.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'
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$'
2015-05-18 21:04:20 +03:00
import os
2012-09-15 18:25:25 +03:00
2016-04-29 11:39:26 +02:00
from qgis.PyQt import uic
from qgis.PyQt.QtCore import pyqtSignal
from qgis.PyQt.QtWidgets import QDialog
from qgis.core import QgsProcessingParameterNumber
2015-05-18 21:04:20 +03:00
pluginPath = os.path.split(os.path.dirname(__file__))[0]
WIDGET, BASE = uic.loadUiType(
os.path.join(pluginPath, 'ui', 'widgetRangeSelector.ui'))
2014-11-08 17:33:02 +02:00
2015-05-18 21:04:20 +03:00
class RangePanel(BASE, WIDGET):
2012-09-15 18:25:25 +03:00
hasChanged = pyqtSignal()
2012-09-15 18:25:25 +03:00
def __init__(self, param):
2015-05-18 21:04:20 +03:00
super(RangePanel, self).__init__(None)
2014-11-08 17:33:02 +02:00
self.setupUi(self)
self.param = param
# Integer or Double range
if self.param.dataType() == QgsProcessingParameterNumber.Integer:
self.spnMin.setDecimals(0)
self.spnMax.setDecimals(0)
if param.defaultValue() is not None:
self.setValue(param.defaultValue())
values = self.getValues()
# Spin range logic
self.spnMin.valueChanged.connect(lambda: self.setMinMax())
self.spnMax.valueChanged.connect(lambda: self.setMaxMin())
def setMinMax(self):
values = self.getValues()
if values[0] >= values[1]:
self.spnMax.setValue(values[0])
self.hasChanged.emit()
def setMaxMin(self):
values = self.getValues()
if values[0] >= values[1]:
self.spnMin.setValue(values[1])
self.hasChanged.emit()
2012-09-15 18:25:25 +03:00
def getValue(self):
2014-11-08 17:33:02 +02:00
return '{},{}'.format(self.spnMin.value(), self.spnMax.value())
def getValues(self):
value = self.getValue()
if value:
return [float(a) for a in value.split(',')]
def setValue(self, value):
try:
values = value.split(',')
minVal = float(values[0])
maxVal = float(values[1])
self.spnMin.setValue(float(minVal))
self.spnMax.setValue(float(maxVal))
except:
return