|
@ -658,12 +658,11 @@ void Planner::check_axes_activity() { |
|
|
rx = dx + X_TILT_FULCRUM; |
|
|
rx = dx + X_TILT_FULCRUM; |
|
|
ry = dy + Y_TILT_FULCRUM; |
|
|
ry = dy + Y_TILT_FULCRUM; |
|
|
|
|
|
|
|
|
#else |
|
|
#elif HAS_MESH |
|
|
|
|
|
|
|
|
#if ENABLED(ENABLE_LEVELING_FADE_HEIGHT) |
|
|
#if ENABLED(ENABLE_LEVELING_FADE_HEIGHT) |
|
|
const float fade_scaling_factor = fade_scaling_factor_for_z(rz); |
|
|
const float fade_scaling_factor = fade_scaling_factor_for_z(rz); |
|
|
if (!fade_scaling_factor) return; |
|
|
#else |
|
|
#elif HAS_MESH |
|
|
|
|
|
constexpr float fade_scaling_factor = 1.0; |
|
|
constexpr float fade_scaling_factor = 1.0; |
|
|
#endif |
|
|
#endif |
|
|
|
|
|
|
|
@ -672,18 +671,16 @@ void Planner::check_axes_activity() { |
|
|
#endif |
|
|
#endif |
|
|
|
|
|
|
|
|
rz += ( |
|
|
rz += ( |
|
|
#if ENABLED(AUTO_BED_LEVELING_UBL) |
|
|
#if ENABLED(MESH_BED_LEVELING) |
|
|
ubl.get_z_correction(rx, ry) * fade_scaling_factor |
|
|
|
|
|
#elif ENABLED(MESH_BED_LEVELING) |
|
|
|
|
|
mbl.get_z(rx, ry |
|
|
mbl.get_z(rx, ry |
|
|
#if ENABLED(ENABLE_LEVELING_FADE_HEIGHT) |
|
|
#if ENABLED(ENABLE_LEVELING_FADE_HEIGHT) |
|
|
, fade_scaling_factor |
|
|
, fade_scaling_factor |
|
|
#endif |
|
|
#endif |
|
|
) |
|
|
) |
|
|
|
|
|
#elif ENABLED(AUTO_BED_LEVELING_UBL) |
|
|
|
|
|
fade_scaling_factor ? fade_scaling_factor * ubl.get_z_correction(rx, ry) : 0.0 |
|
|
#elif ENABLED(AUTO_BED_LEVELING_BILINEAR) |
|
|
#elif ENABLED(AUTO_BED_LEVELING_BILINEAR) |
|
|
bilinear_z_offset(raw) * fade_scaling_factor |
|
|
fade_scaling_factor ? fade_scaling_factor * bilinear_z_offset(raw) : 0.0 |
|
|
#else |
|
|
|
|
|
0 |
|
|
|
|
|
#endif |
|
|
#endif |
|
|
); |
|
|
); |
|
|
|
|
|
|
|
@ -692,13 +689,7 @@ void Planner::check_axes_activity() { |
|
|
|
|
|
|
|
|
void Planner::unapply_leveling(float raw[XYZ]) { |
|
|
void Planner::unapply_leveling(float raw[XYZ]) { |
|
|
|
|
|
|
|
|
#if ENABLED(ENABLE_LEVELING_FADE_HEIGHT) |
|
|
if (leveling_active) { |
|
|
const float fade_scaling_factor = fade_scaling_factor_for_z(raw[Z_AXIS]); |
|
|
|
|
|
#else |
|
|
|
|
|
constexpr float fade_scaling_factor = 1.0; |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
if (leveling_active && fade_scaling_factor) { |
|
|
|
|
|
|
|
|
|
|
|
#if ABL_PLANAR |
|
|
#if ABL_PLANAR |
|
|
|
|
|
|
|
@ -712,25 +703,29 @@ void Planner::check_axes_activity() { |
|
|
raw[X_AXIS] = dx + X_TILT_FULCRUM; |
|
|
raw[X_AXIS] = dx + X_TILT_FULCRUM; |
|
|
raw[Y_AXIS] = dy + Y_TILT_FULCRUM; |
|
|
raw[Y_AXIS] = dy + Y_TILT_FULCRUM; |
|
|
|
|
|
|
|
|
#else // !ABL_PLANAR
|
|
|
#elif HAS_MESH |
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(ENABLE_LEVELING_FADE_HEIGHT) |
|
|
|
|
|
const float fade_scaling_factor = fade_scaling_factor_for_z(raw[Z_AXIS]); |
|
|
|
|
|
#else |
|
|
|
|
|
constexpr float fade_scaling_factor = 1.0; |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
raw[Z_AXIS] -= ( |
|
|
raw[Z_AXIS] -= ( |
|
|
#if ENABLED(AUTO_BED_LEVELING_UBL) |
|
|
#if ENABLED(MESH_BED_LEVELING) |
|
|
ubl.get_z_correction(raw[X_AXIS], raw[Y_AXIS]) * fade_scaling_factor |
|
|
|
|
|
#elif ENABLED(MESH_BED_LEVELING) |
|
|
|
|
|
mbl.get_z(raw[X_AXIS], raw[Y_AXIS] |
|
|
mbl.get_z(raw[X_AXIS], raw[Y_AXIS] |
|
|
#if ENABLED(ENABLE_LEVELING_FADE_HEIGHT) |
|
|
#if ENABLED(ENABLE_LEVELING_FADE_HEIGHT) |
|
|
, fade_scaling_factor |
|
|
, fade_scaling_factor |
|
|
#endif |
|
|
#endif |
|
|
) |
|
|
) |
|
|
|
|
|
#elif ENABLED(AUTO_BED_LEVELING_UBL) |
|
|
|
|
|
fade_scaling_factor ? fade_scaling_factor * ubl.get_z_correction(raw[X_AXIS], raw[Y_AXIS]) : 0.0 |
|
|
#elif ENABLED(AUTO_BED_LEVELING_BILINEAR) |
|
|
#elif ENABLED(AUTO_BED_LEVELING_BILINEAR) |
|
|
bilinear_z_offset(raw) * fade_scaling_factor |
|
|
fade_scaling_factor ? fade_scaling_factor * bilinear_z_offset(raw) : 0.0 |
|
|
#else |
|
|
|
|
|
0 |
|
|
|
|
|
#endif |
|
|
#endif |
|
|
); |
|
|
); |
|
|
|
|
|
|
|
|
#endif // !ABL_PLANAR
|
|
|
#endif |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
#if ENABLED(SKEW_CORRECTION) |
|
|
#if ENABLED(SKEW_CORRECTION) |
|
|