Better alignment of elapsed print time

This commit is contained in:
Scott Lahteine 2016-12-04 21:09:12 -06:00
parent 0b9b529745
commit 9d88a61d52
3 changed files with 39 additions and 23 deletions

View File

@ -145,15 +145,22 @@ struct duration_t {
* 99:59 * 99:59
* 11d 12:33 * 11d 12:33
*/ */
void toDigital(char *buffer, bool with_days=false) const { uint8_t toDigital(char *buffer, bool with_days=false) const {
uint16_t h = uint16_t(this->hour()), uint16_t h = uint16_t(this->hour()),
m = uint16_t(this->minute() % 60UL); m = uint16_t(this->minute() % 60UL);
if (with_days) if (with_days) {
sprintf_P(buffer, PSTR("%ud %02u:%02u"), this->day(), h, m); uint16_t d = this->day();
else if (h < 100) sprintf_P(buffer, PSTR("%ud %02u:%02u"), d, h, m);
return d >= 10 ? 8 : 7;
}
else if (h < 100) {
sprintf_P(buffer, PSTR("%02u:%02u"), h % 24, m); sprintf_P(buffer, PSTR("%02u:%02u"), h % 24, m);
else return 5;
}
else {
sprintf_P(buffer, PSTR("%u:%02u"), h, m); sprintf_P(buffer, PSTR("%u:%02u"), h, m);
return 6;
}
} }
}; };

View File

@ -452,8 +452,14 @@ static void lcd_implementation_status_screen() {
// Progress bar frame // Progress bar frame
// //
if (PAGE_CONTAINS(49, 52 - (TALL_FONT_CORRECTION))) #define PROGRESS_BAR_X 54
u8g.drawFrame(54, 49, 73, 4 - (TALL_FONT_CORRECTION)); // 49-52 (or 49-51) #define PROGRESS_BAR_WIDTH (LCD_PIXEL_WIDTH - PROGRESS_BAR_X)
if (PAGE_CONTAINS(49, 52 - (TALL_FONT_CORRECTION))) // 49-52 (or 49-51)
u8g.drawFrame(
PROGRESS_BAR_X, 49,
PROGRESS_BAR_WIDTH, 4 - (TALL_FONT_CORRECTION)
);
if (IS_SD_PRINTING) { if (IS_SD_PRINTING) {
@ -461,8 +467,11 @@ static void lcd_implementation_status_screen() {
// Progress bar solid part // Progress bar solid part
// //
if (PAGE_CONTAINS(50, 51 - (TALL_FONT_CORRECTION))) if (PAGE_CONTAINS(50, 51 - (TALL_FONT_CORRECTION))) // 50-51 (or just 50)
u8g.drawBox(55, 50, (unsigned int)(71 * card.percentDone() * 0.01), 2 - (TALL_FONT_CORRECTION)); u8g.drawBox(
PROGRESS_BAR_X + 1, 50,
(unsigned int)((PROGRESS_BAR_WIDTH - 2) * card.percentDone() * 0.01), 2 - (TALL_FONT_CORRECTION)
);
// //
// SD Percent Complete // SD Percent Complete
@ -483,9 +492,9 @@ static void lcd_implementation_status_screen() {
// //
#if DISABLED(DOGM_SD_PERCENT) #if DISABLED(DOGM_SD_PERCENT)
#define SD_DURATION_X 71 #define SD_DURATION_X (PROGRESS_BAR_X + (PROGRESS_BAR_WIDTH / 2) - len * (DOG_CHAR_WIDTH / 2))
#else #else
#define SD_DURATION_X 89 #define SD_DURATION_X (LCD_PIXEL_WIDTH - len * DOG_CHAR_WIDTH)
#endif #endif
if (PAGE_CONTAINS(41, 48)) { if (PAGE_CONTAINS(41, 48)) {
@ -493,9 +502,8 @@ static void lcd_implementation_status_screen() {
char buffer[10]; char buffer[10];
duration_t elapsed = print_job_timer.duration(); duration_t elapsed = print_job_timer.duration();
bool has_days = (elapsed.value > 60*60*24L); bool has_days = (elapsed.value > 60*60*24L);
elapsed.toDigital(buffer, has_days); uint8_t len = elapsed.toDigital(buffer, has_days);
u8g.setPrintPos(SD_DURATION_X, 48);
u8g.setPrintPos(SD_DURATION_X + (has_days ? 0 : 9), 48);
lcd_print(buffer); lcd_print(buffer);
} }
@ -749,11 +757,12 @@ static void lcd_implementation_status_screen() {
#define lcd_implementation_drawmenu_setting_edit_callback_bool(sel, row, pstr, pstr2, data, callback) lcd_implementation_drawmenu_setting_edit_generic_P(sel, row, pstr, (*(data))?PSTR(MSG_ON):PSTR(MSG_OFF)) #define lcd_implementation_drawmenu_setting_edit_callback_bool(sel, row, pstr, pstr2, data, callback) lcd_implementation_drawmenu_setting_edit_generic_P(sel, row, pstr, (*(data))?PSTR(MSG_ON):PSTR(MSG_OFF))
void lcd_implementation_drawedit(const char* const pstr, const char* const value=NULL) { void lcd_implementation_drawedit(const char* const pstr, const char* const value=NULL) {
const uint8_t labellen = lcd_strlen_P(pstr), vallen = lcd_strlen(value); const uint8_t labellen = lcd_strlen_P(pstr),
uint8_t lcd_width, char_width, vallen = lcd_strlen(value),
rows = (labellen > LCD_WIDTH - 2 - vallen) ? 2 : 1; rows = (labellen > LCD_WIDTH - 2 - vallen) ? 2 : 1;
#if ENABLED(USE_BIG_EDIT_FONT) #if ENABLED(USE_BIG_EDIT_FONT)
uint8_t lcd_width, char_width;
if (labellen <= LCD_WIDTH_EDIT - 1) { if (labellen <= LCD_WIDTH_EDIT - 1) {
if (labellen >= LCD_WIDTH_EDIT - vallen) rows = 2; if (labellen >= LCD_WIDTH_EDIT - vallen) rows = 2;
lcd_width = LCD_WIDTH_EDIT + 1; lcd_width = LCD_WIDTH_EDIT + 1;
@ -766,8 +775,8 @@ static void lcd_implementation_status_screen() {
lcd_setFont(FONT_MENU); lcd_setFont(FONT_MENU);
} }
#else #else
lcd_width = LCD_WIDTH - (START_COL); constexpr uint8_t lcd_width = LCD_WIDTH - (START_COL),
char_width = DOG_CHAR_WIDTH; char_width = DOG_CHAR_WIDTH;
#endif #endif
// Center either one or two rows // Center either one or two rows

View File

@ -733,12 +733,12 @@ static void lcd_implementation_status_screen() {
#endif // LCD_WIDTH >= 20 && SDSUPPORT #endif // LCD_WIDTH >= 20 && SDSUPPORT
lcd.setCursor(LCD_WIDTH - 6, 2);
lcd.print(LCD_STR_CLOCK[0]);
char buffer[10]; char buffer[10];
duration_t elapsed = print_job_timer.duration(); duration_t elapsed = print_job_timer.duration();
elapsed.toDigital(buffer); uint8_t len = elapsed.toDigital(buffer);
lcd.setCursor(LCD_WIDTH - len - 1, 2);
lcd.print(LCD_STR_CLOCK[0]);
lcd_print(buffer); lcd_print(buffer);
#endif // LCD_HEIGHT > 3 #endif // LCD_HEIGHT > 3