temperature: use long-press gesture for the popup, allow right-click
allow clicking the name to switch device when showing numpad deprecates timeout remove select/deselect from popup, it's redundant and conflicts with the numpad reformat
This commit is contained in:
parent
4d72330761
commit
7d97f003c4
@ -7,6 +7,7 @@ from contextlib import suppress
|
|||||||
from ks_includes.screen_panel import ScreenPanel
|
from ks_includes.screen_panel import ScreenPanel
|
||||||
from ks_includes.widgets.heatergraph import HeaterGraph
|
from ks_includes.widgets.heatergraph import HeaterGraph
|
||||||
from ks_includes.widgets.keypad import Keypad
|
from ks_includes.widgets.keypad import Keypad
|
||||||
|
from ks_includes.KlippyGtk import find_widget
|
||||||
|
|
||||||
|
|
||||||
class Panel(ScreenPanel):
|
class Panel(ScreenPanel):
|
||||||
@ -15,8 +16,11 @@ class Panel(ScreenPanel):
|
|||||||
|
|
||||||
def __init__(self, screen, title, extra=None):
|
def __init__(self, screen, title, extra=None):
|
||||||
super().__init__(screen, title)
|
super().__init__(screen, title)
|
||||||
self.popover_timeout = None
|
|
||||||
self.left_panel = None
|
self.left_panel = None
|
||||||
|
self.devices = {}
|
||||||
|
self.popover = Gtk.Popover(position=Gtk.PositionType.BOTTOM)
|
||||||
|
self.popover_buttons = {}
|
||||||
|
self.long_press = {}
|
||||||
self.popover_device = None
|
self.popover_device = None
|
||||||
self.h = self.f = 0
|
self.h = self.f = 0
|
||||||
self.tempdeltas = ["1", "5", "10", "25"]
|
self.tempdeltas = ["1", "5", "10", "25"]
|
||||||
@ -54,8 +58,12 @@ class Panel(ScreenPanel):
|
|||||||
self.content.add(self.grid)
|
self.content.add(self.grid)
|
||||||
|
|
||||||
def create_right_panel(self):
|
def create_right_panel(self):
|
||||||
cooldown = self._gtk.Button('cool-down', _('Cooldown'), "color4", self.bts, Gtk.PositionType.LEFT, 1)
|
cooldown = self._gtk.Button(
|
||||||
adjust = self._gtk.Button('fine-tune', None, "color3", self.bts * 1.4, Gtk.PositionType.LEFT, 1)
|
"cool-down", _("Cooldown"), "color4", self.bts, Gtk.PositionType.LEFT, 1
|
||||||
|
)
|
||||||
|
adjust = self._gtk.Button(
|
||||||
|
"fine-tune", None, "color3", self.bts * 1.4, Gtk.PositionType.LEFT, 1
|
||||||
|
)
|
||||||
cooldown.connect("clicked", self.set_temperature, "cooldown")
|
cooldown.connect("clicked", self.set_temperature, "cooldown")
|
||||||
adjust.connect("clicked", self.switch_preheat_adjust)
|
adjust.connect("clicked", self.switch_preheat_adjust)
|
||||||
|
|
||||||
@ -79,13 +87,19 @@ class Panel(ScreenPanel):
|
|||||||
self.grid.show_all()
|
self.grid.show_all()
|
||||||
|
|
||||||
def preheat(self):
|
def preheat(self):
|
||||||
self.labels["preheat_grid"] = Gtk.Grid(row_homogeneous=True, column_homogeneous=True)
|
self.labels["preheat_grid"] = Gtk.Grid(
|
||||||
|
row_homogeneous=True, column_homogeneous=True
|
||||||
|
)
|
||||||
i = 0
|
i = 0
|
||||||
for option in self.preheat_options:
|
for option in self.preheat_options:
|
||||||
if option != "cooldown":
|
if option != "cooldown":
|
||||||
self.labels[option] = self._gtk.Button(label=option, style=f"color{(i % 4) + 1}")
|
self.labels[option] = self._gtk.Button(
|
||||||
|
label=option, style=f"color{(i % 4) + 1}"
|
||||||
|
)
|
||||||
self.labels[option].connect("clicked", self.set_temperature, option)
|
self.labels[option].connect("clicked", self.set_temperature, option)
|
||||||
self.labels['preheat_grid'].attach(self.labels[option], (i % 2), int(i / 2), 1, 1)
|
self.labels["preheat_grid"].attach(
|
||||||
|
self.labels[option], (i % 2), int(i / 2), 1, 1
|
||||||
|
)
|
||||||
i += 1
|
i += 1
|
||||||
scroll = self._gtk.ScrolledWindow()
|
scroll = self._gtk.ScrolledWindow()
|
||||||
scroll.add(self.labels["preheat_grid"])
|
scroll.add(self.labels["preheat_grid"])
|
||||||
@ -94,19 +108,23 @@ class Panel(ScreenPanel):
|
|||||||
def delta_adjust(self):
|
def delta_adjust(self):
|
||||||
deltagrid = Gtk.Grid(row_homogeneous=True, column_homogeneous=True)
|
deltagrid = Gtk.Grid(row_homogeneous=True, column_homogeneous=True)
|
||||||
self.labels["increase"] = self._gtk.Button("increase", None, "color1")
|
self.labels["increase"] = self._gtk.Button("increase", None, "color1")
|
||||||
self.labels["increase"].connect("clicked", self.change_target_temp_incremental, "+")
|
self.labels["increase"].connect(
|
||||||
|
"clicked", self.change_target_temp_incremental, "+"
|
||||||
|
)
|
||||||
self.labels["decrease"] = self._gtk.Button("decrease", None, "color3")
|
self.labels["decrease"] = self._gtk.Button("decrease", None, "color3")
|
||||||
self.labels["decrease"].connect("clicked", self.change_target_temp_incremental, "-")
|
self.labels["decrease"].connect(
|
||||||
|
"clicked", self.change_target_temp_incremental, "-"
|
||||||
|
)
|
||||||
|
|
||||||
tempgrid = Gtk.Grid()
|
tempgrid = Gtk.Grid()
|
||||||
for j, i in enumerate(self.tempdeltas):
|
for j, i in enumerate(self.tempdeltas):
|
||||||
self.labels[f'deg{i}'] = self._gtk.Button(label=i)
|
self.labels[f"deg{i}"] = self._gtk.Button(label=i)
|
||||||
self.labels[f'deg{i}'].connect("clicked", self.change_temp_delta, i)
|
self.labels[f"deg{i}"].connect("clicked", self.change_temp_delta, i)
|
||||||
ctx = self.labels[f'deg{i}'].get_style_context()
|
ctx = self.labels[f"deg{i}"].get_style_context()
|
||||||
ctx.add_class("horizontal_togglebuttons")
|
ctx.add_class("horizontal_togglebuttons")
|
||||||
if i == self.tempdelta:
|
if i == self.tempdelta:
|
||||||
ctx.add_class("horizontal_togglebuttons_active")
|
ctx.add_class("horizontal_togglebuttons_active")
|
||||||
tempgrid.attach(self.labels[f'deg{i}'], j, 0, 1, 1)
|
tempgrid.attach(self.labels[f"deg{i}"], j, 0, 1, 1)
|
||||||
|
|
||||||
vbox = Gtk.Box(orientation=Gtk.Orientation.VERTICAL)
|
vbox = Gtk.Box(orientation=Gtk.Orientation.VERTICAL)
|
||||||
vbox.pack_start(Gtk.Label(_("Temperature") + " (°C)"), False, False, 8)
|
vbox.pack_start(Gtk.Label(_("Temperature") + " (°C)"), False, False, 8)
|
||||||
@ -120,8 +138,12 @@ class Panel(ScreenPanel):
|
|||||||
|
|
||||||
def change_temp_delta(self, widget, tempdelta):
|
def change_temp_delta(self, widget, tempdelta):
|
||||||
logging.info(f"### tempdelta {tempdelta}")
|
logging.info(f"### tempdelta {tempdelta}")
|
||||||
self.labels[f"deg{self.tempdelta}"].get_style_context().remove_class("horizontal_togglebuttons_active")
|
self.labels[f"deg{self.tempdelta}"].get_style_context().remove_class(
|
||||||
self.labels[f"deg{tempdelta}"].get_style_context().add_class("horizontal_togglebuttons_active")
|
"horizontal_togglebuttons_active"
|
||||||
|
)
|
||||||
|
self.labels[f"deg{tempdelta}"].get_style_context().add_class(
|
||||||
|
"horizontal_togglebuttons_active"
|
||||||
|
)
|
||||||
self.tempdelta = tempdelta
|
self.tempdelta = tempdelta
|
||||||
|
|
||||||
def change_target_temp_incremental(self, widget, direction):
|
def change_target_temp_incremental(self, widget, direction):
|
||||||
@ -134,19 +156,25 @@ class Panel(ScreenPanel):
|
|||||||
name = heater.split()[1] if len(heater.split()) > 1 else heater
|
name = heater.split()[1] if len(heater.split()) > 1 else heater
|
||||||
if direction == "+":
|
if direction == "+":
|
||||||
target += int(self.tempdelta)
|
target += int(self.tempdelta)
|
||||||
max_temp = int(float(self._printer.get_config_section(heater)['max_temp']))
|
max_temp = int(
|
||||||
|
float(self._printer.get_config_section(heater)["max_temp"])
|
||||||
|
)
|
||||||
if target > max_temp:
|
if target > max_temp:
|
||||||
target = max_temp
|
target = max_temp
|
||||||
self._screen.show_popup_message(_("Can't set above the maximum:") + f' {target}')
|
self._screen.show_popup_message(
|
||||||
|
_("Can't set above the maximum:") + f" {target}"
|
||||||
|
)
|
||||||
|
|
||||||
else:
|
else:
|
||||||
target -= int(self.tempdelta)
|
target -= int(self.tempdelta)
|
||||||
target = max(target, 0)
|
target = max(target, 0)
|
||||||
if heater.startswith('extruder'):
|
if heater.startswith("extruder"):
|
||||||
self._screen._ws.klippy.set_tool_temp(self._printer.get_tool_number(heater), target)
|
self._screen._ws.klippy.set_tool_temp(
|
||||||
elif heater.startswith('heater_bed'):
|
self._printer.get_tool_number(heater), target
|
||||||
|
)
|
||||||
|
elif heater.startswith("heater_bed"):
|
||||||
self._screen._ws.klippy.set_bed_temp(target)
|
self._screen._ws.klippy.set_bed_temp(target)
|
||||||
elif heater.startswith('heater_generic '):
|
elif heater.startswith("heater_generic "):
|
||||||
self._screen._ws.klippy.set_heater_temp(name, target)
|
self._screen._ws.klippy.set_heater_temp(name, target)
|
||||||
elif heater.startswith("temperature_fan "):
|
elif heater.startswith("temperature_fan "):
|
||||||
self._screen._ws.klippy.set_temp_fan_temp(name, target)
|
self._screen._ws.klippy.set_temp_fan_temp(name, target)
|
||||||
@ -158,25 +186,30 @@ class Panel(ScreenPanel):
|
|||||||
def update_graph_visibility(self):
|
def update_graph_visibility(self):
|
||||||
count = 0
|
count = 0
|
||||||
for device in self.devices:
|
for device in self.devices:
|
||||||
visible = self._config.get_config().getboolean(f"graph {self._screen.connected_printer}",
|
visible = self._config.get_config().getboolean(
|
||||||
device, fallback=True)
|
f"graph {self._screen.connected_printer}", device, fallback=True
|
||||||
self.devices[device]['visible'] = visible
|
)
|
||||||
self.labels['da'].set_showing(device, visible)
|
self.devices[device]["visible"] = visible
|
||||||
|
self.labels["da"].set_showing(device, visible)
|
||||||
if visible:
|
if visible:
|
||||||
count += 1
|
count += 1
|
||||||
self.devices[device]['name'].get_style_context().add_class("graph_label")
|
self.devices[device]["name_button"].get_style_context().add_class(
|
||||||
|
"graph_label"
|
||||||
|
)
|
||||||
else:
|
else:
|
||||||
self.devices[device]['name'].get_style_context().remove_class("graph_label")
|
self.devices[device]["name_button"].get_style_context().remove_class(
|
||||||
|
"graph_label"
|
||||||
|
)
|
||||||
if count > 0:
|
if count > 0:
|
||||||
if self.labels['da'] not in self.left_panel:
|
if self.labels["da"] not in self.left_panel:
|
||||||
self.left_panel.add(self.labels['da'])
|
self.left_panel.add(self.labels["da"])
|
||||||
self.labels['da'].queue_draw()
|
self.labels["da"].queue_draw()
|
||||||
self.labels['da'].show()
|
self.labels["da"].show()
|
||||||
if self.graph_update is None:
|
if self.graph_update is None:
|
||||||
# This has a high impact on load
|
# This has a high impact on load
|
||||||
self.graph_update = GLib.timeout_add_seconds(5, self.update_graph)
|
self.graph_update = GLib.timeout_add_seconds(5, self.update_graph)
|
||||||
elif self.labels['da'] in self.left_panel:
|
elif self.labels["da"] in self.left_panel:
|
||||||
self.left_panel.remove(self.labels['da'])
|
self.left_panel.remove(self.labels["da"])
|
||||||
if self.graph_update is not None:
|
if self.graph_update is not None:
|
||||||
GLib.source_remove(self.graph_update)
|
GLib.source_remove(self.graph_update)
|
||||||
self.graph_update = None
|
self.graph_update = None
|
||||||
@ -194,16 +227,22 @@ class Panel(ScreenPanel):
|
|||||||
self.hide_numpad()
|
self.hide_numpad()
|
||||||
|
|
||||||
def select_heater(self, widget, device):
|
def select_heater(self, widget, device):
|
||||||
if self.active_heater is None and device in self.devices and self.devices[device]["can_target"]:
|
if (
|
||||||
|
self.active_heater is None
|
||||||
|
and device in self.devices
|
||||||
|
and self._printer.device_has_target(device)
|
||||||
|
):
|
||||||
if device in self.active_heaters:
|
if device in self.active_heaters:
|
||||||
self.active_heaters.pop(self.active_heaters.index(device))
|
self.active_heaters.pop(self.active_heaters.index(device))
|
||||||
self.devices[device]['name'].get_style_context().remove_class("button_active")
|
self.devices[device]["name_button"].get_style_context().remove_class(
|
||||||
self.devices[device]['select'].set_label(_("Select"))
|
"button_active"
|
||||||
|
)
|
||||||
logging.info(f"Deselecting {device}")
|
logging.info(f"Deselecting {device}")
|
||||||
return
|
return
|
||||||
self.active_heaters.append(device)
|
self.active_heaters.append(device)
|
||||||
self.devices[device]['name'].get_style_context().add_class("button_active")
|
self.devices[device]["name_button"].get_style_context().add_class(
|
||||||
self.devices[device]['select'].set_label(_("Deselect"))
|
"button_active"
|
||||||
|
)
|
||||||
logging.info(f"Selecting {device}")
|
logging.info(f"Selecting {device}")
|
||||||
return
|
return
|
||||||
|
|
||||||
@ -213,7 +252,7 @@ class Panel(ScreenPanel):
|
|||||||
else:
|
else:
|
||||||
for heater in self.active_heaters:
|
for heater in self.active_heaters:
|
||||||
target = None
|
target = None
|
||||||
max_temp = float(self._printer.get_config_section(heater)['max_temp'])
|
max_temp = float(self._printer.get_config_section(heater)["max_temp"])
|
||||||
name = heater.split()[1] if len(heater.split()) > 1 else heater
|
name = heater.split()[1] if len(heater.split()) > 1 else heater
|
||||||
with suppress(KeyError):
|
with suppress(KeyError):
|
||||||
for i in self.preheat_options[setting]:
|
for i in self.preheat_options[setting]:
|
||||||
@ -225,24 +264,30 @@ class Panel(ScreenPanel):
|
|||||||
elif i == heater:
|
elif i == heater:
|
||||||
target = self.preheat_options[setting][heater]
|
target = self.preheat_options[setting][heater]
|
||||||
logging.info(f"heater match {heater}")
|
logging.info(f"heater match {heater}")
|
||||||
if target is None and setting == "cooldown" and not heater.startswith('temperature_fan '):
|
if (
|
||||||
|
target is None
|
||||||
|
and setting == "cooldown"
|
||||||
|
and not heater.startswith("temperature_fan ")
|
||||||
|
):
|
||||||
target = 0
|
target = 0
|
||||||
if heater.startswith('extruder'):
|
if heater.startswith("extruder"):
|
||||||
if self.validate(heater, target, max_temp):
|
if self.validate(heater, target, max_temp):
|
||||||
self._screen._ws.klippy.set_tool_temp(self._printer.get_tool_number(heater), target)
|
self._screen._ws.klippy.set_tool_temp(
|
||||||
elif heater.startswith('heater_bed'):
|
self._printer.get_tool_number(heater), target
|
||||||
|
)
|
||||||
|
elif heater.startswith("heater_bed"):
|
||||||
if target is None:
|
if target is None:
|
||||||
with suppress(KeyError):
|
with suppress(KeyError):
|
||||||
target = self.preheat_options[setting]["bed"]
|
target = self.preheat_options[setting]["bed"]
|
||||||
if self.validate(heater, target, max_temp):
|
if self.validate(heater, target, max_temp):
|
||||||
self._screen._ws.klippy.set_bed_temp(target)
|
self._screen._ws.klippy.set_bed_temp(target)
|
||||||
elif heater.startswith('heater_generic '):
|
elif heater.startswith("heater_generic "):
|
||||||
if target is None:
|
if target is None:
|
||||||
with suppress(KeyError):
|
with suppress(KeyError):
|
||||||
target = self.preheat_options[setting]["heater_generic"]
|
target = self.preheat_options[setting]["heater_generic"]
|
||||||
if self.validate(heater, target, max_temp):
|
if self.validate(heater, target, max_temp):
|
||||||
self._screen._ws.klippy.set_heater_temp(name, target)
|
self._screen._ws.klippy.set_heater_temp(name, target)
|
||||||
elif heater.startswith('temperature_fan '):
|
elif heater.startswith("temperature_fan "):
|
||||||
if target is None:
|
if target is None:
|
||||||
with suppress(KeyError):
|
with suppress(KeyError):
|
||||||
target = self.preheat_options[setting]["temperature_fan"]
|
target = self.preheat_options[setting]["temperature_fan"]
|
||||||
@ -257,14 +302,16 @@ class Panel(ScreenPanel):
|
|||||||
if 0 <= target <= max_temp:
|
if 0 <= target <= max_temp:
|
||||||
return True
|
return True
|
||||||
elif target > max_temp:
|
elif target > max_temp:
|
||||||
self._screen.show_popup_message(_("Can't set above the maximum:") + f' {max_temp}')
|
self._screen.show_popup_message(
|
||||||
|
_("Can't set above the maximum:") + f" {max_temp}"
|
||||||
|
)
|
||||||
return False
|
return False
|
||||||
logging.debug(f"Invalid {heater} Target:{target}/{max_temp}")
|
logging.debug(f"Invalid {heater} Target:{target}/{max_temp}")
|
||||||
return False
|
return False
|
||||||
|
|
||||||
def preheat_gcode(self, widget, setting):
|
def preheat_gcode(self, widget, setting):
|
||||||
with suppress(KeyError):
|
with suppress(KeyError):
|
||||||
script = {"script": self.preheat_options[setting]['gcode']}
|
script = {"script": self.preheat_options[setting]["gcode"]}
|
||||||
self._screen._send_action(widget, "printer.gcode.script", script)
|
self._screen._send_action(widget, "printer.gcode.script", script)
|
||||||
return False
|
return False
|
||||||
|
|
||||||
@ -313,64 +360,72 @@ class Panel(ScreenPanel):
|
|||||||
|
|
||||||
rgb = self._gtk.get_temp_color(dev_type)
|
rgb = self._gtk.get_temp_color(dev_type)
|
||||||
|
|
||||||
name = self._gtk.Button(image, self.prettify(devname), None, self.bts, Gtk.PositionType.LEFT, 1)
|
name = self._gtk.Button(
|
||||||
name.set_alignment(0, .5)
|
image, self.prettify(devname), None, self.bts, Gtk.PositionType.LEFT, 1
|
||||||
|
)
|
||||||
|
name.set_alignment(0, 0.5)
|
||||||
name.get_style_context().add_class(class_name)
|
name.get_style_context().add_class(class_name)
|
||||||
visible = self._config.get_config().getboolean(f"graph {self._screen.connected_printer}", device, fallback=True)
|
visible = self._config.get_config().getboolean(
|
||||||
|
f"graph {self._screen.connected_printer}", device, fallback=True
|
||||||
|
)
|
||||||
if visible:
|
if visible:
|
||||||
name.get_style_context().add_class("graph_label")
|
name.get_style_context().add_class("graph_label")
|
||||||
|
|
||||||
can_target = self._printer.device_has_target(device)
|
self.labels["da"].add_object(device, "temperatures", rgb, False, False)
|
||||||
self.labels['da'].add_object(device, "temperatures", rgb, False, False)
|
temp = self._gtk.Button(label="", lines=1)
|
||||||
if can_target:
|
|
||||||
self.labels['da'].add_object(device, "targets", rgb, False, True)
|
if self._printer.device_has_target(device):
|
||||||
name.connect('button-press-event', self.name_pressed, device)
|
temp.connect("clicked", self.show_numpad, device)
|
||||||
name.connect('button-release-event', self.name_released, device)
|
self.labels["da"].add_object(device, "targets", rgb, False, True)
|
||||||
|
name.connect("button-press-event", self.name_pressed, device)
|
||||||
|
self.long_press[device] = Gtk.GestureLongPress.new(name)
|
||||||
|
self.long_press[device].connect(
|
||||||
|
"pressed", self.name_long_press, name, device
|
||||||
|
)
|
||||||
|
self.long_press[device].connect(
|
||||||
|
"cancelled", self.name_long_press_cancelled, name, device
|
||||||
|
)
|
||||||
else:
|
else:
|
||||||
name.connect("clicked", self.toggle_visibility, device)
|
name.connect("clicked", self.toggle_visibility, device)
|
||||||
if self._show_heater_power and self._printer.device_has_power(device):
|
if self._show_heater_power and self._printer.device_has_power(device):
|
||||||
self.labels['da'].add_object(device, "powers", rgb, True, False)
|
self.labels["da"].add_object(device, "powers", rgb, True, False)
|
||||||
self.labels['da'].set_showing(device, visible)
|
self.labels["da"].set_showing(device, visible)
|
||||||
|
|
||||||
temp = self._gtk.Button(label="", lines=1)
|
|
||||||
if can_target:
|
|
||||||
temp.connect("clicked", self.show_numpad, device)
|
|
||||||
|
|
||||||
self.devices[device] = {
|
self.devices[device] = {
|
||||||
"class": class_name,
|
"class": class_name,
|
||||||
"name": name,
|
"name_button": name,
|
||||||
"temp": temp,
|
"temp": temp,
|
||||||
"can_target": can_target,
|
"visible": visible,
|
||||||
"visible": visible
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if self.devices[device]["can_target"]:
|
|
||||||
self.devices[device]['select'] = self._gtk.Button(label=_("Select"))
|
|
||||||
self.devices[device]['select'].connect('clicked', self.select_heater, device)
|
|
||||||
|
|
||||||
devices = sorted(self.devices)
|
devices = sorted(self.devices)
|
||||||
pos = devices.index(device) + 1
|
pos = devices.index(device) + 1
|
||||||
|
|
||||||
self.labels['devices'].insert_row(pos)
|
self.labels["devices"].insert_row(pos)
|
||||||
self.labels['devices'].attach(name, 0, pos, 1, 1)
|
self.labels["devices"].attach(name, 0, pos, 1, 1)
|
||||||
self.labels['devices'].attach(temp, 1, pos, 1, 1)
|
self.labels["devices"].attach(temp, 1, pos, 1, 1)
|
||||||
self.labels['devices'].show_all()
|
self.labels["devices"].show_all()
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def name_pressed(self, widget, event, device):
|
def name_pressed(self, widget, event, device):
|
||||||
self.popover_timeout = GLib.timeout_add_seconds(1, self.popover_popup, widget, device)
|
self.popover_device = device
|
||||||
|
if event.button == 3:
|
||||||
|
self.popover_popup(widget, device)
|
||||||
|
|
||||||
def name_released(self, widget, event, device):
|
def name_long_press_cancelled(self, gesture_long_press, widget, device):
|
||||||
if self.popover_timeout is not None:
|
if self.active_heater:
|
||||||
GLib.source_remove(self.popover_timeout)
|
self.show_numpad(widget, device)
|
||||||
self.popover_timeout = None
|
else:
|
||||||
if not self.popover_device:
|
self.select_heater(widget, device)
|
||||||
self.select_heater(None, device)
|
|
||||||
|
def name_long_press(self, gesture_long_press, x, y, widget, device):
|
||||||
|
self.popover_device = device
|
||||||
|
self.popover_popup(widget, device)
|
||||||
|
|
||||||
def toggle_visibility(self, widget, device=None):
|
def toggle_visibility(self, widget, device=None):
|
||||||
if device is None:
|
if device is None:
|
||||||
device = self.popover_device
|
device = self.popover_device
|
||||||
self.devices[device]['visible'] ^= True
|
self.devices[device]["visible"] ^= True
|
||||||
logging.info(f"Graph show {self.devices[device]['visible']}: {device}")
|
logging.info(f"Graph show {self.devices[device]['visible']}: {device}")
|
||||||
|
|
||||||
section = f"graph {self._screen.connected_printer}"
|
section = f"graph {self._screen.connected_printer}"
|
||||||
@ -380,83 +435,101 @@ class Panel(ScreenPanel):
|
|||||||
self._config.save_user_config_options()
|
self._config.save_user_config_options()
|
||||||
|
|
||||||
self.update_graph_visibility()
|
self.update_graph_visibility()
|
||||||
if self.devices[device]['can_target']:
|
if self._printer.device_has_target(device):
|
||||||
self.popover_populate_menu()
|
self.popover_populate_menu()
|
||||||
self.labels['popover'].show_all()
|
self.popover.show_all()
|
||||||
|
|
||||||
def change_target_temp(self, temp):
|
def change_target_temp(self, temp):
|
||||||
name = self.active_heater.split()[1] if len(self.active_heater.split()) > 1 else self.active_heater
|
name = (
|
||||||
|
self.active_heater.split()[1]
|
||||||
|
if len(self.active_heater.split()) > 1
|
||||||
|
else self.active_heater
|
||||||
|
)
|
||||||
temp = self.verify_max_temp(temp)
|
temp = self.verify_max_temp(temp)
|
||||||
if temp is False:
|
if temp is False:
|
||||||
return
|
return
|
||||||
|
|
||||||
if self.active_heater.startswith('extruder'):
|
if self.active_heater.startswith("extruder"):
|
||||||
self._screen._ws.klippy.set_tool_temp(self._printer.get_tool_number(self.active_heater), temp)
|
self._screen._ws.klippy.set_tool_temp(
|
||||||
|
self._printer.get_tool_number(self.active_heater), temp
|
||||||
|
)
|
||||||
elif self.active_heater == "heater_bed":
|
elif self.active_heater == "heater_bed":
|
||||||
self._screen._ws.klippy.set_bed_temp(temp)
|
self._screen._ws.klippy.set_bed_temp(temp)
|
||||||
elif self.active_heater.startswith('heater_generic '):
|
elif self.active_heater.startswith("heater_generic "):
|
||||||
self._screen._ws.klippy.set_heater_temp(name, temp)
|
self._screen._ws.klippy.set_heater_temp(name, temp)
|
||||||
elif self.active_heater.startswith('temperature_fan '):
|
elif self.active_heater.startswith("temperature_fan "):
|
||||||
self._screen._ws.klippy.set_temp_fan_temp(name, temp)
|
self._screen._ws.klippy.set_temp_fan_temp(name, temp)
|
||||||
else:
|
else:
|
||||||
logging.info(f"Unknown heater: {self.active_heater}")
|
logging.info(f"Unknown heater: {self.active_heater}")
|
||||||
self._screen.show_popup_message(_("Unknown Heater") + " " + self.active_heater)
|
self._screen.show_popup_message(
|
||||||
|
_("Unknown Heater") + " " + self.active_heater
|
||||||
|
)
|
||||||
|
|
||||||
def verify_max_temp(self, temp):
|
def verify_max_temp(self, temp):
|
||||||
temp = int(temp)
|
temp = int(temp)
|
||||||
max_temp = int(float(self._printer.get_config_section(self.active_heater)['max_temp']))
|
max_temp = int(
|
||||||
|
float(self._printer.get_config_section(self.active_heater)["max_temp"])
|
||||||
|
)
|
||||||
logging.debug(f"{temp}/{max_temp}")
|
logging.debug(f"{temp}/{max_temp}")
|
||||||
if temp > max_temp:
|
if temp > max_temp:
|
||||||
self._screen.show_popup_message(_("Can't set above the maximum:") + f' {max_temp}')
|
self._screen.show_popup_message(
|
||||||
|
_("Can't set above the maximum:") + f" {max_temp}"
|
||||||
|
)
|
||||||
return False
|
return False
|
||||||
return max(temp, 0)
|
return max(temp, 0)
|
||||||
|
|
||||||
def pid_calibrate(self, temp):
|
def pid_calibrate(self, temp):
|
||||||
if self.verify_max_temp(temp):
|
if self.verify_max_temp(temp):
|
||||||
script = {"script": f"PID_CALIBRATE HEATER={self.active_heater} TARGET={temp}"}
|
script = {
|
||||||
|
"script": f"PID_CALIBRATE HEATER={self.active_heater} TARGET={temp}"
|
||||||
|
}
|
||||||
self._screen._confirm_send_action(
|
self._screen._confirm_send_action(
|
||||||
None,
|
None,
|
||||||
_("Initiate a PID calibration for:") + f" {self.active_heater} @ {temp} ºC"
|
_("Initiate a PID calibration for:")
|
||||||
+ "\n\n" + _("It may take more than 5 minutes depending on the heater power."),
|
+ f" {self.active_heater} @ {temp} ºC"
|
||||||
|
+ "\n\n"
|
||||||
|
+ _("It may take more than 5 minutes depending on the heater power."),
|
||||||
"printer.gcode.script",
|
"printer.gcode.script",
|
||||||
script
|
script,
|
||||||
)
|
)
|
||||||
|
|
||||||
def create_left_panel(self):
|
def create_left_panel(self):
|
||||||
|
|
||||||
self.labels['devices'] = Gtk.Grid(vexpand=False)
|
self.labels["devices"] = Gtk.Grid(vexpand=False)
|
||||||
self.labels['devices'].get_style_context().add_class('heater-grid')
|
self.labels["devices"].get_style_context().add_class("heater-grid")
|
||||||
|
|
||||||
name = Gtk.Label()
|
name = Gtk.Label()
|
||||||
temp = Gtk.Label(_("Temp (°C)"))
|
temp = Gtk.Label(_("Temp (°C)"))
|
||||||
temp.get_style_context().add_class("heater-grid-temp")
|
temp.get_style_context().add_class("heater-grid-temp")
|
||||||
|
|
||||||
self.labels['devices'].attach(name, 0, 0, 1, 1)
|
self.labels["devices"].attach(name, 0, 0, 1, 1)
|
||||||
self.labels['devices'].attach(temp, 1, 0, 1, 1)
|
self.labels["devices"].attach(temp, 1, 0, 1, 1)
|
||||||
|
|
||||||
self.labels['da'] = HeaterGraph(self._screen, self._printer, self._gtk.font_size)
|
self.labels["da"] = HeaterGraph(
|
||||||
|
self._screen, self._printer, self._gtk.font_size
|
||||||
|
)
|
||||||
|
|
||||||
scroll = self._gtk.ScrolledWindow(steppers=False)
|
scroll = self._gtk.ScrolledWindow(steppers=False)
|
||||||
scroll.set_policy(Gtk.PolicyType.NEVER, Gtk.PolicyType.AUTOMATIC)
|
scroll.set_policy(Gtk.PolicyType.NEVER, Gtk.PolicyType.AUTOMATIC)
|
||||||
scroll.get_style_context().add_class('heater-list')
|
scroll.get_style_context().add_class("heater-list")
|
||||||
scroll.add(self.labels['devices'])
|
scroll.add(self.labels["devices"])
|
||||||
|
|
||||||
self.left_panel = Gtk.Box(orientation=Gtk.Orientation.VERTICAL)
|
self.left_panel = Gtk.Box(orientation=Gtk.Orientation.VERTICAL)
|
||||||
self.left_panel.add(scroll)
|
self.left_panel.add(scroll)
|
||||||
|
|
||||||
self.labels['graph_settemp'] = self._gtk.Button(label=_("Set Temp"))
|
self.popover_buttons = {
|
||||||
self.labels['graph_settemp'].connect("clicked", self.show_numpad)
|
"set_temp": self._gtk.Button(label=_("Set Temp")),
|
||||||
self.labels['graph_hide'] = self._gtk.Button(label=_("Hide"))
|
"graph_show": self._gtk.Button(label=_("Show")),
|
||||||
self.labels['graph_hide'].connect("clicked", self.toggle_visibility)
|
}
|
||||||
self.labels['graph_show'] = self._gtk.Button(label=_("Show"))
|
self.popover_buttons["set_temp"].connect("clicked", self.show_numpad)
|
||||||
self.labels['graph_show'].connect("clicked", self.toggle_visibility)
|
self.popover_buttons["set_temp"].set_no_show_all(True)
|
||||||
|
self.popover_buttons["graph_show"].connect("clicked", self.toggle_visibility)
|
||||||
|
|
||||||
popover = Gtk.Popover()
|
pobox = Gtk.Box(orientation=Gtk.Orientation.VERTICAL)
|
||||||
self.labels['popover_vbox'] = Gtk.Box(orientation=Gtk.Orientation.VERTICAL)
|
pobox.pack_start(self.popover_buttons["graph_show"], True, True, 5)
|
||||||
popover.add(self.labels['popover_vbox'])
|
pobox.pack_start(self.popover_buttons["set_temp"], True, True, 5)
|
||||||
popover.set_position(Gtk.PositionType.BOTTOM)
|
self.popover.add(pobox)
|
||||||
popover.connect('closed', self.popover_closed)
|
self.popover.connect("closed", self.popover_closed)
|
||||||
self.labels['popover'] = popover
|
|
||||||
|
|
||||||
for d in self._printer.get_temp_devices():
|
for d in self._printer.get_temp_devices():
|
||||||
self.add_device(d)
|
self.add_device(d)
|
||||||
@ -464,11 +537,15 @@ class Panel(ScreenPanel):
|
|||||||
return self.left_panel
|
return self.left_panel
|
||||||
|
|
||||||
def hide_numpad(self, widget=None):
|
def hide_numpad(self, widget=None):
|
||||||
self.devices[self.active_heater]['name'].get_style_context().remove_class("button_active")
|
self.devices[self.active_heater][
|
||||||
|
"name_button"
|
||||||
|
].get_style_context().remove_class("button_active")
|
||||||
self.active_heater = None
|
self.active_heater = None
|
||||||
|
|
||||||
for d in self.active_heaters:
|
for d in self.active_heaters:
|
||||||
self.devices[d]['name'].get_style_context().add_class("button_active")
|
self.devices[d]["name_button"].get_style_context().add_class(
|
||||||
|
"button_active"
|
||||||
|
)
|
||||||
|
|
||||||
if self._screen.vertical_mode:
|
if self._screen.vertical_mode:
|
||||||
self.grid.remove_row(1)
|
self.grid.remove_row(1)
|
||||||
@ -483,23 +560,19 @@ class Panel(ScreenPanel):
|
|||||||
|
|
||||||
def popover_popup(self, widget, device):
|
def popover_popup(self, widget, device):
|
||||||
self.popover_device = device
|
self.popover_device = device
|
||||||
po = self.labels['popover']
|
self.popover.set_relative_to(widget)
|
||||||
po.set_relative_to(widget)
|
|
||||||
self.popover_populate_menu()
|
self.popover_populate_menu()
|
||||||
po.show_all()
|
self.popover.show_all()
|
||||||
|
|
||||||
def popover_populate_menu(self):
|
def popover_populate_menu(self):
|
||||||
pobox = self.labels['popover_vbox']
|
if self.labels["da"].is_showing(self.popover_device):
|
||||||
for child in pobox.get_children():
|
self.popover_buttons["graph_show"].set_label(_("Hide"))
|
||||||
pobox.remove(child)
|
|
||||||
|
|
||||||
if self.labels['da'].is_showing(self.popover_device):
|
|
||||||
pobox.pack_start(self.labels['graph_hide'], True, True, 5)
|
|
||||||
else:
|
else:
|
||||||
pobox.pack_start(self.labels['graph_show'], True, True, 5)
|
self.popover_buttons["graph_show"].set_label(_("Show"))
|
||||||
if self.devices[self.popover_device]["can_target"]:
|
if self._printer.device_has_target(self.popover_device):
|
||||||
pobox.pack_start(self.labels['graph_settemp'], True, True, 5)
|
self.popover_buttons["set_temp"].show()
|
||||||
pobox.pack_end(self.devices[self.popover_device]['select'], True, True, 5)
|
else:
|
||||||
|
self.popover_buttons["set_temp"].hide()
|
||||||
|
|
||||||
def process_update(self, action, data):
|
def process_update(self, action, data):
|
||||||
if action != "notify_status_update":
|
if action != "notify_status_update":
|
||||||
@ -515,14 +588,25 @@ class Panel(ScreenPanel):
|
|||||||
|
|
||||||
def show_numpad(self, widget, device=None):
|
def show_numpad(self, widget, device=None):
|
||||||
for d in self.active_heaters:
|
for d in self.active_heaters:
|
||||||
self.devices[d]['name'].get_style_context().remove_class("button_active")
|
self.devices[d]["name_button"].get_style_context().remove_class(
|
||||||
|
"button_active"
|
||||||
|
)
|
||||||
self.active_heater = self.popover_device if device is None else device
|
self.active_heater = self.popover_device if device is None else device
|
||||||
self.devices[self.active_heater]['name'].get_style_context().add_class("button_active")
|
self.devices[self.active_heater]["name_button"].get_style_context().add_class(
|
||||||
|
"button_active"
|
||||||
|
)
|
||||||
|
|
||||||
if "keypad" not in self.labels:
|
if "keypad" not in self.labels:
|
||||||
self.labels["keypad"] = Keypad(self._screen, self.change_target_temp, self.pid_calibrate, self.hide_numpad)
|
self.labels["keypad"] = Keypad(
|
||||||
can_pid = self._printer.state not in ("printing", "paused") \
|
self._screen,
|
||||||
and self._screen.printer.config[self.active_heater]['control'] == 'pid'
|
self.change_target_temp,
|
||||||
|
self.pid_calibrate,
|
||||||
|
self.hide_numpad,
|
||||||
|
)
|
||||||
|
can_pid = (
|
||||||
|
self._printer.state not in ("printing", "paused")
|
||||||
|
and self._screen.printer.config[self.active_heater]["control"] == "pid"
|
||||||
|
)
|
||||||
self.labels["keypad"].show_pid(can_pid)
|
self.labels["keypad"].show_pid(can_pid)
|
||||||
self.labels["keypad"].clear()
|
self.labels["keypad"].clear()
|
||||||
|
|
||||||
@ -534,8 +618,8 @@ class Panel(ScreenPanel):
|
|||||||
self.grid.attach(self.labels["keypad"], 1, 0, 1, 1)
|
self.grid.attach(self.labels["keypad"], 1, 0, 1, 1)
|
||||||
self.grid.show_all()
|
self.grid.show_all()
|
||||||
|
|
||||||
self.labels['popover'].popdown()
|
self.popover.popdown()
|
||||||
|
|
||||||
def update_graph(self):
|
def update_graph(self):
|
||||||
self.labels['da'].queue_draw()
|
self.labels["da"].queue_draw()
|
||||||
return True
|
return True
|
||||||
|
Loading…
x
Reference in New Issue
Block a user