|
|
@ -240,8 +240,6 @@ void move_to(const float &rx, const float &ry, const float &z, const float &e_de
|
|
|
|
destination[E_AXIS] = current_position[E_AXIS];
|
|
|
|
destination[E_AXIS] = current_position[E_AXIS];
|
|
|
|
|
|
|
|
|
|
|
|
G26_line_to_destination(feed_value);
|
|
|
|
G26_line_to_destination(feed_value);
|
|
|
|
|
|
|
|
|
|
|
|
stepper.synchronize();
|
|
|
|
|
|
|
|
set_destination_from_current();
|
|
|
|
set_destination_from_current();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -256,8 +254,6 @@ void move_to(const float &rx, const float &ry, const float &z, const float &e_de
|
|
|
|
destination[E_AXIS] += e_delta;
|
|
|
|
destination[E_AXIS] += e_delta;
|
|
|
|
|
|
|
|
|
|
|
|
G26_line_to_destination(feed_value);
|
|
|
|
G26_line_to_destination(feed_value);
|
|
|
|
|
|
|
|
|
|
|
|
stepper.synchronize();
|
|
|
|
|
|
|
|
set_destination_from_current();
|
|
|
|
set_destination_from_current();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -499,13 +495,11 @@ inline bool prime_nozzle() {
|
|
|
|
if (Total_Prime >= EXTRUDE_MAXLENGTH) return G26_ERR;
|
|
|
|
if (Total_Prime >= EXTRUDE_MAXLENGTH) return G26_ERR;
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
G26_line_to_destination(planner.max_feedrate_mm_s[E_AXIS] / 15.0);
|
|
|
|
G26_line_to_destination(planner.max_feedrate_mm_s[E_AXIS] / 15.0);
|
|
|
|
|
|
|
|
set_destination_from_current();
|
|
|
|
stepper.synchronize(); // Without this synchronize, the purge is more consistent,
|
|
|
|
stepper.synchronize(); // Without this synchronize, the purge is more consistent,
|
|
|
|
// but because the planner has a buffer, we won't be able
|
|
|
|
// but because the planner has a buffer, we won't be able
|
|
|
|
// to stop as quickly. So we put up with the less smooth
|
|
|
|
// to stop as quickly. So we put up with the less smooth
|
|
|
|
// action to give the user a more responsive 'Stop'.
|
|
|
|
// action to give the user a more responsive 'Stop'.
|
|
|
|
set_destination_from_current();
|
|
|
|
|
|
|
|
idle();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
wait_for_release();
|
|
|
|
wait_for_release();
|
|
|
@ -526,7 +520,6 @@ inline bool prime_nozzle() {
|
|
|
|
set_destination_from_current();
|
|
|
|
set_destination_from_current();
|
|
|
|
destination[E_AXIS] += g26_prime_length;
|
|
|
|
destination[E_AXIS] += g26_prime_length;
|
|
|
|
G26_line_to_destination(planner.max_feedrate_mm_s[E_AXIS] / 15.0);
|
|
|
|
G26_line_to_destination(planner.max_feedrate_mm_s[E_AXIS] / 15.0);
|
|
|
|
stepper.synchronize();
|
|
|
|
|
|
|
|
set_destination_from_current();
|
|
|
|
set_destination_from_current();
|
|
|
|
retract_filament(destination);
|
|
|
|
retract_filament(destination);
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -700,7 +693,6 @@ void GcodeSuite::G26() {
|
|
|
|
|
|
|
|
|
|
|
|
if (current_position[Z_AXIS] < Z_CLEARANCE_BETWEEN_PROBES) {
|
|
|
|
if (current_position[Z_AXIS] < Z_CLEARANCE_BETWEEN_PROBES) {
|
|
|
|
do_blocking_move_to_z(Z_CLEARANCE_BETWEEN_PROBES);
|
|
|
|
do_blocking_move_to_z(Z_CLEARANCE_BETWEEN_PROBES);
|
|
|
|
stepper.synchronize();
|
|
|
|
|
|
|
|
set_current_from_destination();
|
|
|
|
set_current_from_destination();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|