|  |  |  | @ -60,6 +60,10 @@ | 
			
		
	
		
			
				
					|  |  |  |  | // Initialized by settings.load()
 | 
			
		
	
		
			
				
					|  |  |  |  | int16_t lcd_preheat_hotend_temp[2], lcd_preheat_bed_temp[2], lcd_preheat_fan_speed[2]; | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  | #if ENABLED(LCD_SET_PROGRESS_MANUALLY) && (ENABLED(LCD_PROGRESS_BAR) || ENABLED(DOGLCD)) | 
			
		
	
		
			
				
					|  |  |  |  |   uint8_t progress_bar_percent; | 
			
		
	
		
			
				
					|  |  |  |  | #endif | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  | #if ENABLED(FILAMENT_LCD_DISPLAY) && ENABLED(SDSUPPORT) | 
			
		
	
		
			
				
					|  |  |  |  |   millis_t previous_lcd_status_ms = 0; | 
			
		
	
		
			
				
					|  |  |  |  | #endif | 
			
		
	
	
		
			
				
					|  |  |  | @ -603,36 +607,52 @@ void lcd_status_screen() { | 
			
		
	
		
			
				
					|  |  |  |  |   #endif | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |   #if ENABLED(LCD_PROGRESS_BAR) | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     //
 | 
			
		
	
		
			
				
					|  |  |  |  |     // HD44780 implements the following message blinking and
 | 
			
		
	
		
			
				
					|  |  |  |  |     // message expiration because Status Line and Progress Bar
 | 
			
		
	
		
			
				
					|  |  |  |  |     // share the same line on the display.
 | 
			
		
	
		
			
				
					|  |  |  |  |     //
 | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // Set current percentage from SD when actively printing
 | 
			
		
	
		
			
				
					|  |  |  |  |     #if ENABLED(LCD_SET_PROGRESS_MANUALLY) | 
			
		
	
		
			
				
					|  |  |  |  |       if (IS_SD_PRINTING) | 
			
		
	
		
			
				
					|  |  |  |  |         progress_bar_percent = card.percentDone(); | 
			
		
	
		
			
				
					|  |  |  |  |     #endif | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     millis_t ms = millis(); | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // If the message will blink rather than expire...
 | 
			
		
	
		
			
				
					|  |  |  |  |     #if DISABLED(PROGRESS_MSG_ONCE) | 
			
		
	
		
			
				
					|  |  |  |  |       if (ELAPSED(ms, progress_bar_ms + PROGRESS_BAR_MSG_TIME + PROGRESS_BAR_BAR_TIME)) { | 
			
		
	
		
			
				
					|  |  |  |  |       if (ELAPSED(ms, progress_bar_ms + PROGRESS_BAR_MSG_TIME + PROGRESS_BAR_BAR_TIME)) | 
			
		
	
		
			
				
					|  |  |  |  |         progress_bar_ms = ms; | 
			
		
	
		
			
				
					|  |  |  |  |       } | 
			
		
	
		
			
				
					|  |  |  |  |     #endif | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     #if PROGRESS_MSG_EXPIRE > 0 | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |       // Handle message expire
 | 
			
		
	
		
			
				
					|  |  |  |  |       if (expire_status_ms > 0) { | 
			
		
	
		
			
				
					|  |  |  |  |         #if ENABLED(SDSUPPORT) | 
			
		
	
		
			
				
					|  |  |  |  |           if (card.isFileOpen()) { | 
			
		
	
		
			
				
					|  |  |  |  |             // Expire the message when printing is active
 | 
			
		
	
		
			
				
					|  |  |  |  |             if (IS_SD_PRINTING) { | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |         #if DISABLED(LCD_SET_PROGRESS_MANUALLY) | 
			
		
	
		
			
				
					|  |  |  |  |           const uint8_t progress_bar_percent = card.percentDone(); | 
			
		
	
		
			
				
					|  |  |  |  |         #endif | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |         // Expire the message if a job is active and the bar has ticks
 | 
			
		
	
		
			
				
					|  |  |  |  |         if (progress_bar_percent > 2 && !print_job_timer.isPaused()) { | 
			
		
	
		
			
				
					|  |  |  |  |           if (ELAPSED(ms, expire_status_ms)) { | 
			
		
	
		
			
				
					|  |  |  |  |             lcd_status_message[0] = '\0'; | 
			
		
	
		
			
				
					|  |  |  |  |             expire_status_ms = 0; | 
			
		
	
		
			
				
					|  |  |  |  |           } | 
			
		
	
		
			
				
					|  |  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  |  |         else { | 
			
		
	
		
			
				
					|  |  |  |  |           // Defer message expiration before bar appears
 | 
			
		
	
		
			
				
					|  |  |  |  |           // and during any pause (not just SD)
 | 
			
		
	
		
			
				
					|  |  |  |  |           expire_status_ms += LCD_UPDATE_INTERVAL; | 
			
		
	
		
			
				
					|  |  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  |  |       } | 
			
		
	
		
			
				
					|  |  |  |  |           else { | 
			
		
	
		
			
				
					|  |  |  |  |             expire_status_ms = 0; | 
			
		
	
		
			
				
					|  |  |  |  |           } | 
			
		
	
		
			
				
					|  |  |  |  |         #else | 
			
		
	
		
			
				
					|  |  |  |  |           expire_status_ms = 0; | 
			
		
	
		
			
				
					|  |  |  |  |         #endif // SDSUPPORT
 | 
			
		
	
		
			
				
					|  |  |  |  |       } | 
			
		
	
		
			
				
					|  |  |  |  |     #endif | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     #endif // PROGRESS_MSG_EXPIRE
 | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |   #endif // LCD_PROGRESS_BAR
 | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |   #if ENABLED(ULTIPANEL) | 
			
		
	
	
		
			
				
					|  |  |  | 
 |