|
@ -470,8 +470,14 @@ uint16_t max_display_update_time = 0; |
|
|
screen_history_depth = 0; |
|
|
screen_history_depth = 0; |
|
|
} |
|
|
} |
|
|
lcd_implementation_clear(); |
|
|
lcd_implementation_clear(); |
|
|
|
|
|
// Re-initialize custom characters that may be re-used
|
|
|
|
|
|
#if DISABLED(DOGLCD) && ENABLED(AUTO_BED_LEVELING_UBL) |
|
|
|
|
|
if (!ubl_lcd_map_control) lcd_set_custom_characters( |
|
|
#if ENABLED(LCD_PROGRESS_BAR) |
|
|
#if ENABLED(LCD_PROGRESS_BAR) |
|
|
// For LCD_PROGRESS_BAR re-initialize custom characters
|
|
|
screen == lcd_status_screen |
|
|
|
|
|
#endif |
|
|
|
|
|
); |
|
|
|
|
|
#elif ENABLED(LCD_PROGRESS_BAR) |
|
|
lcd_set_custom_characters(screen == lcd_status_screen); |
|
|
lcd_set_custom_characters(screen == lcd_status_screen); |
|
|
#endif |
|
|
#endif |
|
|
lcdDrawUpdate = LCDVIEW_CALL_REDRAW_NEXT; |
|
|
lcdDrawUpdate = LCDVIEW_CALL_REDRAW_NEXT; |
|
@ -547,15 +553,6 @@ uint16_t max_display_update_time = 0; |
|
|
|
|
|
|
|
|
void lcd_status_screen() { |
|
|
void lcd_status_screen() { |
|
|
|
|
|
|
|
|
#if DISABLED(DOGLCD) && ENABLED(AUTO_BED_LEVELING_UBL) |
|
|
|
|
|
if(!ubl_lcd_map_control) |
|
|
|
|
|
lcd_set_custom_characters( |
|
|
|
|
|
#if ENABLED(LCD_PROGRESS_BAR) |
|
|
|
|
|
const bool info_screen_charset = true |
|
|
|
|
|
#endif |
|
|
|
|
|
); |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(ULTIPANEL) |
|
|
#if ENABLED(ULTIPANEL) |
|
|
ENCODER_DIRECTION_NORMAL(); |
|
|
ENCODER_DIRECTION_NORMAL(); |
|
|
ENCODER_RATE_MULTIPLY(false); |
|
|
ENCODER_RATE_MULTIPLY(false); |
|
@ -2151,6 +2148,7 @@ void kill_screen(const char* lcd_msg) { |
|
|
void _lcd_ubl_output_map_lcd(); |
|
|
void _lcd_ubl_output_map_lcd(); |
|
|
|
|
|
|
|
|
void _lcd_ubl_map_homing() { |
|
|
void _lcd_ubl_map_homing() { |
|
|
|
|
|
defer_return_to_status = true; |
|
|
if (lcdDrawUpdate) lcd_implementation_drawedit(PSTR(MSG_LEVEL_BED_HOMING), NULL); |
|
|
if (lcdDrawUpdate) lcd_implementation_drawedit(PSTR(MSG_LEVEL_BED_HOMING), NULL); |
|
|
lcdDrawUpdate = LCDVIEW_CALL_NO_REDRAW; |
|
|
lcdDrawUpdate = LCDVIEW_CALL_NO_REDRAW; |
|
|
if (axis_homed[X_AXIS] && axis_homed[Y_AXIS] && axis_homed[Z_AXIS]) { |
|
|
if (axis_homed[X_AXIS] && axis_homed[Y_AXIS] && axis_homed[Z_AXIS]) { |
|
@ -2260,7 +2258,7 @@ void kill_screen(const char* lcd_msg) { |
|
|
* UBL Homing before LCD map |
|
|
* UBL Homing before LCD map |
|
|
*/ |
|
|
*/ |
|
|
void _lcd_ubl_output_map_lcd_cmd() { |
|
|
void _lcd_ubl_output_map_lcd_cmd() { |
|
|
ubl_lcd_map_control = true; // Used for returning to the map screen
|
|
|
ubl_lcd_map_control = true; // Return to the map screen (and don't restore the character set)
|
|
|
if (!(axis_known_position[X_AXIS] && axis_known_position[Y_AXIS] && axis_known_position[Z_AXIS])) |
|
|
if (!(axis_known_position[X_AXIS] && axis_known_position[Y_AXIS] && axis_known_position[Z_AXIS])) |
|
|
enqueue_and_echo_commands_P(PSTR("G28")); |
|
|
enqueue_and_echo_commands_P(PSTR("G28")); |
|
|
lcd_goto_screen(_lcd_ubl_map_homing); |
|
|
lcd_goto_screen(_lcd_ubl_map_homing); |
|
|