|
@ -262,8 +262,7 @@ static void lcd_goto_menu(menuFunc_t menu, const uint32_t encoder=0, const bool |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
/* Main status screen. It's up to the implementation specific part to show what is needed. As this is very display dependent */ |
|
|
/* Main status screen. It's up to the implementation specific part to show what is needed. As this is very display dependent */ |
|
|
static void lcd_status_screen() |
|
|
static void lcd_status_screen() { |
|
|
{ |
|
|
|
|
|
encoderRateMultiplierEnabled = false; |
|
|
encoderRateMultiplierEnabled = false; |
|
|
|
|
|
|
|
|
#ifdef LCD_PROGRESS_BAR |
|
|
#ifdef LCD_PROGRESS_BAR |
|
@ -296,15 +295,7 @@ static void lcd_status_screen() |
|
|
#endif |
|
|
#endif |
|
|
#endif //LCD_PROGRESS_BAR
|
|
|
#endif //LCD_PROGRESS_BAR
|
|
|
|
|
|
|
|
|
if (lcd_status_update_delay) |
|
|
|
|
|
lcd_status_update_delay--; |
|
|
|
|
|
else |
|
|
|
|
|
lcdDrawUpdate = 1; |
|
|
|
|
|
|
|
|
|
|
|
if (lcdDrawUpdate) { |
|
|
|
|
|
lcd_implementation_status_screen(); |
|
|
lcd_implementation_status_screen(); |
|
|
lcd_status_update_delay = 10; /* redraw the main screen every second. This is easier then trying keep track of all things that change on the screen */ |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
#ifdef ULTIPANEL |
|
|
#ifdef ULTIPANEL |
|
|
|
|
|
|
|
@ -1298,7 +1289,7 @@ void lcd_update() { |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
#endif//CARDINSERTED
|
|
|
#endif//CARDINSERTED
|
|
|
|
|
|
|
|
|
uint32_t ms = millis(); |
|
|
uint32_t ms = millis(); |
|
|
if (ms > lcd_next_update_millis) { |
|
|
if (ms > lcd_next_update_millis) { |
|
|
|
|
|
|
|
@ -1349,27 +1340,36 @@ void lcd_update() { |
|
|
} // encoderRateMultiplierEnabled
|
|
|
} // encoderRateMultiplierEnabled
|
|
|
#endif //ENCODER_RATE_MULTIPLIER
|
|
|
#endif //ENCODER_RATE_MULTIPLIER
|
|
|
|
|
|
|
|
|
lcdDrawUpdate = 1; |
|
|
|
|
|
encoderPosition += (encoderDiff * encoderMultiplier) / ENCODER_PULSES_PER_STEP; |
|
|
encoderPosition += (encoderDiff * encoderMultiplier) / ENCODER_PULSES_PER_STEP; |
|
|
encoderDiff = 0; |
|
|
encoderDiff = 0; |
|
|
} |
|
|
} |
|
|
timeoutToStatus = ms + LCD_TIMEOUT_TO_STATUS; |
|
|
timeoutToStatus = ms + LCD_TIMEOUT_TO_STATUS; |
|
|
|
|
|
lcdDrawUpdate = 1; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
#endif //ULTIPANEL
|
|
|
#endif //ULTIPANEL
|
|
|
|
|
|
|
|
|
|
|
|
if (currentMenu == lcd_status_screen) { |
|
|
|
|
|
if (!lcd_status_update_delay) { |
|
|
|
|
|
lcdDrawUpdate = 1; |
|
|
|
|
|
lcd_status_update_delay = 10; /* redraw the main screen every second. This is easier then trying keep track of all things that change on the screen */ |
|
|
|
|
|
} |
|
|
|
|
|
else { |
|
|
|
|
|
lcd_status_update_delay--; |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
#ifdef DOGLCD // Changes due to different driver architecture of the DOGM display
|
|
|
#ifdef DOGLCD // Changes due to different driver architecture of the DOGM display
|
|
|
blink++; // Variable for fan animation and alive dot
|
|
|
if (lcdDrawUpdate) { |
|
|
u8g.firstPage(); |
|
|
blink++; // Variable for fan animation and alive dot
|
|
|
do { |
|
|
u8g.firstPage(); |
|
|
lcd_setFont(FONT_MENU); |
|
|
do { |
|
|
u8g.setPrintPos(125, 0); |
|
|
lcd_setFont(FONT_MENU); |
|
|
if (blink % 2) u8g.setColorIndex(1); else u8g.setColorIndex(0); // Set color for the alive dot
|
|
|
u8g.setPrintPos(125, 0); |
|
|
u8g.drawPixel(127, 63); // draw alive dot
|
|
|
if (blink % 2) u8g.setColorIndex(1); else u8g.setColorIndex(0); // Set color for the alive dot
|
|
|
u8g.setColorIndex(1); // black on white
|
|
|
u8g.drawPixel(127, 63); // draw alive dot
|
|
|
(*currentMenu)(); |
|
|
u8g.setColorIndex(1); // black on white
|
|
|
if (!lcdDrawUpdate) break; // Terminate display update, when nothing new to draw. This must be done before the last dogm.next()
|
|
|
(*currentMenu)(); |
|
|
} while( u8g.nextPage() ); |
|
|
} while( u8g.nextPage() ); |
|
|
|
|
|
} |
|
|
#else |
|
|
#else |
|
|
(*currentMenu)(); |
|
|
(*currentMenu)(); |
|
|
#endif |
|
|
#endif |
|
|