Finish G12, update Nozzle::clean (#14642)
This commit is contained in:
parent
57ed063ba1
commit
b8cc61262f
|
@ -100,6 +100,10 @@ void set_bed_leveling_enabled(const bool enable/*=true*/) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TemporaryBedLevelingState::TemporaryBedLevelingState(const bool enable) : saved(planner.leveling_active) {
|
||||||
|
set_bed_leveling_enabled(enable);
|
||||||
|
}
|
||||||
|
|
||||||
#if ENABLED(ENABLE_LEVELING_FADE_HEIGHT)
|
#if ENABLED(ENABLE_LEVELING_FADE_HEIGHT)
|
||||||
|
|
||||||
void set_z_fade_height(const float zfh, const bool do_report/*=true*/) {
|
void set_z_fade_height(const float zfh, const bool do_report/*=true*/) {
|
||||||
|
|
|
@ -46,6 +46,18 @@ void reset_bed_level();
|
||||||
void _manual_goto_xy(const float &x, const float &y);
|
void _manual_goto_xy(const float &x, const float &y);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A class to save and change the bed leveling state,
|
||||||
|
* then restore it when it goes out of scope.
|
||||||
|
*/
|
||||||
|
class TemporaryBedLevelingState {
|
||||||
|
bool saved;
|
||||||
|
public:
|
||||||
|
TemporaryBedLevelingState(const bool enable);
|
||||||
|
~TemporaryBedLevelingState() { set_bed_leveling_enabled(saved); }
|
||||||
|
};
|
||||||
|
#define TEMPORARY_BED_LEVELING_STATE(enable) TemporaryBedLevelingState tbls(enable)
|
||||||
|
|
||||||
#if HAS_MESH
|
#if HAS_MESH
|
||||||
|
|
||||||
typedef float (&bed_mesh_t)[GRID_MAX_POINTS_X][GRID_MAX_POINTS_Y];
|
typedef float (&bed_mesh_t)[GRID_MAX_POINTS_X][GRID_MAX_POINTS_Y];
|
||||||
|
|
|
@ -436,7 +436,7 @@ bool pause_print(const float &retract, const point_t &park_point, const float &u
|
||||||
|
|
||||||
// Park the nozzle by moving up by z_lift and then moving to (x_pos, y_pos)
|
// Park the nozzle by moving up by z_lift and then moving to (x_pos, y_pos)
|
||||||
if (!axis_unhomed_error())
|
if (!axis_unhomed_error())
|
||||||
Nozzle::park(2, park_point);
|
nozzle.park(2, park_point);
|
||||||
|
|
||||||
#if ENABLED(DUAL_X_CARRIAGE)
|
#if ENABLED(DUAL_X_CARRIAGE)
|
||||||
const int8_t saved_ext = active_extruder;
|
const int8_t saved_ext = active_extruder;
|
||||||
|
|
|
@ -573,7 +573,7 @@ void MMU2::manage_response(const bool move_axes, const bool turn_off_nozzle) {
|
||||||
COPY(resume_position, current_position);
|
COPY(resume_position, current_position);
|
||||||
|
|
||||||
if (move_axes && all_axes_homed())
|
if (move_axes && all_axes_homed())
|
||||||
Nozzle::park(2, park_point /*= NOZZLE_PARK_POINT*/);
|
nozzle.park(2, park_point /*= NOZZLE_PARK_POINT*/);
|
||||||
|
|
||||||
if (turn_off_nozzle) thermalManager.setTargetHotend(0, active_extruder);
|
if (turn_off_nozzle) thermalManager.setTargetHotend(0, active_extruder);
|
||||||
|
|
||||||
|
|
|
@ -74,7 +74,6 @@ struct measurements_t {
|
||||||
float nozzle_outer_dimension[2] = {CALIBRATION_NOZZLE_OUTER_DIAMETER, CALIBRATION_NOZZLE_OUTER_DIAMETER};
|
float nozzle_outer_dimension[2] = {CALIBRATION_NOZZLE_OUTER_DIAMETER, CALIBRATION_NOZZLE_OUTER_DIAMETER};
|
||||||
};
|
};
|
||||||
|
|
||||||
#define TEMPORARY_BED_LEVELING_STATE(enable) TemporaryBedLevelingState tbls(enable)
|
|
||||||
#define TEMPORARY_SOFT_ENDSTOP_STATE(enable) REMEMBER(tes, soft_endstops_enabled, enable);
|
#define TEMPORARY_SOFT_ENDSTOP_STATE(enable) REMEMBER(tes, soft_endstops_enabled, enable);
|
||||||
|
|
||||||
#if ENABLED(BACKLASH_GCODE)
|
#if ENABLED(BACKLASH_GCODE)
|
||||||
|
@ -89,20 +88,6 @@ struct measurements_t {
|
||||||
#define TEMPORARY_BACKLASH_SMOOTHING(value)
|
#define TEMPORARY_BACKLASH_SMOOTHING(value)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/**
|
|
||||||
* A class to save and change the bed leveling state,
|
|
||||||
* then restore it when it goes out of scope.
|
|
||||||
*/
|
|
||||||
class TemporaryBedLevelingState {
|
|
||||||
bool saved;
|
|
||||||
|
|
||||||
public:
|
|
||||||
TemporaryBedLevelingState(const bool enable) : saved(planner.leveling_active) {
|
|
||||||
set_bed_leveling_enabled(enable);
|
|
||||||
}
|
|
||||||
~TemporaryBedLevelingState() { set_bed_leveling_enabled(saved); }
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Move to a particular location. Up to three individual axes
|
* Move to a particular location. Up to three individual axes
|
||||||
* and their destinations can be specified, in any order.
|
* and their destinations can be specified, in any order.
|
||||||
|
|
|
@ -42,32 +42,25 @@ void GcodeSuite::G12() {
|
||||||
// Don't allow nozzle cleaning without homing first
|
// Don't allow nozzle cleaning without homing first
|
||||||
if (axis_unhomed_error()) return;
|
if (axis_unhomed_error()) return;
|
||||||
|
|
||||||
const bool seenxyz = parser.seen("XYZ"),
|
|
||||||
clean_x = !seenxyz || parser.boolval('X'),
|
|
||||||
clean_y = !seenxyz || parser.boolval('Y');
|
|
||||||
|
|
||||||
#if ENABLED(NOZZLE_CLEAN_NO_Z)
|
|
||||||
static constexpr bool clean_z = false;
|
|
||||||
#else
|
|
||||||
const bool clean_z = !seenxyz || parser.boolval('Z');
|
|
||||||
#endif
|
|
||||||
|
|
||||||
const uint8_t pattern = parser.ushortval('P', 0),
|
const uint8_t pattern = parser.ushortval('P', 0),
|
||||||
strokes = parser.ushortval('S', NOZZLE_CLEAN_STROKES),
|
strokes = parser.ushortval('S', NOZZLE_CLEAN_STROKES),
|
||||||
objects = parser.ushortval('T', NOZZLE_CLEAN_TRIANGLES);
|
objects = parser.ushortval('T', NOZZLE_CLEAN_TRIANGLES);
|
||||||
const float radius = parser.floatval('R', NOZZLE_CLEAN_CIRCLE_RADIUS);
|
const float radius = parser.floatval('R', NOZZLE_CLEAN_CIRCLE_RADIUS);
|
||||||
|
|
||||||
|
const bool seenxyz = parser.seen("XYZ");
|
||||||
|
const uint8_t cleans = (!seenxyz || parser.boolval('X') ? _BV(X_AXIS) : 0)
|
||||||
|
| (!seenxyz || parser.boolval('Y') ? _BV(Y_AXIS) : 0)
|
||||||
|
#if DISABLED(NOZZLE_CLEAN_NO_Z)
|
||||||
|
| (!seenxyz || parser.boolval('Z') ? _BV(Z_AXIS) : 0)
|
||||||
|
#endif
|
||||||
|
;
|
||||||
|
|
||||||
#if HAS_LEVELING
|
#if HAS_LEVELING
|
||||||
const bool was_enabled = planner.leveling_active;
|
// Disable bed leveling if cleaning Z
|
||||||
if (clean_z) set_bed_leveling_enabled(false);
|
TEMPORARY_BED_LEVELING_STATE(!TEST(cleans, Z_AXIS) && planner.leveling_active);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
Nozzle::clean(pattern, strokes, radius, objects, clean_x, clean_y, clean_z);
|
nozzle.clean(pattern, strokes, radius, objects, cleans);
|
||||||
|
|
||||||
// Re-enable bed level correction if it had been on
|
|
||||||
#if HAS_LEVELING
|
|
||||||
if (clean_z) set_bed_leveling_enabled(was_enabled);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // NOZZLE_CLEAN_FEATURE
|
#endif // NOZZLE_CLEAN_FEATURE
|
||||||
|
|
|
@ -35,7 +35,7 @@
|
||||||
void GcodeSuite::G27() {
|
void GcodeSuite::G27() {
|
||||||
// Don't allow nozzle parking without homing first
|
// Don't allow nozzle parking without homing first
|
||||||
if (axis_unhomed_error()) return;
|
if (axis_unhomed_error()) return;
|
||||||
Nozzle::park(parser.ushortval('P'));
|
nozzle.park(parser.ushortval('P'));
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // NOZZLE_PARK_FEATURE
|
#endif // NOZZLE_PARK_FEATURE
|
||||||
|
|
|
@ -26,6 +26,8 @@
|
||||||
|
|
||||||
#include "nozzle.h"
|
#include "nozzle.h"
|
||||||
|
|
||||||
|
Nozzle nozzle;
|
||||||
|
|
||||||
#include "../Marlin.h"
|
#include "../Marlin.h"
|
||||||
#include "../module/motion.h"
|
#include "../module/motion.h"
|
||||||
#include "point_t.h"
|
#include "point_t.h"
|
||||||
|
@ -155,24 +157,34 @@
|
||||||
* @param pattern one of the available patterns
|
* @param pattern one of the available patterns
|
||||||
* @param argument depends on the cleaning pattern
|
* @param argument depends on the cleaning pattern
|
||||||
*/
|
*/
|
||||||
void Nozzle::clean(const uint8_t &pattern, const uint8_t &strokes, const float &radius, const uint8_t &objects, const bool clean_x, const bool clean_y, const bool clean_z) {
|
void Nozzle::clean(const uint8_t &pattern, const uint8_t &strokes, const float &radius, const uint8_t &objects, const uint8_t cleans) {
|
||||||
point_t start = NOZZLE_CLEAN_START_POINT;
|
point_t start = NOZZLE_CLEAN_START_POINT;
|
||||||
point_t end = NOZZLE_CLEAN_END_POINT;
|
point_t end = NOZZLE_CLEAN_END_POINT;
|
||||||
if (!clean_x) start.x = end.x = current_position[X_AXIS];
|
|
||||||
if (!clean_y) start.y = end.y = current_position[Y_AXIS];
|
if (pattern == 2) {
|
||||||
if (!clean_z) start.z = end.z = current_position[Z_AXIS];
|
if (!(cleans & (_BV(X_AXIS) | _BV(Y_AXIS)))) {
|
||||||
|
SERIAL_ECHOLNPGM("Warning : Clean Circle requires XY");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
end = NOZZLE_CLEAN_CIRCLE_MIDDLE;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if (!TEST(cleans, X_AXIS)) start.x = end.x = current_position[X_AXIS];
|
||||||
|
if (!TEST(cleans, Y_AXIS)) start.y = end.y = current_position[Y_AXIS];
|
||||||
|
}
|
||||||
|
if (!TEST(cleans, Z_AXIS)) start.z = end.z = current_position[Z_AXIS];
|
||||||
|
|
||||||
switch (pattern) {
|
switch (pattern) {
|
||||||
case 1:
|
case 1:
|
||||||
zigzag(NOZZLE_CLEAN_START_POINT, NOZZLE_CLEAN_END_POINT, strokes, objects);
|
zigzag(start, end, strokes, objects);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 2:
|
case 2:
|
||||||
circle(NOZZLE_CLEAN_START_POINT, NOZZLE_CLEAN_CIRCLE_MIDDLE, strokes, radius);
|
circle(start, end, strokes, radius);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
stroke(NOZZLE_CLEAN_START_POINT, NOZZLE_CLEAN_END_POINT, strokes);
|
stroke(start, end, strokes);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -78,7 +78,7 @@ class Nozzle {
|
||||||
* @param pattern one of the available patterns
|
* @param pattern one of the available patterns
|
||||||
* @param argument depends on the cleaning pattern
|
* @param argument depends on the cleaning pattern
|
||||||
*/
|
*/
|
||||||
static void clean(const uint8_t &pattern, const uint8_t &strokes, const float &radius, const uint8_t &objects, const bool clean_x, const bool clean_y, const bool clean_z) _Os;
|
static void clean(const uint8_t &pattern, const uint8_t &strokes, const float &radius, const uint8_t &objects, const uint8_t cleans) _Os;
|
||||||
|
|
||||||
#endif // NOZZLE_CLEAN_FEATURE
|
#endif // NOZZLE_CLEAN_FEATURE
|
||||||
|
|
||||||
|
@ -88,3 +88,5 @@ class Nozzle {
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
|
extern Nozzle nozzle;
|
||||||
|
|
|
@ -822,12 +822,6 @@ void tool_change(const uint8_t tmp_extruder, bool no_move/*=false*/) {
|
||||||
return invalid_extruder_error(tmp_extruder);
|
return invalid_extruder_error(tmp_extruder);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if HAS_LEVELING
|
|
||||||
// Set current position to the physical position
|
|
||||||
const bool leveling_was_active = planner.leveling_active;
|
|
||||||
set_bed_leveling_enabled(false);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (tmp_extruder >= EXTRUDERS)
|
if (tmp_extruder >= EXTRUDERS)
|
||||||
return invalid_extruder_error(tmp_extruder);
|
return invalid_extruder_error(tmp_extruder);
|
||||||
|
|
||||||
|
@ -875,6 +869,11 @@ void tool_change(const uint8_t tmp_extruder, bool no_move/*=false*/) {
|
||||||
}
|
}
|
||||||
#endif // TOOLCHANGE_FILAMENT_SWAP
|
#endif // TOOLCHANGE_FILAMENT_SWAP
|
||||||
|
|
||||||
|
#if HAS_LEVELING
|
||||||
|
// Set current position to the physical position
|
||||||
|
TEMPORARY_BED_LEVELING_STATE(false);
|
||||||
|
#endif
|
||||||
|
|
||||||
if (tmp_extruder != active_extruder) {
|
if (tmp_extruder != active_extruder) {
|
||||||
|
|
||||||
#if SWITCHING_NOZZLE_TWO_SERVOS
|
#if SWITCHING_NOZZLE_TWO_SERVOS
|
||||||
|
@ -1071,11 +1070,6 @@ void tool_change(const uint8_t tmp_extruder, bool no_move/*=false*/) {
|
||||||
fanmux_switch(active_extruder);
|
fanmux_switch(active_extruder);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if HAS_LEVELING
|
|
||||||
// Restore leveling to re-establish the logical position
|
|
||||||
set_bed_leveling_enabled(leveling_was_active);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
SERIAL_ECHO_START();
|
SERIAL_ECHO_START();
|
||||||
SERIAL_ECHOLNPAIR(MSG_ACTIVE_EXTRUDER, int(active_extruder));
|
SERIAL_ECHOLNPAIR(MSG_ACTIVE_EXTRUDER, int(active_extruder));
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue