|
|
@ -191,8 +191,8 @@ u8g_page_t &page = ((u8g_pb_t *)((u8g.getU8g())->dev->dev_mem))->p;
|
|
|
|
#define PAGE_UNDER(yb) (u8g.getU8g()->current_page.y0 <= (yb))
|
|
|
|
#define PAGE_UNDER(yb) (u8g.getU8g()->current_page.y0 <= (yb))
|
|
|
|
#define PAGE_CONTAINS(ya, yb) (PAGE_UNDER(yb) && u8g.getU8g()->current_page.y1 >= (ya))
|
|
|
|
#define PAGE_CONTAINS(ya, yb) (PAGE_UNDER(yb) && u8g.getU8g()->current_page.y1 >= (ya))
|
|
|
|
|
|
|
|
|
|
|
|
static void lcd_setFont(char font_nr) {
|
|
|
|
static void lcd_setFont(const char font_nr) {
|
|
|
|
switch(font_nr) {
|
|
|
|
switch (font_nr) {
|
|
|
|
case FONT_STATUSMENU : {u8g.setFont(FONT_STATUSMENU_NAME); currentfont = FONT_STATUSMENU;}; break;
|
|
|
|
case FONT_STATUSMENU : {u8g.setFont(FONT_STATUSMENU_NAME); currentfont = FONT_STATUSMENU;}; break;
|
|
|
|
case FONT_MENU : {u8g.setFont(FONT_MENU_NAME); currentfont = FONT_MENU;}; break;
|
|
|
|
case FONT_MENU : {u8g.setFont(FONT_MENU_NAME); currentfont = FONT_MENU;}; break;
|
|
|
|
case FONT_SPECIAL : {u8g.setFont(FONT_SPECIAL_NAME); currentfont = FONT_SPECIAL;}; break;
|
|
|
|
case FONT_SPECIAL : {u8g.setFont(FONT_SPECIAL_NAME); currentfont = FONT_SPECIAL;}; break;
|
|
|
@ -201,7 +201,7 @@ static void lcd_setFont(char font_nr) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void lcd_print(char c) {
|
|
|
|
void lcd_print(const char c) {
|
|
|
|
if ((c > 0) && (c <= LCD_STR_SPECIAL_MAX)) {
|
|
|
|
if ((c > 0) && (c <= LCD_STR_SPECIAL_MAX)) {
|
|
|
|
u8g.setFont(FONT_SPECIAL_NAME);
|
|
|
|
u8g.setFont(FONT_SPECIAL_NAME);
|
|
|
|
u8g.print(c);
|
|
|
|
u8g.print(c);
|
|
|
@ -210,7 +210,7 @@ void lcd_print(char c) {
|
|
|
|
else charset_mapper(c);
|
|
|
|
else charset_mapper(c);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
char lcd_print_and_count(char c) {
|
|
|
|
char lcd_print_and_count(const char c) {
|
|
|
|
if ((c > 0) && (c <= LCD_STR_SPECIAL_MAX)) {
|
|
|
|
if ((c > 0) && (c <= LCD_STR_SPECIAL_MAX)) {
|
|
|
|
u8g.setFont(FONT_SPECIAL_NAME);
|
|
|
|
u8g.setFont(FONT_SPECIAL_NAME);
|
|
|
|
u8g.print(c);
|
|
|
|
u8g.print(c);
|
|
|
@ -220,7 +220,7 @@ char lcd_print_and_count(char c) {
|
|
|
|
else return charset_mapper(c);
|
|
|
|
else return charset_mapper(c);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void lcd_print(const char* str) {
|
|
|
|
void lcd_print(const char* const str) {
|
|
|
|
for (uint8_t i = 0; char c = str[i]; ++i) lcd_print(c);
|
|
|
|
for (uint8_t i = 0; char c = str[i]; ++i) lcd_print(c);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -268,15 +268,15 @@ static void lcd_implementation_init() {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif // SHOW_CUSTOM_BOOTSCREEN
|
|
|
|
#endif // SHOW_CUSTOM_BOOTSCREEN
|
|
|
|
|
|
|
|
|
|
|
|
int offx = (u8g.getWidth() - (START_BMPWIDTH)) / 2;
|
|
|
|
const uint8_t offx = (u8g.getWidth() - (START_BMPWIDTH)) / 2;
|
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(START_BMPHIGH)
|
|
|
|
#if ENABLED(START_BMPHIGH)
|
|
|
|
int offy = 0;
|
|
|
|
constexpr uint8_t offy = 0;
|
|
|
|
#else
|
|
|
|
#else
|
|
|
|
int offy = DOG_CHAR_HEIGHT;
|
|
|
|
constexpr uint8_t offy = DOG_CHAR_HEIGHT;
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
int txt1X = (u8g.getWidth() - (sizeof(STRING_SPLASH_LINE1) - 1) * (DOG_CHAR_WIDTH)) / 2;
|
|
|
|
const uint8_t txt1X = (u8g.getWidth() - (sizeof(STRING_SPLASH_LINE1) - 1) * (DOG_CHAR_WIDTH)) / 2;
|
|
|
|
|
|
|
|
|
|
|
|
if (show_bootscreen) {
|
|
|
|
if (show_bootscreen) {
|
|
|
|
u8g.firstPage();
|
|
|
|
u8g.firstPage();
|
|
|
@ -286,7 +286,7 @@ static void lcd_implementation_init() {
|
|
|
|
#ifndef STRING_SPLASH_LINE2
|
|
|
|
#ifndef STRING_SPLASH_LINE2
|
|
|
|
u8g.drawStr(txt1X, u8g.getHeight() - (DOG_CHAR_HEIGHT), STRING_SPLASH_LINE1);
|
|
|
|
u8g.drawStr(txt1X, u8g.getHeight() - (DOG_CHAR_HEIGHT), STRING_SPLASH_LINE1);
|
|
|
|
#else
|
|
|
|
#else
|
|
|
|
int txt2X = (u8g.getWidth() - (sizeof(STRING_SPLASH_LINE2) - 1) * (DOG_CHAR_WIDTH)) / 2;
|
|
|
|
const uint8_t txt2X = (u8g.getWidth() - (sizeof(STRING_SPLASH_LINE2) - 1) * (DOG_CHAR_WIDTH)) / 2;
|
|
|
|
u8g.drawStr(txt1X, u8g.getHeight() - (DOG_CHAR_HEIGHT) * 3 / 2, STRING_SPLASH_LINE1);
|
|
|
|
u8g.drawStr(txt1X, u8g.getHeight() - (DOG_CHAR_HEIGHT) * 3 / 2, STRING_SPLASH_LINE1);
|
|
|
|
u8g.drawStr(txt2X, u8g.getHeight() - (DOG_CHAR_HEIGHT) * 1 / 2, STRING_SPLASH_LINE2);
|
|
|
|
u8g.drawStr(txt2X, u8g.getHeight() - (DOG_CHAR_HEIGHT) * 1 / 2, STRING_SPLASH_LINE2);
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
@ -315,14 +315,14 @@ static void lcd_implementation_clear() { } // Automatically cleared by Picture L
|
|
|
|
// Status Screen
|
|
|
|
// Status Screen
|
|
|
|
//
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
|
|
FORCE_INLINE void _draw_centered_temp(int temp, int x, int y) {
|
|
|
|
FORCE_INLINE void _draw_centered_temp(const int temp, const uint8_t x, const uint8_t y) {
|
|
|
|
int degsize = 6 * (temp >= 100 ? 3 : temp >= 10 ? 2 : 1); // number's pixel width
|
|
|
|
const uint8_t degsize = 6 * (temp >= 100 ? 3 : temp >= 10 ? 2 : 1); // number's pixel width
|
|
|
|
u8g.setPrintPos(x - (18 - degsize) / 2, y); // move left if shorter
|
|
|
|
u8g.setPrintPos(x - (18 - degsize) / 2, y); // move left if shorter
|
|
|
|
lcd_print(itostr3(temp));
|
|
|
|
lcd_print(itostr3(temp));
|
|
|
|
lcd_printPGM(PSTR(LCD_STR_DEGREE " "));
|
|
|
|
lcd_printPGM(PSTR(LCD_STR_DEGREE " "));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
FORCE_INLINE void _draw_heater_status(int x, int heater) {
|
|
|
|
FORCE_INLINE void _draw_heater_status(const uint8_t x, const int8_t heater) {
|
|
|
|
#if HAS_TEMP_BED
|
|
|
|
#if HAS_TEMP_BED
|
|
|
|
bool isBed = heater < 0;
|
|
|
|
bool isBed = heater < 0;
|
|
|
|
#else
|
|
|
|
#else
|
|
|
@ -336,8 +336,8 @@ FORCE_INLINE void _draw_heater_status(int x, int heater) {
|
|
|
|
_draw_centered_temp((isBed ? thermalManager.degBed() : thermalManager.degHotend(heater)) + 0.5, x, 28);
|
|
|
|
_draw_centered_temp((isBed ? thermalManager.degBed() : thermalManager.degHotend(heater)) + 0.5, x, 28);
|
|
|
|
|
|
|
|
|
|
|
|
if (PAGE_CONTAINS(17, 20)) {
|
|
|
|
if (PAGE_CONTAINS(17, 20)) {
|
|
|
|
uint8_t h = isBed ? 7 : 8,
|
|
|
|
const uint8_t h = isBed ? 7 : 8,
|
|
|
|
y = isBed ? 18 : 17;
|
|
|
|
y = isBed ? 18 : 17;
|
|
|
|
if (isBed ? thermalManager.isHeatingBed() : thermalManager.isHeatingHotend(heater)) {
|
|
|
|
if (isBed ? thermalManager.isHeatingBed() : thermalManager.isHeatingHotend(heater)) {
|
|
|
|
u8g.setColorIndex(0); // white on black
|
|
|
|
u8g.setColorIndex(0); // white on black
|
|
|
|
u8g.drawBox(x + h, y, 2, 2);
|
|
|
|
u8g.drawBox(x + h, y, 2, 2);
|
|
|
@ -349,7 +349,7 @@ FORCE_INLINE void _draw_heater_status(int x, int heater) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
FORCE_INLINE void _draw_axis_label(AxisEnum axis, const char *pstr, bool blink) {
|
|
|
|
FORCE_INLINE void _draw_axis_label(const AxisEnum axis, const char* const pstr, const bool blink) {
|
|
|
|
if (blink)
|
|
|
|
if (blink)
|
|
|
|
lcd_printPGM(pstr);
|
|
|
|
lcd_printPGM(pstr);
|
|
|
|
else {
|
|
|
|
else {
|
|
|
@ -611,7 +611,7 @@ static void lcd_implementation_status_screen() {
|
|
|
|
uint8_t row_y1, row_y2;
|
|
|
|
uint8_t row_y1, row_y2;
|
|
|
|
|
|
|
|
|
|
|
|
// Set the colors for a menu item based on whether it is selected
|
|
|
|
// Set the colors for a menu item based on whether it is selected
|
|
|
|
static void lcd_implementation_mark_as_selected(uint8_t row, bool isSelected) {
|
|
|
|
static void lcd_implementation_mark_as_selected(const uint8_t row, const bool isSelected) {
|
|
|
|
|
|
|
|
|
|
|
|
row_y1 = row * (DOG_CHAR_HEIGHT) + 1;
|
|
|
|
row_y1 = row * (DOG_CHAR_HEIGHT) + 1;
|
|
|
|
row_y2 = row_y1 + (DOG_CHAR_HEIGHT) - 1;
|
|
|
|
row_y2 = row_y1 + (DOG_CHAR_HEIGHT) - 1;
|
|
|
@ -632,7 +632,7 @@ static void lcd_implementation_status_screen() {
|
|
|
|
#if ENABLED(LCD_INFO_MENU) || ENABLED(FILAMENT_CHANGE_FEATURE)
|
|
|
|
#if ENABLED(LCD_INFO_MENU) || ENABLED(FILAMENT_CHANGE_FEATURE)
|
|
|
|
|
|
|
|
|
|
|
|
// Draw a static line of text in the same idiom as a menu item
|
|
|
|
// Draw a static line of text in the same idiom as a menu item
|
|
|
|
static void lcd_implementation_drawmenu_static(uint8_t row, const char* pstr, bool center=true, bool invert=false, const char* valstr=NULL) {
|
|
|
|
static void lcd_implementation_drawmenu_static(const uint8_t row, const char* pstr, const bool center=true, const bool invert=false, const char* valstr=NULL) {
|
|
|
|
|
|
|
|
|
|
|
|
lcd_implementation_mark_as_selected(row, invert);
|
|
|
|
lcd_implementation_mark_as_selected(row, invert);
|
|
|
|
|
|
|
|
|
|
|
@ -659,7 +659,7 @@ static void lcd_implementation_status_screen() {
|
|
|
|
#endif // LCD_INFO_MENU || FILAMENT_CHANGE_FEATURE
|
|
|
|
#endif // LCD_INFO_MENU || FILAMENT_CHANGE_FEATURE
|
|
|
|
|
|
|
|
|
|
|
|
// Draw a generic menu item
|
|
|
|
// Draw a generic menu item
|
|
|
|
static void lcd_implementation_drawmenu_generic(bool isSelected, uint8_t row, const char* pstr, char pre_char, char post_char) {
|
|
|
|
static void lcd_implementation_drawmenu_generic(const bool isSelected, const uint8_t row, const char* pstr, const char pre_char, const char post_char) {
|
|
|
|
UNUSED(pre_char);
|
|
|
|
UNUSED(pre_char);
|
|
|
|
|
|
|
|
|
|
|
|
lcd_implementation_mark_as_selected(row, isSelected);
|
|
|
|
lcd_implementation_mark_as_selected(row, isSelected);
|
|
|
@ -684,7 +684,7 @@ static void lcd_implementation_status_screen() {
|
|
|
|
#define lcd_implementation_drawmenu_function(sel, row, pstr, data) lcd_implementation_drawmenu_generic(sel, row, pstr, '>', ' ')
|
|
|
|
#define lcd_implementation_drawmenu_function(sel, row, pstr, data) lcd_implementation_drawmenu_generic(sel, row, pstr, '>', ' ')
|
|
|
|
|
|
|
|
|
|
|
|
// Draw a menu item with an editable value
|
|
|
|
// Draw a menu item with an editable value
|
|
|
|
static void _drawmenu_setting_edit_generic(bool isSelected, uint8_t row, const char* pstr, const char* data, bool pgm) {
|
|
|
|
static void _drawmenu_setting_edit_generic(const bool isSelected, const uint8_t row, const char* pstr, const char* const data, const bool pgm) {
|
|
|
|
|
|
|
|
|
|
|
|
lcd_implementation_mark_as_selected(row, isSelected);
|
|
|
|
lcd_implementation_mark_as_selected(row, isSelected);
|
|
|
|
|
|
|
|
|
|
|
@ -729,9 +729,9 @@ static void lcd_implementation_status_screen() {
|
|
|
|
#define lcd_implementation_drawmenu_setting_edit_callback_long5(sel, row, pstr, pstr2, data, minValue, maxValue, callback) lcd_implementation_drawmenu_setting_edit_generic(sel, row, pstr, ftostr5rj(*(data)))
|
|
|
|
#define lcd_implementation_drawmenu_setting_edit_callback_long5(sel, row, pstr, pstr2, data, minValue, maxValue, callback) lcd_implementation_drawmenu_setting_edit_generic(sel, row, pstr, ftostr5rj(*(data)))
|
|
|
|
#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* pstr, const char* 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);
|
|
|
|
uint8_t lcd_width, char_width,
|
|
|
|
uint8_t lcd_width, char_width,
|
|
|
|
labellen = lcd_strlen_P(pstr), 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)
|
|
|
@ -752,8 +752,8 @@ static void lcd_implementation_status_screen() {
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
// Center either one or two rows
|
|
|
|
// Center either one or two rows
|
|
|
|
uint8_t segmentHeight = u8g.getHeight() / (rows + 1), // 1 / (rows+1) = 1/2 or 1/3
|
|
|
|
const uint8_t segmentHeight = u8g.getHeight() / (rows + 1); // 1 / (rows+1) = 1/2 or 1/3
|
|
|
|
baseline = segmentHeight + (DOG_CHAR_HEIGHT_EDIT + 1) / 2;
|
|
|
|
uint8_t baseline = segmentHeight + (DOG_CHAR_HEIGHT_EDIT + 1) / 2;
|
|
|
|
|
|
|
|
|
|
|
|
if (PAGE_CONTAINS(baseline + 1 - (DOG_CHAR_HEIGHT_EDIT), baseline)) {
|
|
|
|
if (PAGE_CONTAINS(baseline + 1 - (DOG_CHAR_HEIGHT_EDIT), baseline)) {
|
|
|
|
u8g.setPrintPos(0, baseline);
|
|
|
|
u8g.setPrintPos(0, baseline);
|
|
|
@ -772,7 +772,7 @@ static void lcd_implementation_status_screen() {
|
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(SDSUPPORT)
|
|
|
|
#if ENABLED(SDSUPPORT)
|
|
|
|
|
|
|
|
|
|
|
|
static void _drawmenu_sd(bool isSelected, uint8_t row, const char* pstr, const char* filename, char* const longFilename, bool isDir) {
|
|
|
|
static void _drawmenu_sd(const bool isSelected, const uint8_t row, const char* const pstr, const char* filename, char* const longFilename, const bool isDir) {
|
|
|
|
UNUSED(pstr);
|
|
|
|
UNUSED(pstr);
|
|
|
|
|
|
|
|
|
|
|
|
lcd_implementation_mark_as_selected(row, isSelected);
|
|
|
|
lcd_implementation_mark_as_selected(row, isSelected);
|
|
|
|