From 57e51e0d7d15d406920a6bf5d67d9d97ba7c75b4 Mon Sep 17 00:00:00 2001 From: InsanityAutomation Date: Sat, 12 Jan 2019 19:00:23 -0500 Subject: [PATCH] Bump --- Marlin/src/gcode/feature/pause/M125.cpp | 19 +++++++++++++++---- Marlin/src/lcd/menu/menu_main.cpp | 22 ++++++++++++---------- 2 files changed, 27 insertions(+), 14 deletions(-) diff --git a/Marlin/src/gcode/feature/pause/M125.cpp b/Marlin/src/gcode/feature/pause/M125.cpp index 5794f6af33..6bb1b72fa5 100644 --- a/Marlin/src/gcode/feature/pause/M125.cpp +++ b/Marlin/src/gcode/feature/pause/M125.cpp @@ -31,6 +31,10 @@ #include "../../../sd/cardreader.h" #include "../../../module/printcounter.h" +#if HAS_LCD_MENU + #include "../../../lcd/ultralcd.h" +#endif + /** * M125: Store current position and move to filament change position. * Called on pause (by M25) to prevent material leaking onto the @@ -74,10 +78,17 @@ void GcodeSuite::M125() { constexpr bool sd_printing = false; #endif - if (pause_print(retract, park_point)) { - if (!sd_printing) { - wait_for_confirmation(); - resume_print(); + #if HAS_LCD_MENU + const bool show_lcd = parser.seenval('P'); + lcd_advanced_pause_show_message(ADVANCED_PAUSE_MESSAGE_INIT, ADVANCED_PAUSE_MODE_PAUSE_PRINT, active_extruder); + #else + constexpr bool show_lcd = false; + #endif + + if (pause_print(retract, park_point, 0, show_lcd)) { + if (!sd_printing || show_lcd ) { + wait_for_confirmation(false, 0); + resume_print(0, 0, PAUSE_PARK_RETRACT_LENGTH, 0); } } } diff --git a/Marlin/src/lcd/menu/menu_main.cpp b/Marlin/src/lcd/menu/menu_main.cpp index 1e05de5a7a..c871d71d13 100644 --- a/Marlin/src/lcd/menu/menu_main.cpp +++ b/Marlin/src/lcd/menu/menu_main.cpp @@ -32,6 +32,7 @@ #include "../../module/temperature.h" #include "../../gcode/queue.h" #include "../../module/printcounter.h" +#include "../../module/stepper.h" #if ENABLED(POWER_LOSS_RECOVERY) #include "../../feature/power_loss_recovery.h" @@ -43,16 +44,14 @@ void lcd_pause() { #endif #if ENABLED(PARK_HEAD_ON_PAUSE) - if (pause_print(PAUSE_PARK_RETRACT_LENGTH, NOZZLE_PARK_POINT, 0, true)) { - wait_for_confirmation(false, 0); - resume_print(0, 0, ADVANCED_PAUSE_PURGE_LENGTH, 0); - ui.return_to_status(); - } + enqueue_and_echo_commands_P(PSTR("M25 P")); #elif ENABLED(SDSUPPORT) enqueue_and_echo_commands_P(PSTR("M25")); #elif defined(ACTION_ON_PAUSE) SERIAL_ECHOLNPGM("//action:" ACTION_ON_PAUSE); #endif + ui.return_to_status(); + planner.synchronize(); } void lcd_resume() { @@ -101,14 +100,15 @@ void menu_main() { if (busy) { MENU_ITEM(function, MSG_PAUSE_PRINT, lcd_pause); - MENU_ITEM(submenu, MSG_TUNE, menu_tune); - } - else { - MENU_ITEM(function, MSG_RESUME_PRINT, lcd_resume); #if ENABLED(SDSUPPORT) if (card.isFileOpen()) MENU_ITEM(submenu, MSG_STOP_PRINT, menu_sdcard_abort_confirm); #endif + MENU_ITEM(submenu, MSG_TUNE, menu_tune); + } + else { + MENU_ITEM(function, MSG_RESUME_PRINT, lcd_resume); + MENU_ITEM(submenu, MSG_MOTION, menu_motion); MENU_ITEM(submenu, MSG_TEMPERATURE, menu_temperature); } @@ -157,11 +157,13 @@ void menu_main() { #endif #if ENABLED(SDSUPPORT) - if (card.isDetected() && !card.isFileOpen()) { + if (card.isDetected()) { + if(!card.isFileOpen()) { MENU_ITEM(submenu, MSG_CARD_MENU, menu_sdcard); #if !PIN_EXISTS(SD_DETECT) MENU_ITEM(gcode, MSG_CHANGE_SDCARD, PSTR("M21")); // SD-card changed by user #endif + } } else { MENU_ITEM(function, MSG_NO_CARD, NULL);