1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116
|
#/*##########################################################################
# Copyright (C) 2004-2018 V.A. Sole, European Synchrotron Radiation Facility
#
# This file is part of the PyMca X-ray Fluorescence Toolkit developed at
# the ESRF by the Software group.
#
# This file is free software; you can redistribute it and/or modify it
# under the terms of the GNU Lesser General Public License as published by the
# Free Software Foundation; either version 2 of the License, or (at your option)
# any later version.
#
# This file is distributed in the hope that it will be useful, but WITHOUT ANY
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
# details.
#
# You should have received a copy of the GNU Lesser General Public
# License along with this library; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
#
# Please contact the ESRF industrial unit (industry@esrf.fr) if this license
# is a problem for you.
#
#############################################################################*/
__author__ = "V.A. Sole - ESRF Data Analysis"
__contact__ = "sole@esrf.fr"
__license__ = "LGPL2+"
__copyright__ = "European Synchrotron Radiation Facility, Grenoble, France"
from . import Object3DQt as qt
QTVERSION = qt.qVersion()
DEBUG = 0
class Object3DSlider(qt.QWidget):
valueChanged = qt.pyqtSignal(float)
def __init__(self, parent = None, orientation=qt.Qt.Horizontal):
qt.QWidget.__init__(self, parent)
if orientation == qt.Qt.Horizontal:
alignment = qt.Qt.AlignHCenter | qt.Qt.AlignTop
layout = qt.QHBoxLayout(self)
else:
alignment = qt.Qt.AlignVCenter | qt.Qt.AlignLeft
layout = qt.QVBoxLayout(self)
layout.setContentsMargins(0, 0, 0, 0)
layout.setSpacing(0)
self.slider = qt.QSlider(self)
self.slider.setOrientation(orientation)
self.label = qt.QLabel("0", self)
self.label.setAlignment(alignment)
self.label.setFixedWidth(self.label.fontMetrics().width('100.99'))
layout.addWidget(self.slider)
layout.addWidget(self.label)
self.slider.valueChanged.connect(self.setNum)
self.__factor = 100.
def setNum(self, value):
if self.__factor != 0.0:
value = value / self.__factor
self.label.setText('%.2f' % value)
self.valueChanged.emit(value)
def setRange(self, minValue, maxValue, increment=None):
if increment is None:
self.__factor = 201.
elif increment == 0.0:
self.__factor = 1.0
else:
self.__factor = (maxValue - minValue) / float(increment)
self.slider.setRange(int(minValue * self.__factor),
int(maxValue * self.__factor))
def setValue(self, value):
self.slider.setValue(value * self.__factor)
def value(self):
if self.__factor != 0.0:
return self.slider.value()/self.__factor
else:
return float(self.slider.value())
def minValue(self):
if self.__factor != 0.0:
return self.slider.minimum() / self.__factor
else:
return float(self.slider.minimum())
def maxValue(self):
if self.__factor != 0.0:
return self.slider.maximum() / self.__factor
else:
return float(self.slider.maximum())
def step(self):
if self.__factor != 0.0:
return self.slider.singleStep() / self.__factor
else:
return float(self.slider.singleStep())
def singleStep(self):
return self.step()
def test():
app = qt.QApplication([])
app.lastWindowClosed.connect(app.quit)
w = Object3DSlider()
w.show()
app.exec_()
if __name__ == "__main__":
test()
|