fine_tune: split speed and flow selectors close #935

This commit is contained in:
alfrix
2023-07-22 12:24:06 -03:00
committed by Alfredo Monclus
parent 7ba9e49374
commit 87ad2a70ba

View File

@@ -14,11 +14,14 @@ def create_panel(*args):
class FineTunePanel(ScreenPanel): class FineTunePanel(ScreenPanel):
bs_deltas = ["0.01", "0.05"] z_deltas = ["0.01", "0.05"]
bs_delta = bs_deltas[-1] z_delta = z_deltas[-1]
percent_deltas = ['1', '5', '10', '25'] speed_deltas = ['5', '25']
percent_delta = percent_deltas[-2] s_delta = speed_deltas[-1]
extrude_deltas = ['1', '2']
e_delta = extrude_deltas[-1]
speed = extrusion = 100 speed = extrusion = 100
z_offset = 0.0
def __init__(self, screen, title): def __init__(self, screen, title):
super().__init__(screen, title) super().__init__(screen, title)
@@ -27,40 +30,53 @@ class FineTunePanel(ScreenPanel):
if re.match(r'^[0-9,\.\s]+$', bs): if re.match(r'^[0-9,\.\s]+$', bs):
bs = [str(i.strip()) for i in bs.split(',')] bs = [str(i.strip()) for i in bs.split(',')]
if 1 < len(bs) < 3: if 1 < len(bs) < 3:
self.bs_deltas = bs self.z_deltas = bs
self.bs_delta = self.bs_deltas[-1] self.z_delta = self.z_deltas[-1]
# babystepping grid zgrid = Gtk.Grid()
bsgrid = Gtk.Grid() for j, i in enumerate(self.z_deltas):
for j, i in enumerate(self.bs_deltas): self.labels[f"zdelta{i}"] = self._gtk.Button(label=i)
self.labels[f"bdelta{i}"] = self._gtk.Button(label=i) self.labels[f"zdelta{i}"].connect("clicked", self.change_percent_delta, "z_offset", float(i))
self.labels[f"bdelta{i}"].connect("clicked", self.change_bs_delta, float(i)) ctx = self.labels[f"zdelta{i}"].get_style_context()
ctx = self.labels[f"bdelta{i}"].get_style_context()
if j == 0: if j == 0:
ctx.add_class("distbutton_top") ctx.add_class("distbutton_top")
elif j == len(self.bs_deltas) - 1: elif j == len(self.z_deltas) - 1:
ctx.add_class("distbutton_bottom") ctx.add_class("distbutton_bottom")
else: else:
ctx.add_class("distbutton") ctx.add_class("distbutton")
if i == self.bs_delta: if i == self.z_delta:
ctx.add_class("distbutton_active") ctx.add_class("distbutton_active")
bsgrid.attach(self.labels[f"bdelta{i}"], j, 0, 1, 1) zgrid.attach(self.labels[f"zdelta{i}"], j, 0, 1, 1)
# Grid for percentage
deltgrid = Gtk.Grid() spdgrid = Gtk.Grid()
for j, i in enumerate(self.percent_deltas): for j, i in enumerate(self.speed_deltas):
self.labels[f"pdelta{i}"] = self._gtk.Button(label=f"{i}%") self.labels[f"sdelta{i}"] = self._gtk.Button(label=f"{i}%")
self.labels[f"pdelta{i}"].connect("clicked", self.change_percent_delta, int(i)) self.labels[f"sdelta{i}"].connect("clicked", self.change_percent_delta, "speed", int(i))
ctx = self.labels[f"pdelta{i}"].get_style_context() ctx = self.labels[f"sdelta{i}"].get_style_context()
if j == 0: if j == 0:
ctx.add_class("distbutton_top") ctx.add_class("distbutton_top")
elif j == len(self.percent_deltas) - 1: elif j == len(self.speed_deltas) - 1:
ctx.add_class("distbutton_bottom") ctx.add_class("distbutton_bottom")
else: else:
ctx.add_class("distbutton") ctx.add_class("distbutton")
if i == self.percent_delta: if i == self.s_delta:
ctx.add_class("distbutton_active") ctx.add_class("distbutton_active")
deltgrid.attach(self.labels[f"pdelta{i}"], j, 0, 1, 1) spdgrid.attach(self.labels[f"sdelta{i}"], j, 0, 1, 1)
extgrid = Gtk.Grid()
for j, i in enumerate(self.extrude_deltas):
self.labels[f"edelta{i}"] = self._gtk.Button(label=f"{i}%")
self.labels[f"edelta{i}"].connect("clicked", self.change_percent_delta, "extrude", int(i))
ctx = self.labels[f"edelta{i}"].get_style_context()
if j == 0:
ctx.add_class("distbutton_top")
elif j == len(self.extrude_deltas) - 1:
ctx.add_class("distbutton_bottom")
else:
ctx.add_class("distbutton")
if i == self.e_delta:
ctx.add_class("distbutton_active")
extgrid.attach(self.labels[f"edelta{i}"], j, 0, 1, 1)
grid = self._gtk.HomogeneousGrid() grid = self._gtk.HomogeneousGrid()
grid.set_row_homogeneous(False) grid.set_row_homogeneous(False)
@@ -81,26 +97,28 @@ class FineTunePanel(ScreenPanel):
grid.attach(self.labels['z+'], 0, 0, 1, 1) grid.attach(self.labels['z+'], 0, 0, 1, 1)
grid.attach(self.labels['z-'], 1, 0, 1, 1) grid.attach(self.labels['z-'], 1, 0, 1, 1)
grid.attach(self.labels['zoffset'], 2, 0, 1, 1) grid.attach(self.labels['zoffset'], 2, 0, 1, 1)
grid.attach(bsgrid, 0, 1, 3, 1) grid.attach(zgrid, 0, 1, 3, 1)
grid.attach(self.labels['speed-'], 0, 2, 1, 1) grid.attach(self.labels['speed-'], 0, 2, 1, 1)
grid.attach(self.labels['speed+'], 1, 2, 1, 1) grid.attach(self.labels['speed+'], 1, 2, 1, 1)
grid.attach(self.labels['speedfactor'], 2, 2, 1, 1) grid.attach(self.labels['speedfactor'], 2, 2, 1, 1)
grid.attach(self.labels['extrude-'], 0, 3, 1, 1) grid.attach(spdgrid, 0, 3, 3, 1)
grid.attach(self.labels['extrude+'], 1, 3, 1, 1) grid.attach(self.labels['extrude-'], 0, 4, 1, 1)
grid.attach(self.labels['extrudefactor'], 2, 3, 1, 1) grid.attach(self.labels['extrude+'], 1, 4, 1, 1)
grid.attach(deltgrid, 0, 4, 3, 1) grid.attach(self.labels['extrudefactor'], 2, 4, 1, 1)
grid.attach(extgrid, 0, 5, 3, 1)
else: else:
grid.attach(self.labels['zoffset'], 0, 0, 1, 1) grid.attach(self.labels['zoffset'], 0, 0, 1, 1)
grid.attach(self.labels['z+'], 0, 1, 1, 1) grid.attach(self.labels['z+'], 0, 1, 1, 1)
grid.attach(self.labels['z-'], 0, 2, 1, 1) grid.attach(self.labels['z-'], 0, 2, 1, 1)
grid.attach(bsgrid, 0, 3, 1, 1) grid.attach(zgrid, 0, 3, 1, 1)
grid.attach(self.labels['speedfactor'], 1, 0, 1, 1) grid.attach(self.labels['speedfactor'], 1, 0, 1, 1)
grid.attach(self.labels['speed+'], 1, 1, 1, 1) grid.attach(self.labels['speed+'], 1, 1, 1, 1)
grid.attach(self.labels['speed-'], 1, 2, 1, 1) grid.attach(self.labels['speed-'], 1, 2, 1, 1)
grid.attach(spdgrid, 1, 3, 1, 1)
grid.attach(self.labels['extrudefactor'], 2, 0, 1, 1) grid.attach(self.labels['extrudefactor'], 2, 0, 1, 1)
grid.attach(self.labels['extrude+'], 2, 1, 1, 1) grid.attach(self.labels['extrude+'], 2, 1, 1, 1)
grid.attach(self.labels['extrude-'], 2, 2, 1, 1) grid.attach(self.labels['extrude-'], 2, 2, 1, 1)
grid.attach(deltgrid, 1, 3, 2, 1) grid.attach(extgrid, 2, 3, 1, 1)
self.labels['z+'].connect("clicked", self.change_babystepping, "+") self.labels['z+'].connect("clicked", self.change_babystepping, "+")
self.labels['zoffset'].connect("clicked", self.change_babystepping, "reset") self.labels['zoffset'].connect("clicked", self.change_babystepping, "reset")
@@ -115,13 +133,12 @@ class FineTunePanel(ScreenPanel):
self.content.add(grid) self.content.add(grid)
def process_update(self, action, data): def process_update(self, action, data):
if action != "notify_status_update": if action != "notify_status_update":
return return
if "gcode_move" in data: if "gcode_move" in data:
if "homing_origin" in data["gcode_move"]: if "homing_origin" in data["gcode_move"]:
self.labels['zoffset'].set_label(f' {data["gcode_move"]["homing_origin"][2]:.3f}mm') self.labels['zoffset'].set_label(f' {data["gcode_move"]["homing_origin"][2]:.3f}mm')
self.z_offset = float(data["gcode_move"]["homing_origin"][2])
if "extrude_factor" in data["gcode_move"]: if "extrude_factor" in data["gcode_move"]:
self.extrusion = round(float(data["gcode_move"]["extrude_factor"]) * 100) self.extrusion = round(float(data["gcode_move"]["extrude_factor"]) * 100)
self.labels['extrudefactor'].set_label(f" {self.extrusion:3}%") self.labels['extrudefactor'].set_label(f" {self.extrusion:3}%")
@@ -133,38 +150,30 @@ class FineTunePanel(ScreenPanel):
if direction == "reset": if direction == "reset":
self.labels['zoffset'].set_label(' 0.00mm') self.labels['zoffset'].set_label(' 0.00mm')
self._screen._ws.klippy.gcode_script("SET_GCODE_OFFSET Z=0 MOVE=1") self._screen._ws.klippy.gcode_script("SET_GCODE_OFFSET Z=0 MOVE=1")
elif direction in ["+", "-"]: return
z_offset = float(self._printer.data["gcode_move"]["homing_origin"][2]) elif direction == "+":
if direction == "+": self.z_offset += float(self.z_delta)
z_offset += float(self.bs_delta) elif direction == "-":
else: self.z_offset -= float(self.z_delta)
z_offset -= float(self.bs_delta) self.labels['zoffset'].set_label(f' {self.z_offset:.3f}mm')
self.labels['zoffset'].set_label(f' {z_offset:.3f}mm') self._screen._ws.klippy.gcode_script(f"SET_GCODE_OFFSET Z_ADJUST={direction}{self.z_delta} MOVE=1")
self._screen._ws.klippy.gcode_script(f"SET_GCODE_OFFSET Z_ADJUST={direction}{self.bs_delta} MOVE=1")
def change_bs_delta(self, widget, bs):
logging.info(f"### BabyStepping {bs}")
self.labels[f"bdelta{self.bs_delta}"].get_style_context().remove_class("distbutton_active")
self.labels[f"bdelta{bs}"].get_style_context().add_class("distbutton_active")
self.bs_delta = bs
def change_extrusion(self, widget, direction): def change_extrusion(self, widget, direction):
if direction == "+": if direction == "+":
self.extrusion += int(self.percent_delta) self.extrusion += int(self.e_delta)
elif direction == "-": elif direction == "-":
self.extrusion -= int(self.percent_delta) self.extrusion -= int(self.e_delta)
elif direction == "reset": elif direction == "reset":
self.extrusion = 100 self.extrusion = 100
self.extrusion = max(self.extrusion, 1) self.extrusion = max(self.extrusion, 1)
self.labels['extrudefactor'].set_label(f" {self.extrusion:3}%") self.labels['extrudefactor'].set_label(f" {self.extrusion:3}%")
self._screen._ws.klippy.gcode_script(KlippyGcodes.set_extrusion_rate(self.extrusion)) self._screen._ws.klippy.gcode_script(KlippyGcodes.set_extrusion_rate(self.extrusion))
def change_speed(self, widget, direction): def change_speed(self, widget, direction):
if direction == "+": if direction == "+":
self.speed += int(self.percent_delta) self.speed += int(self.s_delta)
elif direction == "-": elif direction == "-":
self.speed -= int(self.percent_delta) self.speed -= int(self.s_delta)
elif direction == "reset": elif direction == "reset":
self.speed = 100 self.speed = 100
@@ -172,8 +181,15 @@ class FineTunePanel(ScreenPanel):
self.labels['speedfactor'].set_label(f" {self.speed:3}%") self.labels['speedfactor'].set_label(f" {self.speed:3}%")
self._screen._ws.klippy.gcode_script(KlippyGcodes.set_speed_rate(self.speed)) self._screen._ws.klippy.gcode_script(KlippyGcodes.set_speed_rate(self.speed))
def change_percent_delta(self, widget, delta): def change_percent_delta(self, widget, array, delta):
logging.info(f"### Delta {delta}") logging.info(f"### Delta {delta}")
self.labels[f"pdelta{self.percent_delta}"].get_style_context().remove_class("distbutton_active") widget.get_style_context().add_class("distbutton_active")
self.labels[f"pdelta{delta}"].get_style_context().add_class("distbutton_active") if array == "z_offset":
self.percent_delta = delta self.labels[f"zdelta{self.z_delta}"].get_style_context().remove_class("distbutton_active")
self.z_delta = delta
elif array == "speed":
self.labels[f"sdelta{self.s_delta}"].get_style_context().remove_class("distbutton_active")
self.s_delta = delta
elif array == "extrude":
self.labels[f"edelta{self.e_delta}"].get_style_context().remove_class("distbutton_active")
self.e_delta = delta