move: reformat with black

This commit is contained in:
alfrix 2024-05-09 09:02:37 -03:00
parent 312f56a6a0
commit 6f15d51aa0

View File

@ -9,76 +9,82 @@ from ks_includes.screen_panel import ScreenPanel
class Panel(ScreenPanel): class Panel(ScreenPanel):
distances = ['.1', '.5', '1', '5', '10', '25', '50'] distances = [".1", ".5", "1", "5", "10", "25", "50"]
distance = distances[-2] distance = distances[-2]
def __init__(self, screen, title): def __init__(self, screen, title):
super().__init__(screen, title) super().__init__(screen, title)
if self.ks_printer_cfg is not None: if self.ks_printer_cfg is not None:
dis = self.ks_printer_cfg.get("move_distances", '') dis = self.ks_printer_cfg.get("move_distances", "")
if re.match(r'^[0-9,\.\s]+$', dis): if re.match(r"^[0-9,\.\s]+$", dis):
dis = [str(i.strip()) for i in dis.split(',')] dis = [str(i.strip()) for i in dis.split(",")]
if 1 < len(dis) <= 7: if 1 < len(dis) <= 7:
self.distances = dis self.distances = dis
self.distance = self.distances[-2] self.distance = self.distances[-2]
self.settings = {} self.settings = {}
self.menu = ['move_menu'] self.menu = ["move_menu"]
self.buttons = { self.buttons = {
'x+': self._gtk.Button("arrow-right", "X+", "color1"), "x+": self._gtk.Button("arrow-right", "X+", "color1"),
'x-': self._gtk.Button("arrow-left", "X-", "color1"), "x-": self._gtk.Button("arrow-left", "X-", "color1"),
'y+': self._gtk.Button("arrow-up", "Y+", "color2"), "y+": self._gtk.Button("arrow-up", "Y+", "color2"),
'y-': self._gtk.Button("arrow-down", "Y-", "color2"), "y-": self._gtk.Button("arrow-down", "Y-", "color2"),
'z+': self._gtk.Button("z-farther", "Z+", "color3"), "z+": self._gtk.Button("z-farther", "Z+", "color3"),
'z-': self._gtk.Button("z-closer", "Z-", "color3"), "z-": self._gtk.Button("z-closer", "Z-", "color3"),
'home': self._gtk.Button("home", _("Home"), "color4"), "home": self._gtk.Button("home", _("Home"), "color4"),
'motors_off': self._gtk.Button("motor-off", _("Disable Motors"), "color4"), "motors_off": self._gtk.Button("motor-off", _("Disable Motors"), "color4"),
} }
self.buttons['x+'].connect("clicked", self.move, "X", "+") self.buttons["x+"].connect("clicked", self.move, "X", "+")
self.buttons['x-'].connect("clicked", self.move, "X", "-") self.buttons["x-"].connect("clicked", self.move, "X", "-")
self.buttons['y+'].connect("clicked", self.move, "Y", "+") self.buttons["y+"].connect("clicked", self.move, "Y", "+")
self.buttons['y-'].connect("clicked", self.move, "Y", "-") self.buttons["y-"].connect("clicked", self.move, "Y", "-")
self.buttons['z+'].connect("clicked", self.move, "Z", "+") self.buttons["z+"].connect("clicked", self.move, "Z", "+")
self.buttons['z-'].connect("clicked", self.move, "Z", "-") self.buttons["z-"].connect("clicked", self.move, "Z", "-")
self.buttons['home'].connect("clicked", self.home) self.buttons["home"].connect("clicked", self.home)
script = {"script": "M18"} script = {"script": "M18"}
self.buttons['motors_off'].connect("clicked", self._screen._confirm_send_action, self.buttons["motors_off"].connect(
_("Are you sure you wish to disable motors?"), "clicked",
"printer.gcode.script", script) self._screen._confirm_send_action,
adjust = self._gtk.Button("settings", None, "color2", 1, Gtk.PositionType.LEFT, 1) _("Are you sure you wish to disable motors?"),
adjust.connect("clicked", self.load_menu, 'options', _('Settings')) "printer.gcode.script",
script,
)
adjust = self._gtk.Button(
"settings", None, "color2", 1, Gtk.PositionType.LEFT, 1
)
adjust.connect("clicked", self.load_menu, "options", _("Settings"))
adjust.set_hexpand(False) adjust.set_hexpand(False)
grid = Gtk.Grid(row_homogeneous=True, column_homogeneous=True) grid = Gtk.Grid(row_homogeneous=True, column_homogeneous=True)
if self._screen.vertical_mode: if self._screen.vertical_mode:
if self._screen.lang_ltr: if self._screen.lang_ltr:
grid.attach(self.buttons['x+'], 2, 1, 1, 1) grid.attach(self.buttons["x+"], 2, 1, 1, 1)
grid.attach(self.buttons['x-'], 0, 1, 1, 1) grid.attach(self.buttons["x-"], 0, 1, 1, 1)
grid.attach(self.buttons['z+'], 2, 2, 1, 1) grid.attach(self.buttons["z+"], 2, 2, 1, 1)
grid.attach(self.buttons['z-'], 0, 2, 1, 1) grid.attach(self.buttons["z-"], 0, 2, 1, 1)
else: else:
grid.attach(self.buttons['x+'], 0, 1, 1, 1) grid.attach(self.buttons["x+"], 0, 1, 1, 1)
grid.attach(self.buttons['x-'], 2, 1, 1, 1) grid.attach(self.buttons["x-"], 2, 1, 1, 1)
grid.attach(self.buttons['z+'], 0, 2, 1, 1) grid.attach(self.buttons["z+"], 0, 2, 1, 1)
grid.attach(self.buttons['z-'], 2, 2, 1, 1) grid.attach(self.buttons["z-"], 2, 2, 1, 1)
grid.attach(adjust, 1, 2, 1, 1) grid.attach(adjust, 1, 2, 1, 1)
grid.attach(self.buttons['y+'], 1, 0, 1, 1) grid.attach(self.buttons["y+"], 1, 0, 1, 1)
grid.attach(self.buttons['y-'], 1, 1, 1, 1) grid.attach(self.buttons["y-"], 1, 1, 1, 1)
else: else:
if self._screen.lang_ltr: if self._screen.lang_ltr:
grid.attach(self.buttons['x+'], 2, 1, 1, 1) grid.attach(self.buttons["x+"], 2, 1, 1, 1)
grid.attach(self.buttons['x-'], 0, 1, 1, 1) grid.attach(self.buttons["x-"], 0, 1, 1, 1)
else: else:
grid.attach(self.buttons['x+'], 0, 1, 1, 1) grid.attach(self.buttons["x+"], 0, 1, 1, 1)
grid.attach(self.buttons['x-'], 2, 1, 1, 1) grid.attach(self.buttons["x-"], 2, 1, 1, 1)
grid.attach(self.buttons['y+'], 1, 0, 1, 1) grid.attach(self.buttons["y+"], 1, 0, 1, 1)
grid.attach(self.buttons['y-'], 1, 1, 1, 1) grid.attach(self.buttons["y-"], 1, 1, 1, 1)
grid.attach(self.buttons['z+'], 3, 0, 1, 1) grid.attach(self.buttons["z+"], 3, 0, 1, 1)
grid.attach(self.buttons['z-'], 3, 1, 1, 1) grid.attach(self.buttons["z-"], 3, 1, 1, 1)
grid.attach(self.buttons['home'], 0, 0, 1, 1) grid.attach(self.buttons["home"], 0, 0, 1, 1)
grid.attach(self.buttons['motors_off'], 2, 0, 1, 1) grid.attach(self.buttons["motors_off"], 2, 0, 1, 1)
distgrid = Gtk.Grid() distgrid = Gtk.Grid()
for j, i in enumerate(self.distances): for j, i in enumerate(self.distances):
@ -91,25 +97,27 @@ class Panel(ScreenPanel):
ctx.add_class("horizontal_togglebuttons_active") ctx.add_class("horizontal_togglebuttons_active")
distgrid.attach(self.labels[i], j, 0, 1, 1) distgrid.attach(self.labels[i], j, 0, 1, 1)
for p in ('pos_x', 'pos_y', 'pos_z'): for p in ("pos_x", "pos_y", "pos_z"):
self.labels[p] = Gtk.Label() self.labels[p] = Gtk.Label()
self.labels['move_dist'] = Gtk.Label(label=_("Move Distance (mm)")) self.labels["move_dist"] = Gtk.Label(label=_("Move Distance (mm)"))
bottomgrid = Gtk.Grid(row_homogeneous=True, column_homogeneous=True) bottomgrid = Gtk.Grid(row_homogeneous=True, column_homogeneous=True)
bottomgrid.set_direction(Gtk.TextDirection.LTR) bottomgrid.set_direction(Gtk.TextDirection.LTR)
bottomgrid.attach(self.labels['pos_x'], 0, 0, 1, 1) bottomgrid.attach(self.labels["pos_x"], 0, 0, 1, 1)
bottomgrid.attach(self.labels['pos_y'], 1, 0, 1, 1) bottomgrid.attach(self.labels["pos_y"], 1, 0, 1, 1)
bottomgrid.attach(self.labels['pos_z'], 2, 0, 1, 1) bottomgrid.attach(self.labels["pos_z"], 2, 0, 1, 1)
bottomgrid.attach(self.labels['move_dist'], 0, 1, 3, 1) bottomgrid.attach(self.labels["move_dist"], 0, 1, 3, 1)
if not self._screen.vertical_mode: if not self._screen.vertical_mode:
bottomgrid.attach(adjust, 3, 0, 1, 2) bottomgrid.attach(adjust, 3, 0, 1, 2)
self.labels['move_menu'] = Gtk.Grid(row_homogeneous=True, column_homogeneous=True) self.labels["move_menu"] = Gtk.Grid(
self.labels['move_menu'].attach(grid, 0, 0, 1, 3) row_homogeneous=True, column_homogeneous=True
self.labels['move_menu'].attach(bottomgrid, 0, 3, 1, 1) )
self.labels['move_menu'].attach(distgrid, 0, 4, 1, 1) self.labels["move_menu"].attach(grid, 0, 0, 1, 3)
self.labels["move_menu"].attach(bottomgrid, 0, 3, 1, 1)
self.labels["move_menu"].attach(distgrid, 0, 4, 1, 1)
self.content.add(self.labels['move_menu']) self.content.add(self.labels["move_menu"])
printer_cfg = self._printer.get_config_section("printer") printer_cfg = self._printer.get_config_section("printer")
# The max_velocity parameter is not optional in klipper config. # The max_velocity parameter is not optional in klipper config.
@ -121,26 +129,63 @@ class Panel(ScreenPanel):
max_z_velocity = max_velocity max_z_velocity = max_velocity
configurable_options = [ configurable_options = [
{"invert_x": {"section": "main", "name": _("Invert X"), "type": "binary", "value": "False", {
"callback": self.reinit_panels}}, "invert_x": {
{"invert_y": {"section": "main", "name": _("Invert Y"), "type": "binary", "value": "False", "section": "main",
"callback": self.reinit_panels}}, "name": _("Invert X"),
{"invert_z": {"section": "main", "name": _("Invert Z"), "type": "binary", "value": "False"}}, "type": "binary",
{"move_speed_xy": { "value": "False",
"section": "main", "name": _("XY Speed (mm/s)"), "type": "scale", "value": "50", "callback": self.reinit_panels,
"range": [1, max_velocity], "step": 1}}, }
{"move_speed_z": { },
"section": "main", "name": _("Z Speed (mm/s)"), "type": "scale", "value": "10", {
"range": [1, max_z_velocity], "step": 1}} "invert_y": {
"section": "main",
"name": _("Invert Y"),
"type": "binary",
"value": "False",
"callback": self.reinit_panels,
}
},
{
"invert_z": {
"section": "main",
"name": _("Invert Z"),
"type": "binary",
"value": "False",
}
},
{
"move_speed_xy": {
"section": "main",
"name": _("XY Speed (mm/s)"),
"type": "scale",
"value": "50",
"range": [1, max_velocity],
"step": 1,
}
},
{
"move_speed_z": {
"section": "main",
"name": _("Z Speed (mm/s)"),
"type": "scale",
"value": "10",
"range": [1, max_z_velocity],
"step": 1,
}
},
] ]
self.labels['options_menu'] = self._gtk.ScrolledWindow() self.labels["options_menu"] = self._gtk.ScrolledWindow()
self.labels['options'] = Gtk.Grid() self.labels["options"] = Gtk.Grid()
self.labels['options_menu'].add(self.labels['options']) self.labels["options_menu"].add(self.labels["options"])
self.options = {} self.options = {}
for option in configurable_options: for option in configurable_options:
name = list(option)[0] name = list(option)[0]
self.options.update(self.add_option('options', self.settings, name, option[name])) self.options.update(
self.add_option("options", self.settings, name, option[name])
)
def reinit_panels(self, value): def reinit_panels(self, value):
logging.info(self._screen.panels) logging.info(self._screen.panels)
@ -152,32 +197,47 @@ class Panel(ScreenPanel):
return return
if "toolhead" in data and "max_velocity" in data["toolhead"]: if "toolhead" in data and "max_velocity" in data["toolhead"]:
max_vel = max(int(float(data["toolhead"]["max_velocity"])), 2) max_vel = max(int(float(data["toolhead"]["max_velocity"])), 2)
adj = self.options['move_speed_xy'].get_adjustment() adj = self.options["move_speed_xy"].get_adjustment()
adj.set_upper(max_vel) adj.set_upper(max_vel)
if "gcode_move" in data or "toolhead" in data and "homed_axes" in data["toolhead"]: if (
"gcode_move" in data
or "toolhead" in data
and "homed_axes" in data["toolhead"]
):
homed_axes = self._printer.get_stat("toolhead", "homed_axes") homed_axes = self._printer.get_stat("toolhead", "homed_axes")
for i, axis in enumerate(('x', 'y', 'z')): for i, axis in enumerate(("x", "y", "z")):
if axis not in homed_axes: if axis not in homed_axes:
self.labels[f"pos_{axis}"].set_text(f"{axis.upper()}: ?") self.labels[f"pos_{axis}"].set_text(f"{axis.upper()}: ?")
elif "gcode_move" in data and "gcode_position" in data["gcode_move"]: elif "gcode_move" in data and "gcode_position" in data["gcode_move"]:
self.labels[f"pos_{axis}"].set_text( self.labels[f"pos_{axis}"].set_text(
f"{axis.upper()}: {data['gcode_move']['gcode_position'][i]:.2f}") f"{axis.upper()}: {data['gcode_move']['gcode_position'][i]:.2f}"
)
def change_distance(self, widget, distance): def change_distance(self, widget, distance):
logging.info(f"### Distance {distance}") logging.info(f"### Distance {distance}")
self.labels[f"{self.distance}"].get_style_context().remove_class("horizontal_togglebuttons_active") self.labels[f"{self.distance}"].get_style_context().remove_class(
self.labels[f"{distance}"].get_style_context().add_class("horizontal_togglebuttons_active") "horizontal_togglebuttons_active"
)
self.labels[f"{distance}"].get_style_context().add_class(
"horizontal_togglebuttons_active"
)
self.distance = distance self.distance = distance
def move(self, widget, axis, direction): def move(self, widget, axis, direction):
if self._config.get_config()['main'].getboolean(f"invert_{axis.lower()}", False): if self._config.get_config()["main"].getboolean(
f"invert_{axis.lower()}", False
):
direction = "-" if direction == "+" else "+" direction = "-" if direction == "+" else "+"
dist = f"{direction}{self.distance}" dist = f"{direction}{self.distance}"
config_key = "move_speed_z" if axis == "Z" else "move_speed_xy" config_key = "move_speed_z" if axis == "Z" else "move_speed_xy"
speed = None if self.ks_printer_cfg is None else self.ks_printer_cfg.getint(config_key, None) speed = (
None
if self.ks_printer_cfg is None
else self.ks_printer_cfg.getint(config_key, None)
)
if speed is None: if speed is None:
speed = self._config.get_config()['main'].getint(config_key, 20) speed = self._config.get_config()["main"].getint(config_key, 20)
speed = 60 * max(1, speed) speed = 60 * max(1, speed)
script = f"{KlippyGcodes.MOVE_RELATIVE}\nG0 {axis}{dist} F{speed}" script = f"{KlippyGcodes.MOVE_RELATIVE}\nG0 {axis}{dist} F{speed}"
self._screen._send_action(widget, "printer.gcode.script", {"script": script}) self._screen._send_action(widget, "printer.gcode.script", {"script": script})
@ -191,8 +251,8 @@ class Panel(ScreenPanel):
return False return False
def home(self, widget): def home(self, widget):
if "delta" in self._printer.get_config_section("printer")['kinematics']: if "delta" in self._printer.get_config_section("printer")["kinematics"]:
self._screen._send_action(widget, "printer.gcode.script", {"script": 'G28'}) self._screen._send_action(widget, "printer.gcode.script", {"script": "G28"})
return return
name = "homing" name = "homing"
disname = self._screen._config.get_menu_name("move", name) disname = self._screen._config.get_menu_name("move", name)