M421: Add 'adjust closest point' capability
- Split M421 into separate versions for bilinear and ubl - Fix minor issue in G26
This commit is contained in:
parent
2819228d4f
commit
ae676490c9
4 changed files with 61 additions and 21 deletions
|
@ -740,12 +740,14 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
if (code_seen('R')) {
|
if (code_seen('R')) {
|
||||||
g26_repeats = code_has_value() ? code_value_int() - 1 : 999;
|
g26_repeats = code_has_value() ? code_value_int() : 999;
|
||||||
|
|
||||||
if (g26_repeats <= 0) {
|
if (g26_repeats <= 0) {
|
||||||
SERIAL_PROTOCOLLNPGM("?(R)epeat value not plausible; must be greater than 0.");
|
SERIAL_PROTOCOLLNPGM("?(R)epeat value not plausible; must be greater than 0.");
|
||||||
return UBL_ERR;
|
return UBL_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
g26_repeats--;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -8477,7 +8477,7 @@ void quickstop_stepper() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#elif ENABLED(AUTO_BED_LEVELING_BILINEAR) || ENABLED(AUTO_BED_LEVELING_UBL)
|
#elif ENABLED(AUTO_BED_LEVELING_BILINEAR)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* M421: Set a single Mesh Bed Leveling Z coordinate
|
* M421: Set a single Mesh Bed Leveling Z coordinate
|
||||||
|
@ -8490,8 +8490,8 @@ void quickstop_stepper() {
|
||||||
int8_t px = 0, py = 0;
|
int8_t px = 0, py = 0;
|
||||||
float z = 0;
|
float z = 0;
|
||||||
bool hasI, hasJ, hasZ, hasQ;
|
bool hasI, hasJ, hasZ, hasQ;
|
||||||
if ((hasI = code_seen('I'))) px = code_value_linear_units();
|
if ((hasI = code_seen('I'))) px = code_value_int();
|
||||||
if ((hasJ = code_seen('J'))) py = code_value_linear_units();
|
if ((hasJ = code_seen('J'))) py = code_value_int();
|
||||||
if ((hasZ = code_seen('Z'))) z = code_value_linear_units();
|
if ((hasZ = code_seen('Z'))) z = code_value_linear_units();
|
||||||
if ((hasQ = code_seen('Q'))) z = code_value_linear_units();
|
if ((hasQ = code_seen('Q'))) z = code_value_linear_units();
|
||||||
|
|
||||||
|
@ -8503,23 +8503,15 @@ void quickstop_stepper() {
|
||||||
|
|
||||||
if (WITHIN(px, 0, GRID_MAX_POINTS_X - 1) && WITHIN(py, 0, GRID_MAX_POINTS_Y - 1)) {
|
if (WITHIN(px, 0, GRID_MAX_POINTS_X - 1) && WITHIN(py, 0, GRID_MAX_POINTS_Y - 1)) {
|
||||||
if (hasZ) { // doing an absolute mesh value
|
if (hasZ) { // doing an absolute mesh value
|
||||||
#if ENABLED(AUTO_BED_LEVELING_UBL)
|
z_values[px][py] = z;
|
||||||
ubl.z_values[px][py] = z;
|
#if ENABLED(ABL_BILINEAR_SUBDIVISION)
|
||||||
#else
|
bed_level_virt_interpolate();
|
||||||
z_values[px][py] = z;
|
|
||||||
#if ENABLED(ABL_BILINEAR_SUBDIVISION)
|
|
||||||
bed_level_virt_interpolate();
|
|
||||||
#endif
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
else { // doing an offset of a mesh value
|
else { // doing an offset of a mesh value
|
||||||
#if ENABLED(AUTO_BED_LEVELING_UBL)
|
z_values[px][py] += z;
|
||||||
ubl.z_values[px][py] += z;
|
#if ENABLED(ABL_BILINEAR_SUBDIVISION)
|
||||||
#else
|
bed_level_virt_interpolate();
|
||||||
z_values[px][py] += z;
|
|
||||||
#if ENABLED(ABL_BILINEAR_SUBDIVISION)
|
|
||||||
bed_level_virt_interpolate();
|
|
||||||
#endif
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -8528,6 +8520,52 @@ void quickstop_stepper() {
|
||||||
SERIAL_ERRORLNPGM(MSG_ERR_MESH_XY);
|
SERIAL_ERRORLNPGM(MSG_ERR_MESH_XY);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#elif ENABLED(AUTO_BED_LEVELING_UBL)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* M421: Set a single Mesh Bed Leveling Z coordinate
|
||||||
|
*
|
||||||
|
* M421 I<xindex> J<yindex> Z<linear>
|
||||||
|
* or
|
||||||
|
* M421 I<xindex> J<yindex> Q<offset>
|
||||||
|
*/
|
||||||
|
|
||||||
|
//todo: change multiple points simultaneously?
|
||||||
|
|
||||||
|
inline void gcode_M421() {
|
||||||
|
int8_t px = 0, py = 0;
|
||||||
|
float z = 0;
|
||||||
|
bool hasI, hasJ, hasZ, hasQ, hasC;
|
||||||
|
if ((hasI = code_seen('I'))) px = code_value_int();
|
||||||
|
if ((hasJ = code_seen('J'))) py = code_value_int();
|
||||||
|
if ((hasZ = code_seen('Z'))) z = code_value_linear_units();
|
||||||
|
if ((hasQ = code_seen('Q'))) z = code_value_linear_units();
|
||||||
|
hasC = code_seen('C');
|
||||||
|
|
||||||
|
if ( (!(hasI && hasJ) && !hasC) || (hasQ && hasZ) || (!hasQ && !hasZ)) {
|
||||||
|
SERIAL_ERROR_START;
|
||||||
|
SERIAL_ERRORLNPGM(MSG_ERR_M421_PARAMETERS);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (hasC) { // get closest position
|
||||||
|
const mesh_index_pair location = find_closest_mesh_point_of_type(REAL, current_position[X_AXIS], current_position[Y_AXIS], USE_NOZZLE_AS_REFERENCE, NULL, false);
|
||||||
|
px = location.x_index;
|
||||||
|
py = location.y_index;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (WITHIN(px, 0, GRID_MAX_POINTS_X - 1) && WITHIN(py, 0, GRID_MAX_POINTS_Y - 1)) {
|
||||||
|
if (hasZ) // doing an absolute mesh value
|
||||||
|
ubl.z_values[px][py] = z;
|
||||||
|
else // doing an offset of a mesh value
|
||||||
|
ubl.z_values[px][py] += z;
|
||||||
|
}
|
||||||
|
else { // bad indexes were specified for the mesh point
|
||||||
|
SERIAL_ERROR_START;
|
||||||
|
SERIAL_ERRORLNPGM(MSG_ERR_MESH_XY);
|
||||||
|
}
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if HAS_M206_COMMAND
|
#if HAS_M206_COMMAND
|
||||||
|
|
|
@ -35,6 +35,9 @@
|
||||||
#define UBL_OK false
|
#define UBL_OK false
|
||||||
#define UBL_ERR true
|
#define UBL_ERR true
|
||||||
|
|
||||||
|
#define USE_NOZZLE_AS_REFERENCE 0
|
||||||
|
#define USE_PROBE_AS_REFERENCE 1
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
int8_t x_index, y_index;
|
int8_t x_index, y_index;
|
||||||
float distance; // When populated, the distance from the search location
|
float distance; // When populated, the distance from the search location
|
||||||
|
|
|
@ -311,9 +311,6 @@
|
||||||
* we now have the functionality and features of all three systems combined.
|
* we now have the functionality and features of all three systems combined.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define USE_NOZZLE_AS_REFERENCE 0
|
|
||||||
#define USE_PROBE_AS_REFERENCE 1
|
|
||||||
|
|
||||||
// The simple parameter flags and values are 'static' so parameter parsing can be in a support routine.
|
// The simple parameter flags and values are 'static' so parameter parsing can be in a support routine.
|
||||||
static int g29_verbose_level, phase_value, repetition_cnt,
|
static int g29_verbose_level, phase_value, repetition_cnt,
|
||||||
storage_slot = 0, map_type, grid_size;
|
storage_slot = 0, map_type, grid_size;
|
||||||
|
|
Reference in a new issue