tuning_tower: Only cancel tuning tower test if extrude at notably lower z

Some print start scripts may extrude at a position slightly higher
than the first z layer height.  Tweak the backwards z test to reduce
the chance of the tuning test ending prematurely.

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2019-10-04 14:58:17 -04:00
parent 4ef0db5087
commit 6d7d079bab
1 changed files with 6 additions and 3 deletions

View File

@ -5,6 +5,8 @@
# This file may be distributed under the terms of the GNU GPLv3 license. # This file may be distributed under the terms of the GNU GPLv3 license.
import math, logging import math, logging
CANCEL_Z_DELTA=2.0
class TuningTower: class TuningTower:
def __init__(self, config): def __init__(self, config):
self.printer = config.get_printer() self.printer = config.get_printer()
@ -48,7 +50,10 @@ class TuningTower:
and newpos[:3] != self.last_position[:3]): and newpos[:3] != self.last_position[:3]):
# Extrusion move at new z height # Extrusion move at new z height
z = newpos[2] z = newpos[2]
if z > self.last_z: if z < self.last_z - CANCEL_Z_DELTA:
# Extrude at a lower z height - probably start of new print
self.end_test()
else:
# Process update # Process update
oldval = self.calc_value(self.last_z) oldval = self.calc_value(self.last_z)
newval = self.calc_value(z) newval = self.calc_value(z)
@ -57,8 +62,6 @@ class TuningTower:
gcode = self.printer.lookup_object("gcode") gcode = self.printer.lookup_object("gcode")
gcode.run_script_from_command("%s %s=%.9f" % ( gcode.run_script_from_command("%s %s=%.9f" % (
self.command, self.parameter, newval)) self.command, self.parameter, newval))
else:
self.end_test()
# Forward move to actual handler # Forward move to actual handler
self.last_position[:] = newpos self.last_position[:] = newpos
normal_transform.move(newpos, speed) normal_transform.move(newpos, speed)