2017-09-08 22:35:25 +02:00
|
|
|
/**
|
|
|
|
* Marlin 3D Printer Firmware
|
2020-02-03 15:00:57 +01:00
|
|
|
* Copyright (c) 2020 MarlinFirmware [https://github.com/MarlinFirmware/Marlin]
|
2017-09-08 22:35:25 +02:00
|
|
|
*
|
|
|
|
* Based on Sprinter and grbl.
|
2019-06-28 06:57:50 +02:00
|
|
|
* Copyright (c) 2011 Camiel Gubbels / Erik van der Zalm
|
2017-09-08 22:35:25 +02:00
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
2020-07-23 05:20:14 +02:00
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
2017-09-08 22:35:25 +02:00
|
|
|
*
|
|
|
|
*/
|
2018-11-04 09:25:55 +01:00
|
|
|
#pragma once
|
2017-09-08 22:35:25 +02:00
|
|
|
|
2017-11-24 00:59:43 +01:00
|
|
|
#include "../../inc/MarlinConfigPre.h"
|
2017-09-08 22:35:25 +02:00
|
|
|
|
2021-01-17 06:08:48 +01:00
|
|
|
#if EITHER(RESTORE_LEVELING_AFTER_G28, ENABLE_LEVELING_AFTER_G28)
|
|
|
|
#define G28_L0_ENSURES_LEVELING_OFF 1
|
|
|
|
#endif
|
|
|
|
|
2017-09-08 22:35:25 +02:00
|
|
|
#if ENABLED(PROBE_MANUALLY)
|
|
|
|
extern bool g29_in_progress;
|
|
|
|
#else
|
|
|
|
constexpr bool g29_in_progress = false;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
bool leveling_is_valid();
|
|
|
|
void set_bed_leveling_enabled(const bool enable=true);
|
|
|
|
void reset_bed_level();
|
|
|
|
|
|
|
|
#if ENABLED(ENABLE_LEVELING_FADE_HEIGHT)
|
2021-04-02 00:59:57 +02:00
|
|
|
void set_z_fade_height(const_float_t zfh, const bool do_report=true);
|
2017-09-08 22:35:25 +02:00
|
|
|
#endif
|
|
|
|
|
2019-03-18 22:31:11 +01:00
|
|
|
#if EITHER(MESH_BED_LEVELING, PROBE_MANUALLY)
|
2019-09-29 11:25:39 +02:00
|
|
|
void _manual_goto_xy(const xy_pos_t &pos);
|
2019-03-18 22:31:11 +01:00
|
|
|
#endif
|
2017-09-08 22:35:25 +02:00
|
|
|
|
2019-07-17 10:41:04 +02:00
|
|
|
/**
|
|
|
|
* 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); }
|
|
|
|
};
|
2019-09-14 10:05:10 +02:00
|
|
|
#define TEMPORARY_BED_LEVELING_STATE(enable) const TemporaryBedLevelingState tbls(enable)
|
2019-07-17 10:41:04 +02:00
|
|
|
|
2019-03-18 22:31:11 +01:00
|
|
|
#if HAS_MESH
|
2017-09-08 22:35:25 +02:00
|
|
|
|
2019-09-18 01:16:28 +02:00
|
|
|
typedef float bed_mesh_t[GRID_MAX_POINTS_X][GRID_MAX_POINTS_Y];
|
|
|
|
|
2019-03-18 22:31:11 +01:00
|
|
|
#if ENABLED(AUTO_BED_LEVELING_BILINEAR)
|
|
|
|
#include "abl/abl.h"
|
|
|
|
#elif ENABLED(AUTO_BED_LEVELING_UBL)
|
|
|
|
#include "ubl/ubl.h"
|
|
|
|
#elif ENABLED(MESH_BED_LEVELING)
|
|
|
|
#include "mbl/mesh_bed_leveling.h"
|
|
|
|
#endif
|
2017-09-08 22:35:25 +02:00
|
|
|
|
2019-03-18 22:31:11 +01:00
|
|
|
#define Z_VALUES(X,Y) Z_VALUES_ARR[X][Y]
|
2019-09-29 11:25:39 +02:00
|
|
|
#define _GET_MESH_POS(M) { _GET_MESH_X(M.a), _GET_MESH_Y(M.b) }
|
2017-09-08 22:35:25 +02:00
|
|
|
|
2019-03-18 22:31:11 +01:00
|
|
|
#if EITHER(AUTO_BED_LEVELING_BILINEAR, MESH_BED_LEVELING)
|
2017-09-08 22:35:25 +02:00
|
|
|
|
2019-03-18 22:31:11 +01:00
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
typedef float (*element_2d_fn)(const uint8_t, const uint8_t);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Print calibration results for plotting or manual frame adjustment.
|
|
|
|
*/
|
|
|
|
void print_2d_array(const uint8_t sx, const uint8_t sy, const uint8_t precision, element_2d_fn fn);
|
|
|
|
|
|
|
|
#endif
|
2017-11-24 00:59:43 +01:00
|
|
|
|
2019-09-29 11:25:39 +02:00
|
|
|
struct mesh_index_pair {
|
|
|
|
xy_int8_t pos;
|
|
|
|
float distance; // When populated, the distance from the search location
|
|
|
|
void invalidate() { pos = -1; }
|
|
|
|
bool valid() const { return pos.x >= 0 && pos.y >= 0; }
|
|
|
|
#if ENABLED(AUTO_BED_LEVELING_UBL)
|
|
|
|
xy_pos_t meshpos() {
|
|
|
|
return { ubl.mesh_index_to_xpos(pos.x), ubl.mesh_index_to_ypos(pos.y) };
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
operator xy_int8_t&() { return pos; }
|
|
|
|
operator const xy_int8_t&() const { return pos; }
|
|
|
|
};
|
|
|
|
|
2017-11-24 00:59:43 +01:00
|
|
|
#endif
|