[2.0.x] Add NO_LCD_MENUS option (#10582)
This commit is contained in:
		| @@ -72,29 +72,6 @@ | ||||
|   #include "../libs/buzzer.h" | ||||
| #endif | ||||
|  | ||||
| #if ENABLED(AUTO_BED_LEVELING_UBL) || ENABLED(G26_MESH_VALIDATION) | ||||
|   bool lcd_external_control; // = false | ||||
| #endif | ||||
|  | ||||
| // Initialized by settings.load() | ||||
| int16_t lcd_preheat_hotend_temp[2], lcd_preheat_bed_temp[2], lcd_preheat_fan_speed[2]; | ||||
|  | ||||
| #if ENABLED(FILAMENT_LCD_DISPLAY) && ENABLED(SDSUPPORT) | ||||
|   millis_t previous_lcd_status_ms = 0; | ||||
| #endif | ||||
|  | ||||
| #if ENABLED(BABYSTEPPING) | ||||
|   long babysteps_done = 0; | ||||
|   #if ENABLED(BABYSTEP_ZPROBE_OFFSET) | ||||
|     static void lcd_babystep_zoffset(); | ||||
|   #else | ||||
|     static void lcd_babystep_z(); | ||||
|   #endif | ||||
| #endif | ||||
|  | ||||
| uint8_t lcd_status_update_delay = 1, // First update one loop delayed | ||||
|         lcd_status_message_level;    // Higher level blocks lower level | ||||
|  | ||||
| #if ENABLED(STATUS_MESSAGE_SCROLLING) | ||||
|   #if LONG_FILENAME_LENGTH > CHARSIZE * 2 * (LCD_WIDTH) | ||||
|     #define MAX_MESSAGE_LENGTH LONG_FILENAME_LENGTH | ||||
| @@ -107,8 +84,14 @@ uint8_t lcd_status_update_delay = 1, // First update one loop delayed | ||||
| #endif | ||||
|  | ||||
| char lcd_status_message[MAX_MESSAGE_LENGTH + 1]; | ||||
| uint8_t lcd_status_update_delay = 1, // First update one loop delayed | ||||
|         lcd_status_message_level;    // Higher level blocks lower level | ||||
|  | ||||
| #if ENABLED(SCROLL_LONG_FILENAMES) | ||||
| #if ENABLED(FILAMENT_LCD_DISPLAY) && ENABLED(SDSUPPORT) | ||||
|   millis_t previous_lcd_status_ms = 0; | ||||
| #endif | ||||
|  | ||||
| #if ENABLED(ULTIPANEL) && ENABLED(SCROLL_LONG_FILENAMES) | ||||
|   uint8_t filename_scroll_pos, filename_scroll_max, filename_scroll_hash; | ||||
| #endif | ||||
|  | ||||
| @@ -119,11 +102,23 @@ char lcd_status_message[MAX_MESSAGE_LENGTH + 1]; | ||||
| #if ENABLED(DOGLCD) | ||||
|   #include "ultralcd_impl_DOGM.h" | ||||
|   #include <U8glib.h> | ||||
|   bool drawing_screen, // = false | ||||
|        first_page; | ||||
| #else | ||||
|   #include "ultralcd_impl_HD44780.h" | ||||
|   constexpr bool first_page = true; | ||||
| #endif | ||||
|  | ||||
| // The main status screen | ||||
| void lcd_status_screen(); | ||||
|  | ||||
| millis_t next_lcd_update_ms; | ||||
|  | ||||
| uint8_t lcdDrawUpdate = LCDVIEW_CLEAR_CALL_REDRAW; // Set when the LCD needs to draw, decrements after every draw. Set to 2 in LCD routines so the LCD gets at least 1 full redraw (first redraw is partial) | ||||
| uint16_t max_display_update_time = 0; | ||||
|  | ||||
| #if ENABLED(ULTIPANEL) | ||||
|  | ||||
|   #define DEFINE_LCD_IMPLEMENTATION_DRAWMENU_SETTING_EDIT_TYPE(_type, _name, _strFunc) \ | ||||
|     inline void lcd_implementation_drawmenu_setting_edit_ ## _name (const bool sel, const uint8_t row, const char* pstr, const char* pstr2, _type * const data, ...) { \ | ||||
|       UNUSED(pstr2); \ | ||||
| @@ -151,29 +146,6 @@ char lcd_status_message[MAX_MESSAGE_LENGTH + 1]; | ||||
|   #define lcd_implementation_drawmenu_setting_edit_bool(sel, row, pstr, pstr2, data)                    DRAW_BOOL_SETTING(sel, row, pstr, data) | ||||
|   #define lcd_implementation_drawmenu_setting_edit_callback_bool(sel, row, pstr, pstr2, data, callback) DRAW_BOOL_SETTING(sel, row, pstr, data) | ||||
|   #define lcd_implementation_drawmenu_setting_edit_accessor_bool(sel, row, pstr, pstr2, pget, pset)     DRAW_BOOL_SETTING(sel, row, pstr, data) | ||||
| #endif // ULTIPANEL | ||||
|  | ||||
| // The main status screen | ||||
| void lcd_status_screen(); | ||||
|  | ||||
| millis_t next_lcd_update_ms; | ||||
|  | ||||
| uint8_t lcdDrawUpdate = LCDVIEW_CLEAR_CALL_REDRAW; // Set when the LCD needs to draw, decrements after every draw. Set to 2 in LCD routines so the LCD gets at least 1 full redraw (first redraw is partial) | ||||
| uint16_t max_display_update_time = 0; | ||||
|  | ||||
| #if ENABLED(DOGLCD) | ||||
|   bool drawing_screen, // = false | ||||
|        first_page; | ||||
| #else | ||||
|   constexpr bool first_page = true; | ||||
| #endif | ||||
|  | ||||
| #if ENABLED(DAC_STEPPER_CURRENT) | ||||
|   #include "../feature/dac/stepper_dac.h" //was dac_mcp4728.h MarlinMain uses stepper dac for the m-codes | ||||
|   uint8_t driverPercent[XYZE]; | ||||
| #endif | ||||
|  | ||||
| #if ENABLED(ULTIPANEL) | ||||
|  | ||||
|   #ifndef TALL_FONT_CORRECTION | ||||
|     #define TALL_FONT_CORRECTION 0 | ||||
| @@ -182,6 +154,27 @@ uint16_t max_display_update_time = 0; | ||||
|   bool no_reentry = false; | ||||
|   constexpr int8_t menu_bottom = LCD_HEIGHT - (TALL_FONT_CORRECTION); | ||||
|  | ||||
|   // Initialized by settings.load() | ||||
|   int16_t lcd_preheat_hotend_temp[2], lcd_preheat_bed_temp[2], lcd_preheat_fan_speed[2]; | ||||
|  | ||||
|   #if ENABLED(AUTO_BED_LEVELING_UBL) || ENABLED(G26_MESH_VALIDATION) | ||||
|     bool lcd_external_control; // = false | ||||
|   #endif | ||||
|  | ||||
|   #if ENABLED(BABYSTEPPING) | ||||
|     long babysteps_done = 0; | ||||
|     #if ENABLED(BABYSTEP_ZPROBE_OFFSET) | ||||
|       static void lcd_babystep_zoffset(); | ||||
|     #else | ||||
|       static void lcd_babystep_z(); | ||||
|     #endif | ||||
|   #endif | ||||
|  | ||||
|   #if ENABLED(DAC_STEPPER_CURRENT) | ||||
|     #include "../feature/dac/stepper_dac.h" //was dac_mcp4728.h MarlinMain uses stepper dac for the m-codes | ||||
|     uint8_t driverPercent[XYZE]; | ||||
|   #endif | ||||
|  | ||||
|   //////////////////////////////////////////// | ||||
|   ///////////////// Menu Tree //////////////// | ||||
|   //////////////////////////////////////////// | ||||
| @@ -791,36 +784,44 @@ void kill_screen(const char* lcd_msg) { | ||||
|   lcd_kill_screen(); | ||||
| } | ||||
|  | ||||
| #if ENABLED(ULTIPANEL) | ||||
| /** | ||||
|  * | ||||
|  * Audio feedback for controller clicks | ||||
|  * | ||||
|  */ | ||||
| void lcd_buzz(const long duration, const uint16_t freq) { | ||||
|   #if ENABLED(LCD_USE_I2C_BUZZER) | ||||
|     lcd.buzz(duration, freq); | ||||
|   #elif PIN_EXISTS(BEEPER) | ||||
|     buzzer.tone(duration, freq); | ||||
|   #else | ||||
|     UNUSED(duration); UNUSED(freq); | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|   /** | ||||
|    * | ||||
|    * Audio feedback for controller clicks | ||||
|    * | ||||
|    */ | ||||
|   void lcd_buzz(const long duration, const uint16_t freq) { | ||||
|     #if ENABLED(LCD_USE_I2C_BUZZER) | ||||
|       lcd.buzz(duration, freq); | ||||
|     #elif PIN_EXISTS(BEEPER) | ||||
|       buzzer.tone(duration, freq); | ||||
|     #else | ||||
|       UNUSED(duration); UNUSED(freq); | ||||
|     #endif | ||||
|   } | ||||
| void lcd_quick_feedback(const bool clear_buttons) { | ||||
|  | ||||
|   void lcd_quick_feedback(const bool clear_buttons) { | ||||
|   #if ENABLED(ULTIPANEL) | ||||
|     lcd_refresh(); | ||||
|     if (clear_buttons) buttons = 0; | ||||
|     next_button_update_ms = millis() + 500; | ||||
|   #else | ||||
|     UNUSED(clear_buttons); | ||||
|   #endif | ||||
|  | ||||
|     // Buzz and wait. The delay is needed for buttons to settle! | ||||
|     lcd_buzz(LCD_FEEDBACK_FREQUENCY_DURATION_MS, LCD_FEEDBACK_FREQUENCY_HZ); | ||||
|   // Buzz and wait. The delay is needed for buttons to settle! | ||||
|   lcd_buzz(LCD_FEEDBACK_FREQUENCY_DURATION_MS, LCD_FEEDBACK_FREQUENCY_HZ); | ||||
|  | ||||
|   #if ENABLED(ULTIPANEL) | ||||
|     #if ENABLED(LCD_USE_I2C_BUZZER) | ||||
|       delay(10); | ||||
|     #elif PIN_EXISTS(BEEPER) | ||||
|       for (int8_t i = 5; i--;) { buzzer.tick(); delay(2); } | ||||
|     #endif | ||||
|   } | ||||
|   #endif | ||||
| } | ||||
|  | ||||
| #if ENABLED(ULTIPANEL) | ||||
|  | ||||
|   void lcd_completion_feedback(const bool good/*=true*/) { | ||||
|     if (good) { | ||||
| @@ -5243,7 +5244,7 @@ void lcd_update() { | ||||
|       lcdDrawUpdate = LCDVIEW_REDRAW_NOW; | ||||
|     } | ||||
|  | ||||
|     #if ENABLED(SCROLL_LONG_FILENAMES) | ||||
|     #if ENABLED(ULTIPANEL) && ENABLED(SCROLL_LONG_FILENAMES) | ||||
|       // If scrolling of long file names is enabled and we are in the sd card menu, | ||||
|       // cause a refresh to occur until all the text has scrolled into view. | ||||
|       if (currentScreen == lcd_sdcard_menu && filename_scroll_pos < filename_scroll_max && !lcd_status_update_delay--) { | ||||
|   | ||||
| @@ -45,19 +45,6 @@ | ||||
|     #include "../feature/pause.h" | ||||
|   #endif | ||||
|  | ||||
|   #if ENABLED(AUTO_BED_LEVELING_UBL) || ENABLED(G26_MESH_VALIDATION) | ||||
|     extern bool lcd_external_control; | ||||
|   #else | ||||
|     constexpr bool lcd_external_control = false; | ||||
|   #endif | ||||
|  | ||||
|   extern int16_t lcd_preheat_hotend_temp[2], lcd_preheat_bed_temp[2], lcd_preheat_fan_speed[2]; | ||||
|  | ||||
|   #if ENABLED(LCD_BED_LEVELING) | ||||
|     extern bool lcd_wait_for_move; | ||||
|   #else | ||||
|     constexpr bool lcd_wait_for_move = false; | ||||
|   #endif | ||||
|  | ||||
|   bool lcd_hasstatus(); | ||||
|   void lcd_setstatus(const char* message, const bool persist=false); | ||||
| @@ -76,6 +63,8 @@ | ||||
|     void lcd_buzz(const long duration, const uint16_t freq); | ||||
|   #endif | ||||
|  | ||||
|   void lcd_quick_feedback(const bool clear_buttons); // Audible feedback for a button click - could also be visual | ||||
|  | ||||
|   #if ENABLED(LCD_PROGRESS_BAR) && PROGRESS_MSG_EXPIRE > 0 | ||||
|     void dontExpireStatus(); | ||||
|   #endif | ||||
| @@ -109,6 +98,20 @@ | ||||
|     typedef void (*screenFunc_t)(); | ||||
|     typedef void (*menuAction_t)(); | ||||
|  | ||||
|     extern int16_t lcd_preheat_hotend_temp[2], lcd_preheat_bed_temp[2], lcd_preheat_fan_speed[2]; | ||||
|  | ||||
|     #if ENABLED(AUTO_BED_LEVELING_UBL) || ENABLED(G26_MESH_VALIDATION) | ||||
|       extern bool lcd_external_control; | ||||
|     #else | ||||
|       constexpr bool lcd_external_control = false; | ||||
|     #endif | ||||
|  | ||||
|     #if ENABLED(LCD_BED_LEVELING) | ||||
|       extern bool lcd_wait_for_move; | ||||
|     #else | ||||
|       constexpr bool lcd_wait_for_move = false; | ||||
|     #endif | ||||
|  | ||||
|     void lcd_goto_screen(screenFunc_t screen, const uint32_t encoder=0); | ||||
|  | ||||
|     // Encoder click is directly connected | ||||
| @@ -132,7 +135,6 @@ | ||||
|  | ||||
|     extern volatile uint8_t buttons;  // The last-checked buttons in a bit array. | ||||
|     void lcd_buttons_update(); | ||||
|     void lcd_quick_feedback(const bool clear_buttons); // Audible feedback for a button click - could also be visual | ||||
|     void lcd_completion_feedback(const bool good=true); | ||||
|  | ||||
|     #if ENABLED(ADVANCED_PAUSE_FEATURE) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user