Print/display ABL current probe point (#14788)
This commit is contained in:
parent
3765e67434
commit
f59a7e8b07
|
@ -752,17 +752,19 @@
|
||||||
save_ubl_active_state_and_disable(); // No bed level correction so only raw data is obtained
|
save_ubl_active_state_and_disable(); // No bed level correction so only raw data is obtained
|
||||||
DEPLOY_PROBE();
|
DEPLOY_PROBE();
|
||||||
|
|
||||||
uint16_t count = GRID_MAX_POINTS, current = 1;
|
uint8_t count = GRID_MAX_POINTS, current = 1;
|
||||||
|
|
||||||
do {
|
do {
|
||||||
current = (GRID_MAX_POINTS) - count + 1;
|
current = (GRID_MAX_POINTS) - count + 1;
|
||||||
|
|
||||||
if (do_ubl_mesh_map) display_map(g29_map_type);
|
if (do_ubl_mesh_map) display_map(g29_map_type);
|
||||||
|
|
||||||
SERIAL_ECHOLNPAIR("\nProbing mesh point ", current, "/", GRID_MAX_POINTS, ".\n");
|
SERIAL_ECHOLNPAIR("\nProbing mesh point ", int(current), "/", int(GRID_MAX_POINTS), ".\n");
|
||||||
#if HAS_LCD_MENU
|
#if HAS_DISPLAY
|
||||||
ui.status_printf_P(0, PSTR(MSG_LCD_PROBING_MESH " %i/%i"), current, int(GRID_MAX_POINTS));
|
ui.status_printf_P(0, PSTR(MSG_PROBING_MESH " %i/%i"), int(current), int(GRID_MAX_POINTS));
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if HAS_LCD_MENU
|
||||||
if (ui.button_pressed()) {
|
if (ui.button_pressed()) {
|
||||||
ui.quick_feedback(false); // Preserve button state for click-and-hold
|
ui.quick_feedback(false); // Preserve button state for click-and-hold
|
||||||
SERIAL_ECHOLNPGM("\nMesh only partially populated.\n");
|
SERIAL_ECHOLNPGM("\nMesh only partially populated.\n");
|
||||||
|
@ -1405,7 +1407,7 @@
|
||||||
|
|
||||||
if (do_3_pt_leveling) {
|
if (do_3_pt_leveling) {
|
||||||
SERIAL_ECHOLNPGM("Tilting mesh (1/3)");
|
SERIAL_ECHOLNPGM("Tilting mesh (1/3)");
|
||||||
#if HAS_LCD_MENU
|
#if HAS_DISPLAY
|
||||||
ui.status_printf_P(0, PSTR(MSG_LCD_TILTING_MESH " 1/3"));
|
ui.status_printf_P(0, PSTR(MSG_LCD_TILTING_MESH " 1/3"));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -1424,7 +1426,7 @@
|
||||||
|
|
||||||
if (!abort_flag) {
|
if (!abort_flag) {
|
||||||
SERIAL_ECHOLNPGM("Tilting mesh (2/3)");
|
SERIAL_ECHOLNPGM("Tilting mesh (2/3)");
|
||||||
#if HAS_LCD_MENU
|
#if HAS_DISPLAY
|
||||||
ui.status_printf_P(0, PSTR(MSG_LCD_TILTING_MESH " 2/3"));
|
ui.status_printf_P(0, PSTR(MSG_LCD_TILTING_MESH " 2/3"));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -1444,7 +1446,7 @@
|
||||||
|
|
||||||
if (!abort_flag) {
|
if (!abort_flag) {
|
||||||
SERIAL_ECHOLNPGM("Tilting mesh (3/3)");
|
SERIAL_ECHOLNPGM("Tilting mesh (3/3)");
|
||||||
#if HAS_LCD_MENU
|
#if HAS_DISPLAY
|
||||||
ui.status_printf_P(0, PSTR(MSG_LCD_TILTING_MESH " 3/3"));
|
ui.status_printf_P(0, PSTR(MSG_LCD_TILTING_MESH " 3/3"));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -1485,7 +1487,7 @@
|
||||||
|
|
||||||
if (!abort_flag) {
|
if (!abort_flag) {
|
||||||
SERIAL_ECHOLNPAIR("Tilting mesh point ", current, "/", total_points, "\n");
|
SERIAL_ECHOLNPAIR("Tilting mesh point ", current, "/", total_points, "\n");
|
||||||
#if HAS_LCD_MENU
|
#if HAS_DISPLAY
|
||||||
ui.status_printf_P(0, PSTR(MSG_LCD_TILTING_MESH " %i/%i"), current, total_points);
|
ui.status_printf_P(0, PSTR(MSG_LCD_TILTING_MESH " %i/%i"), current, total_points);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -36,7 +36,7 @@
|
||||||
#include "../../../module/probe.h"
|
#include "../../../module/probe.h"
|
||||||
#include "../../queue.h"
|
#include "../../queue.h"
|
||||||
|
|
||||||
#if BOTH(LCD_BED_LEVELING, PROBE_MANUALLY)
|
#if HAS_DISPLAY
|
||||||
#include "../../../lcd/ultralcd.h"
|
#include "../../../lcd/ultralcd.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -254,8 +254,8 @@ G29_TYPE GcodeSuite::G29() {
|
||||||
|
|
||||||
ABL_VAR int indexIntoAB[GRID_MAX_POINTS_X][GRID_MAX_POINTS_Y];
|
ABL_VAR int indexIntoAB[GRID_MAX_POINTS_X][GRID_MAX_POINTS_Y];
|
||||||
|
|
||||||
ABL_VAR float eqnAMatrix[GRID_MAX_POINTS * 3], // "A" matrix of the linear system of equations
|
ABL_VAR float eqnAMatrix[(GRID_MAX_POINTS) * 3], // "A" matrix of the linear system of equations
|
||||||
eqnBVector[GRID_MAX_POINTS], // "B" vector of Z points
|
eqnBVector[GRID_MAX_POINTS], // "B" vector of Z points
|
||||||
mean;
|
mean;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -311,8 +311,7 @@ G29_TYPE GcodeSuite::G29() {
|
||||||
|
|
||||||
const float rx = RAW_X_POSITION(parser.linearval('X', NAN)),
|
const float rx = RAW_X_POSITION(parser.linearval('X', NAN)),
|
||||||
ry = RAW_Y_POSITION(parser.linearval('Y', NAN));
|
ry = RAW_Y_POSITION(parser.linearval('Y', NAN));
|
||||||
int8_t i = parser.byteval('I', -1),
|
int8_t i = parser.byteval('I', -1), j = parser.byteval('J', -1);
|
||||||
j = parser.byteval('J', -1);
|
|
||||||
|
|
||||||
if (!isnan(rx) && !isnan(ry)) {
|
if (!isnan(rx) && !isnan(ry)) {
|
||||||
// Get nearest i / j from rx / ry
|
// Get nearest i / j from rx / ry
|
||||||
|
@ -689,8 +688,11 @@ G29_TYPE GcodeSuite::G29() {
|
||||||
|
|
||||||
zig ^= true; // zag
|
zig ^= true; // zag
|
||||||
|
|
||||||
|
// An index to print current state
|
||||||
|
uint8_t pt_index = (PR_OUTER_VAR) * (PR_INNER_END) + 1;
|
||||||
|
|
||||||
// Inner loop is Y with PROBE_Y_FIRST enabled
|
// Inner loop is Y with PROBE_Y_FIRST enabled
|
||||||
for (int8_t PR_INNER_VAR = inStart; PR_INNER_VAR != inStop; PR_INNER_VAR += inInc) {
|
for (int8_t PR_INNER_VAR = inStart; PR_INNER_VAR != inStop; pt_index++, PR_INNER_VAR += inInc) {
|
||||||
|
|
||||||
const float xBase = left_probe_bed_position + xGridSpacing * xCount,
|
const float xBase = left_probe_bed_position + xGridSpacing * xCount,
|
||||||
yBase = front_probe_bed_position + yGridSpacing * yCount;
|
yBase = front_probe_bed_position + yGridSpacing * yCount;
|
||||||
|
@ -707,11 +709,16 @@ G29_TYPE GcodeSuite::G29() {
|
||||||
if (!position_is_reachable_by_probe(xProbe, yProbe)) continue;
|
if (!position_is_reachable_by_probe(xProbe, yProbe)) continue;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
if (verbose_level) SERIAL_ECHOLNPAIR("Probing mesh point ", int(pt_index), "/", int(GRID_MAX_POINTS), ".");
|
||||||
|
#if HAS_DISPLAY
|
||||||
|
ui.status_printf_P(0, PSTR(MSG_PROBING_MESH " %i/%i"), int(pt_index), int(GRID_MAX_POINTS));
|
||||||
|
#endif
|
||||||
|
|
||||||
measured_z = faux ? 0.001 * random(-100, 101) : probe_pt(xProbe, yProbe, raise_after, verbose_level);
|
measured_z = faux ? 0.001 * random(-100, 101) : probe_pt(xProbe, yProbe, raise_after, verbose_level);
|
||||||
|
|
||||||
if (isnan(measured_z)) {
|
if (isnan(measured_z)) {
|
||||||
set_bed_leveling_enabled(abl_should_enable);
|
set_bed_leveling_enabled(abl_should_enable);
|
||||||
break;
|
break; // Breaks out of both loops
|
||||||
}
|
}
|
||||||
|
|
||||||
#if ENABLED(AUTO_BED_LEVELING_LINEAR)
|
#if ENABLED(AUTO_BED_LEVELING_LINEAR)
|
||||||
|
@ -744,6 +751,11 @@ G29_TYPE GcodeSuite::G29() {
|
||||||
// Probe at 3 arbitrary points
|
// Probe at 3 arbitrary points
|
||||||
|
|
||||||
for (uint8_t i = 0; i < 3; ++i) {
|
for (uint8_t i = 0; i < 3; ++i) {
|
||||||
|
if (verbose_level) SERIAL_ECHOLNPAIR("Probing point ", int(i), "/3.");
|
||||||
|
#if HAS_DISPLAY
|
||||||
|
ui.status_printf_P(0, PSTR(MSG_PROBING_MESH " %i/3"), int(i));
|
||||||
|
#endif
|
||||||
|
|
||||||
// Retain the last probe position
|
// Retain the last probe position
|
||||||
xProbe = points[i].x;
|
xProbe = points[i].x;
|
||||||
yProbe = points[i].y;
|
yProbe = points[i].y;
|
||||||
|
@ -770,6 +782,10 @@ G29_TYPE GcodeSuite::G29() {
|
||||||
|
|
||||||
#endif // AUTO_BED_LEVELING_3POINT
|
#endif // AUTO_BED_LEVELING_3POINT
|
||||||
|
|
||||||
|
#if HAS_DISPLAY
|
||||||
|
ui.reset_status();
|
||||||
|
#endif
|
||||||
|
|
||||||
// Stow the probe. No raise for FIX_MOUNTED_PROBE.
|
// Stow the probe. No raise for FIX_MOUNTED_PROBE.
|
||||||
if (STOW_PROBE()) {
|
if (STOW_PROBE()) {
|
||||||
set_bed_leveling_enabled(abl_should_enable);
|
set_bed_leveling_enabled(abl_should_enable);
|
||||||
|
|
|
@ -95,6 +95,7 @@
|
||||||
#define MSG_LEVEL_CORNERS _UxGT("Ecken nivellieren")
|
#define MSG_LEVEL_CORNERS _UxGT("Ecken nivellieren")
|
||||||
#define MSG_NEXT_CORNER _UxGT("Nächste Ecke")
|
#define MSG_NEXT_CORNER _UxGT("Nächste Ecke")
|
||||||
#define MSG_EDITING_STOPPED _UxGT("Netzbearb. angeh.")
|
#define MSG_EDITING_STOPPED _UxGT("Netzbearb. angeh.")
|
||||||
|
#define MSG_PROBING_MESH _UxGT("Messpunkt")
|
||||||
#define MSG_MESH_X _UxGT("Index X")
|
#define MSG_MESH_X _UxGT("Index X")
|
||||||
#define MSG_MESH_Y _UxGT("Index Y")
|
#define MSG_MESH_Y _UxGT("Index Y")
|
||||||
#define MSG_MESH_EDIT_Z _UxGT("Z-Wert")
|
#define MSG_MESH_EDIT_Z _UxGT("Z-Wert")
|
||||||
|
@ -103,7 +104,6 @@
|
||||||
#define MSG_UBL_UNHOMED _UxGT("Home XYZ zuerst")
|
#define MSG_UBL_UNHOMED _UxGT("Home XYZ zuerst")
|
||||||
#define MSG_UBL_TOOLS _UxGT("UBL-Werkzeuge")
|
#define MSG_UBL_TOOLS _UxGT("UBL-Werkzeuge")
|
||||||
#define MSG_UBL_LEVEL_BED _UxGT("Unified Bed Leveling")
|
#define MSG_UBL_LEVEL_BED _UxGT("Unified Bed Leveling")
|
||||||
#define MSG_LCD_PROBING_MESH _UxGT("Messpunkt")
|
|
||||||
#define MSG_LCD_TILTING_MESH _UxGT("Berührungspunkt")
|
#define MSG_LCD_TILTING_MESH _UxGT("Berührungspunkt")
|
||||||
#define MSG_IDEX_MENU _UxGT("IDEX-Modus")
|
#define MSG_IDEX_MENU _UxGT("IDEX-Modus")
|
||||||
#define MSG_OFFSETS_MENU _UxGT("Werkzeugversätze")
|
#define MSG_OFFSETS_MENU _UxGT("Werkzeugversätze")
|
||||||
|
|
|
@ -235,6 +235,9 @@
|
||||||
#ifndef MSG_EDITING_STOPPED
|
#ifndef MSG_EDITING_STOPPED
|
||||||
#define MSG_EDITING_STOPPED _UxGT("Mesh Editing Stopped")
|
#define MSG_EDITING_STOPPED _UxGT("Mesh Editing Stopped")
|
||||||
#endif
|
#endif
|
||||||
|
#ifndef MSG_PROBING_MESH
|
||||||
|
#define MSG_PROBING_MESH _UxGT("Probing point")
|
||||||
|
#endif
|
||||||
#ifndef MSG_MESH_X
|
#ifndef MSG_MESH_X
|
||||||
#define MSG_MESH_X _UxGT("Index X")
|
#define MSG_MESH_X _UxGT("Index X")
|
||||||
#endif
|
#endif
|
||||||
|
@ -259,9 +262,6 @@
|
||||||
#ifndef MSG_UBL_LEVEL_BED
|
#ifndef MSG_UBL_LEVEL_BED
|
||||||
#define MSG_UBL_LEVEL_BED _UxGT("Unified Bed Leveling")
|
#define MSG_UBL_LEVEL_BED _UxGT("Unified Bed Leveling")
|
||||||
#endif
|
#endif
|
||||||
#ifndef MSG_LCD_PROBING_MESH
|
|
||||||
#define MSG_LCD_PROBING_MESH _UxGT("Probing point")
|
|
||||||
#endif
|
|
||||||
#ifndef MSG_LCD_TILTING_MESH
|
#ifndef MSG_LCD_TILTING_MESH
|
||||||
#define MSG_LCD_TILTING_MESH _UxGT("Tilting point")
|
#define MSG_LCD_TILTING_MESH _UxGT("Tilting point")
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -90,6 +90,7 @@
|
||||||
#define MSG_LEVEL_CORNERS _UxGT("Niveau coins")
|
#define MSG_LEVEL_CORNERS _UxGT("Niveau coins")
|
||||||
#define MSG_NEXT_CORNER _UxGT("Coin suivant")
|
#define MSG_NEXT_CORNER _UxGT("Coin suivant")
|
||||||
#define MSG_EDITING_STOPPED _UxGT("Arrêt édit. maillage")
|
#define MSG_EDITING_STOPPED _UxGT("Arrêt édit. maillage")
|
||||||
|
#define MSG_PROBING_MESH _UxGT("Mesure point")
|
||||||
#define MSG_MESH_X _UxGT("Index X")
|
#define MSG_MESH_X _UxGT("Index X")
|
||||||
#define MSG_MESH_Y _UxGT("Index Y")
|
#define MSG_MESH_Y _UxGT("Index Y")
|
||||||
#define MSG_MESH_EDIT_Z _UxGT("Valeur Z")
|
#define MSG_MESH_EDIT_Z _UxGT("Valeur Z")
|
||||||
|
@ -99,7 +100,6 @@
|
||||||
#define MSG_UBL_UNHOMED _UxGT("Origine XYZ requise")
|
#define MSG_UBL_UNHOMED _UxGT("Origine XYZ requise")
|
||||||
#define MSG_UBL_TOOLS _UxGT("Outils UBL")
|
#define MSG_UBL_TOOLS _UxGT("Outils UBL")
|
||||||
#define MSG_UBL_LEVEL_BED _UxGT("Niveau lit unifié")
|
#define MSG_UBL_LEVEL_BED _UxGT("Niveau lit unifié")
|
||||||
#define MSG_LCD_PROBING_MESH _UxGT("Mesure point")
|
|
||||||
#define MSG_LCD_TILTING_MESH _UxGT("Touche point")
|
#define MSG_LCD_TILTING_MESH _UxGT("Touche point")
|
||||||
#define MSG_M48_TEST _UxGT("Ecart sonde Z M48")
|
#define MSG_M48_TEST _UxGT("Ecart sonde Z M48")
|
||||||
#define MSG_M48_DEVIATION _UxGT("Ecart")
|
#define MSG_M48_DEVIATION _UxGT("Ecart")
|
||||||
|
|
|
@ -93,6 +93,7 @@
|
||||||
#define MSG_LEVEL_CORNERS _UxGT("Livella spigoli")
|
#define MSG_LEVEL_CORNERS _UxGT("Livella spigoli")
|
||||||
#define MSG_NEXT_CORNER _UxGT("Prossimo spigolo")
|
#define MSG_NEXT_CORNER _UxGT("Prossimo spigolo")
|
||||||
#define MSG_EDITING_STOPPED _UxGT("Modif. Mesh Fermata")
|
#define MSG_EDITING_STOPPED _UxGT("Modif. Mesh Fermata")
|
||||||
|
#define MSG_PROBING_MESH _UxGT("Punto sondato")
|
||||||
#define MSG_MESH_X _UxGT("Indice X")
|
#define MSG_MESH_X _UxGT("Indice X")
|
||||||
#define MSG_MESH_Y _UxGT("Indice Y")
|
#define MSG_MESH_Y _UxGT("Indice Y")
|
||||||
#define MSG_MESH_EDIT_Z _UxGT("Valore di Z")
|
#define MSG_MESH_EDIT_Z _UxGT("Valore di Z")
|
||||||
|
@ -101,7 +102,6 @@
|
||||||
#define MSG_UBL_UNHOMED _UxGT("Home XYZ prima")
|
#define MSG_UBL_UNHOMED _UxGT("Home XYZ prima")
|
||||||
#define MSG_UBL_TOOLS _UxGT("Strumenti UBL")
|
#define MSG_UBL_TOOLS _UxGT("Strumenti UBL")
|
||||||
#define MSG_UBL_LEVEL_BED _UxGT("Unified Bed Leveling")
|
#define MSG_UBL_LEVEL_BED _UxGT("Unified Bed Leveling")
|
||||||
#define MSG_LCD_PROBING_MESH _UxGT("Punto sondato")
|
|
||||||
#define MSG_LCD_TILTING_MESH _UxGT("Punto inclinaz.")
|
#define MSG_LCD_TILTING_MESH _UxGT("Punto inclinaz.")
|
||||||
#define MSG_M48_TEST _UxGT("Test sonda M48")
|
#define MSG_M48_TEST _UxGT("Test sonda M48")
|
||||||
#define MSG_M48_DEVIATION _UxGT("Deviazione")
|
#define MSG_M48_DEVIATION _UxGT("Deviazione")
|
||||||
|
|
|
@ -101,6 +101,7 @@
|
||||||
#define MSG_LEVEL_CORNERS _UxGT("Vyrovnať rohy")
|
#define MSG_LEVEL_CORNERS _UxGT("Vyrovnať rohy")
|
||||||
#define MSG_NEXT_CORNER _UxGT("Ďalší roh")
|
#define MSG_NEXT_CORNER _UxGT("Ďalší roh")
|
||||||
#define MSG_EDITING_STOPPED _UxGT("Koniec úprav siete")
|
#define MSG_EDITING_STOPPED _UxGT("Koniec úprav siete")
|
||||||
|
#define MSG_PROBING_MESH _UxGT("Skúšam bod")
|
||||||
#define MSG_MESH_X _UxGT("Index X")
|
#define MSG_MESH_X _UxGT("Index X")
|
||||||
#define MSG_MESH_Y _UxGT("Index Y")
|
#define MSG_MESH_Y _UxGT("Index Y")
|
||||||
#define MSG_MESH_EDIT_Z _UxGT("Hodnota Z")
|
#define MSG_MESH_EDIT_Z _UxGT("Hodnota Z")
|
||||||
|
@ -110,7 +111,6 @@
|
||||||
#define MSG_UBL_UNHOMED _UxGT("Prejdite domov")
|
#define MSG_UBL_UNHOMED _UxGT("Prejdite domov")
|
||||||
#define MSG_UBL_TOOLS _UxGT("Nástroje UBL")
|
#define MSG_UBL_TOOLS _UxGT("Nástroje UBL")
|
||||||
#define MSG_UBL_LEVEL_BED _UxGT("UBL rovnanie")
|
#define MSG_UBL_LEVEL_BED _UxGT("UBL rovnanie")
|
||||||
#define MSG_LCD_PROBING_MESH _UxGT("Skúšam bod")
|
|
||||||
#define MSG_LCD_TILTING_MESH _UxGT("Vyrovnávam bod")
|
#define MSG_LCD_TILTING_MESH _UxGT("Vyrovnávam bod")
|
||||||
#define MSG_IDEX_MENU _UxGT("IDEX režim")
|
#define MSG_IDEX_MENU _UxGT("IDEX režim")
|
||||||
#define MSG_OFFSETS_MENU _UxGT("Ofset nástrojov")
|
#define MSG_OFFSETS_MENU _UxGT("Ofset nástrojov")
|
||||||
|
|
Loading…
Reference in a new issue