Add "Bed" / "Chamber" substitutions (#18255)

This commit is contained in:
Scott Lahteine 2020-06-10 18:35:56 -05:00 committed by GitHub
parent 3bf990ec34
commit 67305f7976
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 16 additions and 14 deletions

View file

@ -35,7 +35,7 @@
* lcd_put_u8str_ind_P * lcd_put_u8str_ind_P
* Print a string with an index substituted within it * Print a string with an index substituted within it
*/ */
lcd_uint_t lcd_put_u8str_ind_P(PGM_P const pstr, const uint8_t ind, const lcd_uint_t maxlen/*=LCD_WIDTH*/) { lcd_uint_t lcd_put_u8str_ind_P(PGM_P const pstr, const int8_t ind, const lcd_uint_t maxlen/*=LCD_WIDTH*/) {
uint8_t *p = (uint8_t*)pstr; uint8_t *p = (uint8_t*)pstr;
lcd_uint_t n = maxlen; lcd_uint_t n = maxlen;
for (; n; n--) { for (; n; n--) {
@ -43,15 +43,17 @@ lcd_uint_t lcd_put_u8str_ind_P(PGM_P const pstr, const uint8_t ind, const lcd_ui
p = get_utf8_value_cb(p, read_byte_rom, &ch); p = get_utf8_value_cb(p, read_byte_rom, &ch);
if (!ch) break; if (!ch) break;
if (ch == '=' || ch == '~' || ch == '*') { if (ch == '=' || ch == '~' || ch == '*') {
if (ch == '*') { lcd_put_wchar('E'); n--; }
// lcd_put_int(ind); n--; if (ind >= 10) n--; // lcd_put_int(ind); n--; if (ind >= 10) n--;
// if (ind >= 0) if (ind >= 0) {
{ if (ch == '*') { lcd_put_wchar('E'); n--; }
lcd_put_wchar(ind + ((ch == '=') ? '0' : LCD_FIRST_TOOL)); lcd_put_wchar(ind + ((ch == '=') ? '0' : LCD_FIRST_TOOL));
n--; n--;
} }
// else if (ind == -1) { PGM_P const b = GET_TEXT(MSG_BED); lcd_put_u8str_P(b); n -= utf8_strlen_P(b); } else {
// else if (ind == -2) { PGM_P const c = GET_TEXT(MSG_CHAMBER); lcd_put_u8str_P(c); n -= utf8_strlen_P(c); } PGM_P const b = ind == -2 ? GET_TEXT(MSG_CHAMBER) : GET_TEXT(MSG_BED);
lcd_put_u8str_P(b);
n -= utf8_strlen_P(b);
}
if (n) n -= lcd_put_u8str_max_P((PGM_P)p, n); if (n) n -= lcd_put_u8str_max_P((PGM_P)p, n);
break; break;
} }

View file

@ -71,8 +71,8 @@ inline int lcd_put_u8str_P(const lcd_uint_t col, const lcd_uint_t row, PGM_P con
return lcd_put_u8str_P(pstr); return lcd_put_u8str_P(pstr);
} }
lcd_uint_t lcd_put_u8str_ind_P(PGM_P const pstr, const uint8_t ind, const lcd_uint_t maxlen=LCD_WIDTH); lcd_uint_t lcd_put_u8str_ind_P(PGM_P const pstr, const int8_t ind, const lcd_uint_t maxlen=LCD_WIDTH);
inline lcd_uint_t lcd_put_u8str_ind_P(const lcd_uint_t col, const lcd_uint_t row, PGM_P const pstr, const uint8_t ind, const lcd_uint_t maxlen=LCD_WIDTH) { inline lcd_uint_t lcd_put_u8str_ind_P(const lcd_uint_t col, const lcd_uint_t row, PGM_P const pstr, const int8_t ind, const lcd_uint_t maxlen=LCD_WIDTH) {
lcd_moveto(col, row); lcd_moveto(col, row);
return lcd_put_u8str_ind_P(pstr, ind, maxlen); return lcd_put_u8str_ind_P(pstr, ind, maxlen);
} }

View file

@ -61,7 +61,7 @@ typedef struct {
menuPosition screen_history[6]; menuPosition screen_history[6];
uint8_t screen_history_depth = 0; uint8_t screen_history_depth = 0;
uint8_t MenuItemBase::itemIndex; // Index number for draw and action int8_t MenuItemBase::itemIndex; // Index number for draw and action
chimera_t editable; // Value Editing chimera_t editable; // Value Editing
// Menu Edit Items // Menu Edit Items

View file

@ -65,10 +65,10 @@ class MenuItemBase {
public: public:
// An index to interject in the item label and for // An index to interject in the item label and for
// use by the action // use by the action
static uint8_t itemIndex; static int8_t itemIndex;
// Store the index of the item ahead of use by indexed items // Store the index of the item ahead of use by indexed items
FORCE_INLINE static void init(const uint8_t ind) { itemIndex = ind; } FORCE_INLINE static void init(const int8_t ind) { itemIndex = ind; }
// Draw an item either selected (pre_char) or not (space) with post_char // Draw an item either selected (pre_char) or not (space) with post_char
static void _draw(const bool sel, const uint8_t row, PGM_P const pstr, const char pre_char, const char post_char); static void _draw(const bool sel, const uint8_t row, PGM_P const pstr, const char pre_char, const char post_char);