diff options
author | Arksine <arksine.code@gmail.com> | 2018-08-25 10:55:12 -0400 |
---|---|---|
committer | Kevin O'Connor <kevin@koconnor.net> | 2018-08-29 12:01:14 -0400 |
commit | 1588426229909809db017f76b086ce7c8da16677 (patch) | |
tree | 11bbc2d7fa9dcb30b7740dbd7c4d1d45200685d8 /klippy/extras | |
parent | 4acda88e8d016893e1ad2d41af483d31f6f633db (diff) | |
download | kutter-1588426229909809db017f76b086ce7c8da16677.tar.gz kutter-1588426229909809db017f76b086ce7c8da16677.tar.xz kutter-1588426229909809db017f76b086ce7c8da16677.zip |
probe: Refactor z lift code to its own function.
Call lift-z prior to the first move. This prevents the nozzle from hitting the build surface in situations that home the nozzle off and below the bed.
Signed-off-by: Eric Callahan <arksine.code@gmail.com>
Diffstat (limited to 'klippy/extras')
-rw-r--r-- | klippy/extras/probe.py | 18 |
1 files changed, 11 insertions, 7 deletions
diff --git a/klippy/extras/probe.py b/klippy/extras/probe.py index 4164ef14..ac7300e6 100644 --- a/klippy/extras/probe.py +++ b/klippy/extras/probe.py @@ -180,6 +180,15 @@ class ProbePointsHelper: return self.probe.last_home_position() else: return None + def lift_z(self, z_pos): + # Lift toolhead + curpos = self.toolhead.get_position() + curpos[2] = z_pos + try: + self.toolhead.move(curpos, self.lift_speed) + except homing.EndstopError as e: + self.finalize(False) + raise self.gcode.error(str(e)) def start_probe(self): # Begin probing self.toolhead = self.printer.lookup_object('toolhead') @@ -191,6 +200,7 @@ class ProbePointsHelper: 'NEXT', self.cmd_NEXT, desc=self.cmd_NEXT_help) self.results = [] self.busy = True + self.lift_z(self.horizontal_move_z) self.move_next() if self.probe is not None: try: @@ -218,13 +228,7 @@ class ProbePointsHelper: self.toolhead.wait_moves() self.results.append(self.callback.get_probed_position()) # Lift toolhead - curpos = self.toolhead.get_position() - curpos[2] = self.horizontal_move_z - try: - self.toolhead.move(curpos, self.lift_speed) - except homing.EndstopError as e: - self.finalize(False) - raise self.gcode.error(str(e)) + self.lift_z(self.horizontal_move_z) # Move to next position if len(self.results) == len(self.probe_points): self.toolhead.get_last_move_time() |