Fix wipe tower deretraction string.

Return the previous behaviour for non priming toolchanges and
handle priming toolchanges separately.
This commit is contained in:
Martin Šach 2024-01-25 10:29:49 +01:00
parent e5b926690e
commit 4481525169

View File

@ -93,7 +93,8 @@ std::string WipeTowerIntegration::append_tcr(GCodeGenerator &gcodegen, const Wip
gcodegen.m_wipe.reset_path(); // We don't want wiping on the ramming lines.
toolchange_gcode_str = gcodegen.set_extruder(new_extruder_id, tcr.print_z); // TODO: toolchange_z vs print_z
if (gcodegen.config().wipe_tower) {
deretraction_str += gcodegen.writer().get_travel_to_z_gcode(tcr.print_z, "restore layer Z");
const double retract_to_z = tcr.priming ? tcr.print_z + gcodegen.config().z_offset.value : z;
deretraction_str += gcodegen.writer().get_travel_to_z_gcode(retract_to_z, "restore layer Z");
deretraction_str += gcodegen.unretract();
}
}