From 9926c004949e298cf69eab82b293e289355145a3 Mon Sep 17 00:00:00 2001 From: atse Date: Thu, 18 Jul 2024 13:38:46 +0800 Subject: [PATCH] ctrl_panel: Indicate active parameter of control Instead of hiding the inactive control parameter, underline and bold the active control parameter title, e.g. "Set Current" when control method is constant current, and "Setpoint" when it is temperature PID. --- pytec/pytec/gui/view/ctrl_panel.py | 55 ++++++++++------------------ pytec/pytec/gui/view/param_tree.json | 3 +- pytec/tec_qt.py | 4 +- 3 files changed, 23 insertions(+), 39 deletions(-) diff --git a/pytec/pytec/gui/view/ctrl_panel.py b/pytec/pytec/gui/view/ctrl_panel.py index c42330a..211bfef 100644 --- a/pytec/pytec/gui/view/ctrl_panel.py +++ b/pytec/pytec/gui/view/ctrl_panel.py @@ -7,42 +7,6 @@ from pyqtgraph.parametertree import ( import pytec.gui.view.lockable_unit -class MutexParameter(pTypes.ListParameter): - """ - Mutually exclusive parameter where only one of its children is visible at a time, list selectable. - - The ordering of the list items determines which children will be visible. - """ - - def __init__(self, **opts): - super().__init__(**opts) - - self.sigValueChanged.connect(self.show_chosen_child) - self.sigValueChanged.emit(self, self.opts["value"]) - - def _get_param_from_value(self, value): - if isinstance(self.opts["limits"], dict): - values_list = list(self.opts["limits"].values()) - else: - values_list = self.opts["limits"] - - return self.children()[values_list.index(value)] - - @pyqtSlot(object, object) - def show_chosen_child(self, value): - for param in self.children(): - param.hide() - - child_to_show = self._get_param_from_value(value.value()) - child_to_show.show() - - if child_to_show.opts.get("triggerOnShow", None): - child_to_show.sigValueChanged.emit(child_to_show, child_to_show.value()) - - -registerParameterType("mutex", MutexParameter) - - def set_tree_label_tips(tree): for item in tree.listAllItems(): p = item.param @@ -89,6 +53,25 @@ class CtrlPanel(QObject): for handle in sigActivated_handles[ch]: param.child(*handle[0]).sigActivated.connect(handle[1]) + def _indicate_usage(param, control_method="constant_current"): + for item in param.child("i_set").items: + is_constant_current = control_method == "constant_current" + font = item.font(0) + font.setUnderline(is_constant_current) + font.setBold(is_constant_current) + item.setFont(0, font) + for item in param.child("target").items: + is_temperature_pid = control_method == "temperature_pid" + font = item.font(0) + font.setUnderline(is_temperature_pid) + font.setBold(is_temperature_pid) + item.setFont(0, font) + + param.child("output", "control_method").sigValueChanged.connect( + _indicate_usage + ) + _indicate_usage(param.child("output", "control_method")) + def _setValue(self, value, blockSignal=None): """ Implement 'lock' mechanism for Parameter Type diff --git a/pytec/pytec/gui/view/param_tree.json b/pytec/pytec/gui/view/param_tree.json index 3a85d83..8e4ab28 100644 --- a/pytec/pytec/gui/view/param_tree.json +++ b/pytec/pytec/gui/view/param_tree.json @@ -29,7 +29,7 @@ { "name": "control_method", "title": "Control Method", - "type": "mutex", + "type": "list", "limits": { "Constant Current": "constant_current", "Temperature PID": "temperature_pid" @@ -50,7 +50,6 @@ -2, 2 ], - "triggerOnShow": true, "decimals": 6, "pinSiPrefix": "m", "suffix": "A", diff --git a/pytec/tec_qt.py b/pytec/tec_qt.py index d197ac5..35e7828 100644 --- a/pytec/tec_qt.py +++ b/pytec/tec_qt.py @@ -277,7 +277,9 @@ class MainWindow(QtWidgets.QMainWindow): thermostat_param["field"] = "off" new_value = "" case "control_method", "constant_current": - return + thermostat_param = thermostat_param.copy() + thermostat_param["field"] = "i_set" + new_value = inner_param.child("i_set").value() case "control_method", "temperature_pid": new_value = ""