🎨 Fix and improve FTDI Eve Touch UI (#22093)
This commit is contained in:
		| @@ -27,9 +27,7 @@ | |||||||
|  |  | ||||||
|   #if ENABLED(SDSUPPORT) |   #if ENABLED(SDSUPPORT) | ||||||
|     bool MediaFileReader::open(const char *filename) { |     bool MediaFileReader::open(const char *filename) { | ||||||
|       card.init(SD_SPI_SPEED, SDSS); |       root = CardReader::getroot(); | ||||||
|       volume.init(&card); |  | ||||||
|       root.openRoot(&volume); |  | ||||||
|       return file.open(&root, filename, O_READ); |       return file.open(&root, filename, O_READ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -82,8 +82,8 @@ namespace FTDI { | |||||||
|       box_width = w; |       box_width = w; | ||||||
|       measure_text_box(fm, str, box_width, box_height); |       measure_text_box(fm, str, box_width, box_height); | ||||||
|       if (box_width <= (uint16_t)w && box_height <= (uint16_t)h) break; |       if (box_width <= (uint16_t)w && box_height <= (uint16_t)h) break; | ||||||
|       fm.load(--font); |  | ||||||
|       if (font == 26) break; |       if (font == 26) break; | ||||||
|  |       fm.load(--font); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     const uint16_t dx = (options & OPT_RIGHTX) ? w : |     const uint16_t dx = (options & OPT_RIGHTX) ? w : | ||||||
|   | |||||||
| @@ -26,7 +26,7 @@ | |||||||
| #ifdef FTDI_ABOUT_SCREEN | #ifdef FTDI_ABOUT_SCREEN | ||||||
|  |  | ||||||
| #define GRID_COLS 4 | #define GRID_COLS 4 | ||||||
| #define GRID_ROWS 7 | #define GRID_ROWS 8 | ||||||
|  |  | ||||||
| using namespace FTDI; | using namespace FTDI; | ||||||
| using namespace Theme; | using namespace Theme; | ||||||
| @@ -47,9 +47,9 @@ void AboutScreen::onRedraw(draw_mode_t) { | |||||||
|   #define HEADING_POS BTN_POS(1,2), BTN_SIZE(4,1) |   #define HEADING_POS BTN_POS(1,2), BTN_SIZE(4,1) | ||||||
|   #define FW_VERS_POS BTN_POS(1,3), BTN_SIZE(4,1) |   #define FW_VERS_POS BTN_POS(1,3), BTN_SIZE(4,1) | ||||||
|   #define FW_INFO_POS BTN_POS(1,4), BTN_SIZE(4,1) |   #define FW_INFO_POS BTN_POS(1,4), BTN_SIZE(4,1) | ||||||
|   #define LICENSE_POS BTN_POS(1,5), BTN_SIZE(4,2) |   #define LICENSE_POS BTN_POS(1,5), BTN_SIZE(4,3) | ||||||
|   #define STATS_POS   BTN_POS(1,7), BTN_SIZE(2,1) |   #define STATS_POS   BTN_POS(1,8), BTN_SIZE(2,1) | ||||||
|   #define BACK_POS    BTN_POS(3,7), BTN_SIZE(2,1) |   #define BACK_POS    BTN_POS(3,8), BTN_SIZE(2,1) | ||||||
|  |  | ||||||
|   #define _INSET_POS(x,y,w,h) x + w/10, y, w - w/5, h |   #define _INSET_POS(x,y,w,h) x + w/10, y, w - w/5, h | ||||||
|   #define INSET_POS(pos) _INSET_POS(pos) |   #define INSET_POS(pos) _INSET_POS(pos) | ||||||
|   | |||||||
| @@ -69,7 +69,7 @@ void BedMeshViewScreen::onEntry() { | |||||||
| void BedMeshViewScreen::drawHighlightedPointValue() { | void BedMeshViewScreen::drawHighlightedPointValue() { | ||||||
|   CommandProcessor cmd; |   CommandProcessor cmd; | ||||||
|   cmd.font(Theme::font_medium) |   cmd.font(Theme::font_medium) | ||||||
|      .colors(normal_btn) |      .cmd(COLOR_RGB(bg_text_enabled)) | ||||||
|      .text(Z_LABEL_POS, GET_TEXT_F(MSG_MESH_EDIT_Z)) |      .text(Z_LABEL_POS, GET_TEXT_F(MSG_MESH_EDIT_Z)) | ||||||
|      .font(font_small); |      .font(font_small); | ||||||
|  |  | ||||||
| @@ -161,7 +161,7 @@ void BedMeshViewScreen::doProbe() { | |||||||
| void BedMeshViewScreen::doMeshValidation() { | void BedMeshViewScreen::doMeshValidation() { | ||||||
|   mydata.count = 0; |   mydata.count = 0; | ||||||
|   GOTO_SCREEN(StatusScreen); |   GOTO_SCREEN(StatusScreen); | ||||||
|   injectCommands_P(PSTR("G28 O\nM117 Heating...\nG26 R X0 Y0")); |   injectCommands_P(PSTR("M75\nG28 O\nM117 Heating...\nG26 R X0 Y0\nG27\nM77")); | ||||||
| } | } | ||||||
|  |  | ||||||
| void BedMeshViewScreen::show() { | void BedMeshViewScreen::show() { | ||||||
|   | |||||||
| @@ -46,17 +46,22 @@ void ZOffsetScreen::onRedraw(draw_mode_t what) { | |||||||
|   w.heading(                  GET_TEXT_F(MSG_ZPROBE_ZOFFSET)); |   w.heading(                  GET_TEXT_F(MSG_ZPROBE_ZOFFSET)); | ||||||
|   w.color(z_axis).adjuster(4, GET_TEXT_F(MSG_ZPROBE_ZOFFSET), getZOffset_mm()); |   w.color(z_axis).adjuster(4, GET_TEXT_F(MSG_ZPROBE_ZOFFSET), getZOffset_mm()); | ||||||
|   w.increments(); |   w.increments(); | ||||||
|   w.button(   2, GET_TEXT_F(MSG_PROBE_WIZARD)); |   w.button(2, GET_TEXT_F(MSG_PROBE_WIZARD), !isPrinting()); | ||||||
| } | } | ||||||
|  |  | ||||||
| void ZOffsetScreen::move(float inc) { | void ZOffsetScreen::move(float mm, int16_t steps) { | ||||||
|   // We can't store state after the call to the AlertBox, so |   // We can't store state after the call to the AlertBox, so | ||||||
|   // check whether the current position equal mydata.z in order |   // check whether the current position equal mydata.z in order | ||||||
|   // to know whether the user started the wizard. |   // to know whether the user started the wizard. | ||||||
|   if (getAxisPosition_mm(Z) == mydata.z) { |   if (getAxisPosition_mm(Z) == mydata.z) { | ||||||
|     mydata.z += inc; |     // In the wizard | ||||||
|  |     mydata.z += mm; | ||||||
|     setAxisPosition_mm(mydata.z, Z); |     setAxisPosition_mm(mydata.z, Z); | ||||||
|   } |   } | ||||||
|  |   else { | ||||||
|  |     // Otherwise doing a manual adjustment, possibly during a print. | ||||||
|  |     babystepAxis_steps(steps, Z); | ||||||
|  |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| void ZOffsetScreen::runWizard() { | void ZOffsetScreen::runWizard() { | ||||||
| @@ -80,11 +85,12 @@ void ZOffsetScreen::runWizard() { | |||||||
| } | } | ||||||
|  |  | ||||||
| bool ZOffsetScreen::onTouchHeld(uint8_t tag) { | bool ZOffsetScreen::onTouchHeld(uint8_t tag) { | ||||||
|   const float increment = getIncrement(); |   const int16_t steps = mmToWholeSteps(getIncrement(), Z); | ||||||
|  |   const float increment = mmFromWholeSteps(steps, Z); | ||||||
|   switch (tag) { |   switch (tag) { | ||||||
|     case 2: runWizard(); break; |     case 2: runWizard(); break; | ||||||
|     case 4: UI_DECREMENT(ZOffset_mm); move(-increment); break; |     case 4: UI_DECREMENT(ZOffset_mm); move(-increment, -steps); break; | ||||||
|     case 5: UI_INCREMENT(ZOffset_mm); move( increment); break; |     case 5: UI_INCREMENT(ZOffset_mm); move( increment,  steps); break; | ||||||
|     default: |     default: | ||||||
|       return false; |       return false; | ||||||
|   } |   } | ||||||
|   | |||||||
| @@ -31,7 +31,7 @@ struct ZOffsetScreenData : public BaseNumericAdjustmentScreenData { | |||||||
|  |  | ||||||
| class ZOffsetScreen : public BaseNumericAdjustmentScreen, public CachedScreen<ZOFFSET_SCREEN_CACHE> { | class ZOffsetScreen : public BaseNumericAdjustmentScreen, public CachedScreen<ZOFFSET_SCREEN_CACHE> { | ||||||
|   private: |   private: | ||||||
|     static void move(float inc); |     static void move(float mm, int16_t steps); | ||||||
|     static void runWizard(); |     static void runWizard(); | ||||||
|   public: |   public: | ||||||
|     static void onEntry(); |     static void onEntry(); | ||||||
|   | |||||||
| @@ -70,7 +70,7 @@ namespace Language_en { | |||||||
|   PROGMEM Language_Str MSG_ABOUT_TOUCH_PANEL_2      = WEBSITE_URL; |   PROGMEM Language_Str MSG_ABOUT_TOUCH_PANEL_2      = WEBSITE_URL; | ||||||
|   PROGMEM Language_Str MSG_LICENSE                  = u8"This program is free software: you can redistribute it and/or modify it under the terms of " |   PROGMEM Language_Str MSG_LICENSE                  = u8"This program is free software: you can redistribute it and/or modify it under the terms of " | ||||||
|                                                         "the GNU General Public License as published by the Free Software Foundation, either version 3 " |                                                         "the GNU General Public License as published by the Free Software Foundation, either version 3 " | ||||||
|                                                         "of the License, or (at your option) any later version.\n\nTo view a copy of the GNU General " |                                                         "of the License, or (at your option) any later version. To view a copy of the GNU General " | ||||||
|                                                         "Public License, go to the following location: https://www.gnu.org/licenses."; |                                                         "Public License, go to the following location: https://www.gnu.org/licenses."; | ||||||
|   PROGMEM Language_Str MSG_RUNOUT_1                 = u8"Runout 1"; |   PROGMEM Language_Str MSG_RUNOUT_1                 = u8"Runout 1"; | ||||||
|   PROGMEM Language_Str MSG_RUNOUT_2                 = u8"Runout 2"; |   PROGMEM Language_Str MSG_RUNOUT_2                 = u8"Runout 2"; | ||||||
| @@ -130,7 +130,7 @@ namespace Language_en { | |||||||
|   PROGMEM Language_Str MSG_EEPROM_RESTORED          = u8"Settings restored from backup"; |   PROGMEM Language_Str MSG_EEPROM_RESTORED          = u8"Settings restored from backup"; | ||||||
|   PROGMEM Language_Str MSG_EEPROM_RESET             = u8"Settings restored to default"; |   PROGMEM Language_Str MSG_EEPROM_RESET             = u8"Settings restored to default"; | ||||||
|   PROGMEM Language_Str MSG_EEPROM_SAVED             = u8"Settings saved!"; |   PROGMEM Language_Str MSG_EEPROM_SAVED             = u8"Settings saved!"; | ||||||
|   PROGMEM Language_Str MSG_EEPROM_SAVE_PROMPT       = u8"Do you wish to save these settings as defaults?"; |   PROGMEM Language_Str MSG_EEPROM_SAVE_PROMPT       = u8"Do you wish to save these settings for next power-on?"; | ||||||
|   PROGMEM Language_Str MSG_EEPROM_RESET_WARNING     = u8"Are you sure? Customizations will be lost."; |   PROGMEM Language_Str MSG_EEPROM_RESET_WARNING     = u8"Are you sure? Customizations will be lost."; | ||||||
|  |  | ||||||
|   PROGMEM Language_Str MSG_PASSCODE_REJECTED        = u8"Wrong passcode!"; |   PROGMEM Language_Str MSG_PASSCODE_REJECTED        = u8"Wrong passcode!"; | ||||||
|   | |||||||
| @@ -767,6 +767,10 @@ namespace ExtUI { | |||||||
|       return steps > 0 ? CEIL(steps) : FLOOR(steps); |       return steps > 0 ? CEIL(steps) : FLOOR(steps); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     float mmFromWholeSteps(int16_t steps, const axis_t axis) { | ||||||
|  |       return steps * planner.steps_to_mm[axis]; | ||||||
|  |     } | ||||||
|  |  | ||||||
|   #endif // BABYSTEPPING |   #endif // BABYSTEPPING | ||||||
|  |  | ||||||
|   float getZOffset_mm() { |   float getZOffset_mm() { | ||||||
|   | |||||||
| @@ -239,6 +239,7 @@ namespace ExtUI { | |||||||
|  |  | ||||||
|   #if ENABLED(BABYSTEPPING) |   #if ENABLED(BABYSTEPPING) | ||||||
|     int16_t mmToWholeSteps(const_float_t mm, const axis_t axis); |     int16_t mmToWholeSteps(const_float_t mm, const axis_t axis); | ||||||
|  |     float mmFromWholeSteps(int16_t steps, const axis_t axis); | ||||||
|  |  | ||||||
|     bool babystepAxis_steps(const int16_t steps, const axis_t axis); |     bool babystepAxis_steps(const int16_t steps, const axis_t axis); | ||||||
|     void smartAdjustAxis_steps(const int16_t steps, const axis_t axis, bool linked_nozzles); |     void smartAdjustAxis_steps(const int16_t steps, const axis_t axis, bool linked_nozzles); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user