Skip to content

Commit

Permalink
🚸 Use Tool 0 for G30 (#24511)
Browse files Browse the repository at this point in the history
  • Loading branch information
InsanityAutomation authored Jul 19, 2022
1 parent 57700b4 commit 258904e
Showing 1 changed file with 43 additions and 31 deletions.
74 changes: 43 additions & 31 deletions Marlin/src/gcode/probe/G30.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,10 @@
#include "../../feature/probe_temp_comp.h"
#endif

#if HAS_MULTI_HOTEND
#include "../../module/tool_change.h"
#endif

#if ENABLED(DWIN_LCD_PROUI)
#include "../../lcd/marlinui.h"
#endif
Expand All @@ -49,6 +53,11 @@
*/
void GcodeSuite::G30() {

#if HAS_MULTI_HOTEND
const uint8_t old_tool_index = active_extruder;
tool_change(0);
#endif

const xy_pos_t pos = { parser.linearval('X', current_position.x + probe.offset_xy.x),
parser.linearval('Y', current_position.y + probe.offset_xy.y) };

Expand All @@ -57,40 +66,43 @@ void GcodeSuite::G30() {
SERIAL_ECHOLNF(GET_EN_TEXT_F(MSG_ZPROBE_OUT));
LCD_MESSAGE(MSG_ZPROBE_OUT);
#endif
return;
}

// Disable leveling so the planner won't mess with us
TERN_(HAS_LEVELING, set_bed_leveling_enabled(false));

remember_feedrate_scaling_off();

TERN_(DWIN_LCD_PROUI, process_subcommands_now(F("G28O")));

const ProbePtRaise raise_after = parser.boolval('E', true) ? PROBE_PT_STOW : PROBE_PT_NONE;

TERN_(HAS_PTC, ptc.set_enabled(!parser.seen('C') || parser.value_bool()));
const float measured_z = probe.probe_at_point(pos, raise_after, 1);
TERN_(HAS_PTC, ptc.set_enabled(true));
if (!isnan(measured_z)) {
SERIAL_ECHOLNPGM("Bed X: ", pos.x, " Y: ", pos.y, " Z: ", measured_z);
#if ENABLED(DWIN_LCD_PROUI)
char msg[31], str_1[6], str_2[6], str_3[6];
sprintf_P(msg, PSTR("X:%s, Y:%s, Z:%s"),
dtostrf(pos.x, 1, 1, str_1),
dtostrf(pos.y, 1, 1, str_2),
dtostrf(measured_z, 1, 2, str_3)
);
ui.set_status(msg);
#endif
else {
// Disable leveling so the planner won't mess with us
TERN_(HAS_LEVELING, set_bed_leveling_enabled(false));

remember_feedrate_scaling_off();

TERN_(DWIN_LCD_PROUI, process_subcommands_now(F("G28O")));

const ProbePtRaise raise_after = parser.boolval('E', true) ? PROBE_PT_STOW : PROBE_PT_NONE;

TERN_(HAS_PTC, ptc.set_enabled(!parser.seen('C') || parser.value_bool()));
const float measured_z = probe.probe_at_point(pos, raise_after, 1);
TERN_(HAS_PTC, ptc.set_enabled(true));
if (!isnan(measured_z)) {
SERIAL_ECHOLNPGM("Bed X: ", pos.x, " Y: ", pos.y, " Z: ", measured_z);
#if ENABLED(DWIN_LCD_PROUI)
char msg[31], str_1[6], str_2[6], str_3[6];
sprintf_P(msg, PSTR("X:%s, Y:%s, Z:%s"),
dtostrf(pos.x, 1, 1, str_1),
dtostrf(pos.y, 1, 1, str_2),
dtostrf(measured_z, 1, 2, str_3)
);
ui.set_status(msg);
#endif
}

restore_feedrate_and_scaling();

if (raise_after == PROBE_PT_STOW)
probe.move_z_after_probing();

report_current_position();
}

restore_feedrate_and_scaling();

if (raise_after == PROBE_PT_STOW)
probe.move_z_after_probing();

report_current_position();
// Restore the active tool
TERN_(HAS_MULTI_HOTEND, tool_change(old_tool_index));
}

#endif // HAS_BED_PROBE

0 comments on commit 258904e

Please sign in to comment.