mirror of
https://github.com/MarlinFirmware/Marlin.git
synced 2024-11-27 13:56:24 +00:00
Support 4.3" (480x272) Color UI display (#20334)
This commit is contained in:
parent
84ab088b40
commit
41e4124af9
@ -2438,6 +2438,7 @@
|
|||||||
//#define TOUCH_CALIBRATION_Y -8981
|
//#define TOUCH_CALIBRATION_Y -8981
|
||||||
//#define TOUCH_OFFSET_X -43
|
//#define TOUCH_OFFSET_X -43
|
||||||
//#define TOUCH_OFFSET_Y 257
|
//#define TOUCH_OFFSET_Y 257
|
||||||
|
//#define TOUCH_ORIENTATION TOUCH_LANDSCAPE
|
||||||
|
|
||||||
#if ENABLED(TFT_COLOR_UI)
|
#if ENABLED(TFT_COLOR_UI)
|
||||||
//#define SINGLE_TOUCH_NAVIGATION
|
//#define SINGLE_TOUCH_NAVIGATION
|
||||||
|
@ -1169,6 +1169,12 @@
|
|||||||
#elif ENABLED(TFT_INTERFACE_FSMC)
|
#elif ENABLED(TFT_INTERFACE_FSMC)
|
||||||
#define TFT_480x320
|
#define TFT_480x320
|
||||||
#endif
|
#endif
|
||||||
|
#elif ENABLED(TFT_COLOR_UI) && TFT_HEIGHT == 272
|
||||||
|
#if ENABLED(TFT_INTERFACE_SPI)
|
||||||
|
#define TFT_480x272_SPI
|
||||||
|
#elif ENABLED(TFT_INTERFACE_FSMC)
|
||||||
|
#define TFT_480x272
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Fewer lines with touch buttons on-screen
|
// Fewer lines with touch buttons on-screen
|
||||||
@ -1178,6 +1184,9 @@
|
|||||||
#elif EITHER(TFT_480x320, TFT_480x320_SPI)
|
#elif EITHER(TFT_480x320, TFT_480x320_SPI)
|
||||||
#define HAS_UI_480x320 1
|
#define HAS_UI_480x320 1
|
||||||
#define LCD_HEIGHT TERN(TOUCH_SCREEN, 6, 7)
|
#define LCD_HEIGHT TERN(TOUCH_SCREEN, 6, 7)
|
||||||
|
#elif EITHER(TFT_480x272, TFT_480x272_SPI)
|
||||||
|
#define HAS_UI_480x272 1
|
||||||
|
#define LCD_HEIGHT TERN(TOUCH_SCREEN, 6, 7)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// This emulated DOGM has 'touch/xpt2046', not 'tft/xpt2046'
|
// This emulated DOGM has 'touch/xpt2046', not 'tft/xpt2046'
|
||||||
|
@ -43,6 +43,9 @@
|
|||||||
#elif HAS_UI_480x320
|
#elif HAS_UI_480x320
|
||||||
#define TFT_WIDTH 480
|
#define TFT_WIDTH 480
|
||||||
#define TFT_HEIGHT 320
|
#define TFT_HEIGHT 320
|
||||||
|
#elif HAS_UI_480x272
|
||||||
|
#define TFT_WIDTH 480
|
||||||
|
#define TFT_HEIGHT 272
|
||||||
#else
|
#else
|
||||||
#error "Unsupported display resolution!"
|
#error "Unsupported display resolution!"
|
||||||
#endif
|
#endif
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
|
|
||||||
#include "../../inc/MarlinConfigPre.h"
|
#include "../../inc/MarlinConfigPre.h"
|
||||||
|
|
||||||
#if HAS_UI_480x320
|
#if HAS_UI_480x320 || HAS_UI_480x272
|
||||||
|
|
||||||
#include "ui_480x320.h"
|
#include "ui_480x320.h"
|
||||||
|
|
||||||
@ -56,9 +56,9 @@
|
|||||||
void MarlinUI::tft_idle() {
|
void MarlinUI::tft_idle() {
|
||||||
#if ENABLED(TOUCH_SCREEN)
|
#if ENABLED(TOUCH_SCREEN)
|
||||||
if (draw_menu_navigation) {
|
if (draw_menu_navigation) {
|
||||||
add_control(104, 286, PAGE_UP, imgPageUp, encoderTopLine > 0);
|
add_control(104, TFT_HEIGHT - 34, PAGE_UP, imgPageUp, encoderTopLine > 0);
|
||||||
add_control(344, 286, PAGE_DOWN, imgPageDown, encoderTopLine + LCD_HEIGHT < screen_items);
|
add_control(344, TFT_HEIGHT - 34, PAGE_DOWN, imgPageDown, encoderTopLine + LCD_HEIGHT < screen_items);
|
||||||
add_control(224, 286, BACK, imgBack);
|
add_control(224, TFT_HEIGHT - 34, BACK, imgBack);
|
||||||
draw_menu_navigation = false;
|
draw_menu_navigation = false;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -259,10 +259,12 @@ void MarlinUI::draw_status_screen() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
y += TERN(HAS_UI_480x272, 118, 128);
|
||||||
|
|
||||||
// coordinates
|
// coordinates
|
||||||
tft.canvas(4, 132, TFT_WIDTH - 8, 34);
|
tft.canvas(4, y, TFT_WIDTH - 8, FONT_LINE_HEIGHT);
|
||||||
tft.set_background(COLOR_BACKGROUND);
|
tft.set_background(COLOR_BACKGROUND);
|
||||||
tft.add_rectangle(0, 0, TFT_WIDTH - 8, 34, COLOR_AXIS_HOMED);
|
tft.add_rectangle(0, 0, TFT_WIDTH - 8, FONT_LINE_HEIGHT, COLOR_AXIS_HOMED);
|
||||||
|
|
||||||
tft.add_text( 16, 3, COLOR_AXIS_HOMED , "X");
|
tft.add_text( 16, 3, COLOR_AXIS_HOMED , "X");
|
||||||
tft.add_text(192, 3, COLOR_AXIS_HOMED , "Y");
|
tft.add_text(192, 3, COLOR_AXIS_HOMED , "Y");
|
||||||
@ -290,10 +292,11 @@ void MarlinUI::draw_status_screen() {
|
|||||||
offset -= tft_string.width();
|
offset -= tft_string.width();
|
||||||
}
|
}
|
||||||
tft.add_text(455 - tft_string.width() - offset, 3, not_homed ? COLOR_AXIS_NOT_HOMED : COLOR_AXIS_HOMED, tft_string);
|
tft.add_text(455 - tft_string.width() - offset, 3, not_homed ? COLOR_AXIS_NOT_HOMED : COLOR_AXIS_HOMED, tft_string);
|
||||||
TERN_(TOUCH_SCREEN, touch.add_control(MOVE_AXIS, 4, 132, TFT_WIDTH - 8, 34));
|
TERN_(TOUCH_SCREEN, touch.add_control(MOVE_AXIS, 4, y, TFT_WIDTH - 8, FONT_LINE_HEIGHT));
|
||||||
|
|
||||||
|
y += TERN(HAS_UI_480x272, 38, 48);
|
||||||
// feed rate
|
// feed rate
|
||||||
tft.canvas(96, 180, 100, 32);
|
tft.canvas(96, y, 100, 32);
|
||||||
tft.set_background(COLOR_BACKGROUND);
|
tft.set_background(COLOR_BACKGROUND);
|
||||||
uint16_t color = feedrate_percentage == 100 ? COLOR_RATE_100 : COLOR_RATE_ALTERED;
|
uint16_t color = feedrate_percentage == 100 ? COLOR_RATE_100 : COLOR_RATE_ALTERED;
|
||||||
tft.add_image(0, 0, imgFeedRate, color);
|
tft.add_image(0, 0, imgFeedRate, color);
|
||||||
@ -303,7 +306,7 @@ void MarlinUI::draw_status_screen() {
|
|||||||
TERN_(TOUCH_SCREEN, touch.add_control(FEEDRATE, 96, 176, 100, 32));
|
TERN_(TOUCH_SCREEN, touch.add_control(FEEDRATE, 96, 176, 100, 32));
|
||||||
|
|
||||||
// flow rate
|
// flow rate
|
||||||
tft.canvas(284, 180, 100, 32);
|
tft.canvas(284, y, 100, 32);
|
||||||
tft.set_background(COLOR_BACKGROUND);
|
tft.set_background(COLOR_BACKGROUND);
|
||||||
color = planner.flow_percentage[0] == 100 ? COLOR_RATE_100 : COLOR_RATE_ALTERED;
|
color = planner.flow_percentage[0] == 100 ? COLOR_RATE_100 : COLOR_RATE_ALTERED;
|
||||||
tft.add_image(0, 0, imgFlowRate, color);
|
tft.add_image(0, 0, imgFlowRate, color);
|
||||||
@ -312,36 +315,38 @@ void MarlinUI::draw_status_screen() {
|
|||||||
tft.add_text(36, 1, color , tft_string);
|
tft.add_text(36, 1, color , tft_string);
|
||||||
TERN_(TOUCH_SCREEN, touch.add_control(FLOWRATE, 284, 176, 100, 32, active_extruder));
|
TERN_(TOUCH_SCREEN, touch.add_control(FLOWRATE, 284, 176, 100, 32, active_extruder));
|
||||||
|
|
||||||
|
#if ENABLED(TOUCH_SCREEN)
|
||||||
|
add_control(404, y, menu_main, imgSettings);
|
||||||
|
TERN_(SDSUPPORT, add_control(12, y, menu_media, imgSD, !printingIsActive(), COLOR_CONTROL_ENABLED, card.isMounted() && printingIsActive() ? COLOR_BUSY : COLOR_CONTROL_DISABLED));
|
||||||
|
#endif
|
||||||
|
|
||||||
|
y += TERN(HAS_UI_480x272, 36, 44);
|
||||||
// print duration
|
// print duration
|
||||||
char buffer[14];
|
char buffer[14];
|
||||||
duration_t elapsed = print_job_timer.duration();
|
duration_t elapsed = print_job_timer.duration();
|
||||||
elapsed.toDigital(buffer);
|
elapsed.toDigital(buffer);
|
||||||
|
|
||||||
tft.canvas((TFT_WIDTH - 128) / 2, 224, 128, 29);
|
tft.canvas((TFT_WIDTH - 128) / 2, y, 128, 29);
|
||||||
tft.set_background(COLOR_BACKGROUND);
|
tft.set_background(COLOR_BACKGROUND);
|
||||||
tft_string.set(buffer);
|
tft_string.set(buffer);
|
||||||
tft.add_text(tft_string.center(128), 0, COLOR_PRINT_TIME, tft_string);
|
tft.add_text(tft_string.center(128), 0, COLOR_PRINT_TIME, tft_string);
|
||||||
|
|
||||||
|
y += TERN(HAS_UI_480x272, 28, 36);
|
||||||
// progress bar
|
// progress bar
|
||||||
const uint8_t progress = ui.get_progress_percent();
|
const uint8_t progress = ui.get_progress_percent();
|
||||||
tft.canvas(4, 260, TFT_WIDTH - 8, 9);
|
tft.canvas(4, y, TFT_WIDTH - 8, 9);
|
||||||
tft.set_background(COLOR_PROGRESS_BG);
|
tft.set_background(COLOR_PROGRESS_BG);
|
||||||
tft.add_rectangle(0, 0, TFT_WIDTH - 8, 9, COLOR_PROGRESS_FRAME);
|
tft.add_rectangle(0, 0, TFT_WIDTH - 8, 9, COLOR_PROGRESS_FRAME);
|
||||||
if (progress)
|
if (progress)
|
||||||
tft.add_bar(1, 1, ((TFT_WIDTH - 10) * progress) / 100, 7, COLOR_PROGRESS_BAR);
|
tft.add_bar(1, 1, ((TFT_WIDTH - 10) * progress) / 100, 7, COLOR_PROGRESS_BAR);
|
||||||
|
|
||||||
|
y += 20;
|
||||||
// status message
|
// status message
|
||||||
tft.canvas(0, 280, TFT_WIDTH, 29);
|
tft.canvas(0, y, TFT_WIDTH, FONT_LINE_HEIGHT - 5);
|
||||||
tft.set_background(COLOR_BACKGROUND);
|
tft.set_background(COLOR_BACKGROUND);
|
||||||
tft_string.set(status_message);
|
tft_string.set(status_message);
|
||||||
tft_string.trim();
|
tft_string.trim();
|
||||||
tft.add_text(tft_string.center(TFT_WIDTH), 0, COLOR_STATUS_MESSAGE, tft_string);
|
tft.add_text(tft_string.center(TFT_WIDTH), 0, COLOR_STATUS_MESSAGE, tft_string);
|
||||||
|
|
||||||
|
|
||||||
#if ENABLED(TOUCH_SCREEN)
|
|
||||||
add_control(404, 180, menu_main, imgSettings);
|
|
||||||
TERN_(SDSUPPORT, add_control(12, 180, menu_media, imgSD, !printingIsActive(), COLOR_CONTROL_ENABLED, card.isMounted() && printingIsActive() ? COLOR_BUSY : COLOR_CONTROL_DISABLED));
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Draw a static item with no left-right margin required. Centered by default.
|
// Draw a static item with no left-right margin required. Centered by default.
|
||||||
@ -450,9 +455,9 @@ void MenuEditItemBase::draw_edit_screen(PGM_P const pstr, const char* const valu
|
|||||||
|
|
||||||
void TFT::draw_edit_screen_buttons() {
|
void TFT::draw_edit_screen_buttons() {
|
||||||
#if ENABLED(TOUCH_SCREEN)
|
#if ENABLED(TOUCH_SCREEN)
|
||||||
add_control(64, 256, DECREASE, imgDecrease);
|
add_control(64, TFT_HEIGHT - 64, DECREASE, imgDecrease);
|
||||||
add_control(352, 256, INCREASE, imgIncrease);
|
add_control(352, TFT_HEIGHT - 64, INCREASE, imgIncrease);
|
||||||
add_control(208, 256, CLICK, imgConfirm);
|
add_control(208, TFT_HEIGHT - 64, CLICK, imgConfirm);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -481,8 +486,8 @@ void MenuItem_confirm::draw_select_screen(PGM_P const yes, PGM_P const no, const
|
|||||||
tft.add_text(tft_string.center(TFT_WIDTH), 0, COLOR_MENU_TEXT, tft_string);
|
tft.add_text(tft_string.center(TFT_WIDTH), 0, COLOR_MENU_TEXT, tft_string);
|
||||||
}
|
}
|
||||||
#if ENABLED(TOUCH_SCREEN)
|
#if ENABLED(TOUCH_SCREEN)
|
||||||
add_control(88, 256, CANCEL, imgCancel, true, yesno ? HALF(COLOR_CONTROL_CANCEL) : COLOR_CONTROL_CANCEL);
|
add_control(88, TFT_HEIGHT - 64, CANCEL, imgCancel, true, yesno ? HALF(COLOR_CONTROL_CANCEL) : COLOR_CONTROL_CANCEL);
|
||||||
add_control(328, 256, CONFIRM, imgConfirm, true, yesno ? COLOR_CONTROL_CONFIRM : HALF(COLOR_CONTROL_CONFIRM));
|
add_control(328, TFT_HEIGHT - 64, CONFIRM, imgConfirm, true, yesno ? COLOR_CONTROL_CONFIRM : HALF(COLOR_CONTROL_CONFIRM));
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -541,7 +546,7 @@ void MenuItem_confirm::draw_select_screen(PGM_P const yes, PGM_P const no, const
|
|||||||
const xy_pos_t pos = { ubl.mesh_index_to_xpos(x_plot), ubl.mesh_index_to_ypos(y_plot) },
|
const xy_pos_t pos = { ubl.mesh_index_to_xpos(x_plot), ubl.mesh_index_to_ypos(y_plot) },
|
||||||
lpos = pos.asLogical();
|
lpos = pos.asLogical();
|
||||||
|
|
||||||
tft.canvas(320, GRID_OFFSET_Y + (GRID_HEIGHT - 43) / 2 - 43, 120, 43);
|
tft.canvas(320, GRID_OFFSET_Y + (GRID_HEIGHT - MENU_ITEM_HEIGHT) / 2 - MENU_ITEM_HEIGHT, 120, MENU_ITEM_HEIGHT);
|
||||||
tft.set_background(COLOR_BACKGROUND);
|
tft.set_background(COLOR_BACKGROUND);
|
||||||
tft_string.set(X_LBL);
|
tft_string.set(X_LBL);
|
||||||
tft.add_text(0, MENU_TEXT_Y_OFFSET, COLOR_MENU_TEXT, tft_string);
|
tft.add_text(0, MENU_TEXT_Y_OFFSET, COLOR_MENU_TEXT, tft_string);
|
||||||
@ -549,7 +554,7 @@ void MenuItem_confirm::draw_select_screen(PGM_P const yes, PGM_P const no, const
|
|||||||
tft_string.trim();
|
tft_string.trim();
|
||||||
tft.add_text(120 - tft_string.width(), MENU_TEXT_Y_OFFSET, COLOR_MENU_VALUE, tft_string);
|
tft.add_text(120 - tft_string.width(), MENU_TEXT_Y_OFFSET, COLOR_MENU_VALUE, tft_string);
|
||||||
|
|
||||||
tft.canvas(320, GRID_OFFSET_Y + (GRID_HEIGHT - 43) / 2, 120, 43);
|
tft.canvas(320, GRID_OFFSET_Y + (GRID_HEIGHT - MENU_ITEM_HEIGHT) / 2, 120, MENU_ITEM_HEIGHT);
|
||||||
tft.set_background(COLOR_BACKGROUND);
|
tft.set_background(COLOR_BACKGROUND);
|
||||||
tft_string.set(Y_LBL);
|
tft_string.set(Y_LBL);
|
||||||
tft.add_text(0, MENU_TEXT_Y_OFFSET, COLOR_MENU_TEXT, tft_string);
|
tft.add_text(0, MENU_TEXT_Y_OFFSET, COLOR_MENU_TEXT, tft_string);
|
||||||
@ -557,7 +562,7 @@ void MenuItem_confirm::draw_select_screen(PGM_P const yes, PGM_P const no, const
|
|||||||
tft_string.trim();
|
tft_string.trim();
|
||||||
tft.add_text(120 - tft_string.width(), MENU_TEXT_Y_OFFSET, COLOR_MENU_VALUE, tft_string);
|
tft.add_text(120 - tft_string.width(), MENU_TEXT_Y_OFFSET, COLOR_MENU_VALUE, tft_string);
|
||||||
|
|
||||||
tft.canvas(320, GRID_OFFSET_Y + (GRID_HEIGHT - 43) / 2 + 43, 120, 43);
|
tft.canvas(320, GRID_OFFSET_Y + (GRID_HEIGHT - MENU_ITEM_HEIGHT) / 2 + MENU_ITEM_HEIGHT, 120, MENU_ITEM_HEIGHT);
|
||||||
tft.set_background(COLOR_BACKGROUND);
|
tft.set_background(COLOR_BACKGROUND);
|
||||||
tft_string.set(Z_LBL);
|
tft_string.set(Z_LBL);
|
||||||
tft.add_text(0, MENU_TEXT_Y_OFFSET, COLOR_MENU_TEXT, tft_string);
|
tft.add_text(0, MENU_TEXT_Y_OFFSET, COLOR_MENU_TEXT, tft_string);
|
||||||
@ -566,13 +571,13 @@ void MenuItem_confirm::draw_select_screen(PGM_P const yes, PGM_P const no, const
|
|||||||
tft.add_text(120 - tft_string.width(), MENU_TEXT_Y_OFFSET, COLOR_MENU_VALUE, tft_string);
|
tft.add_text(120 - tft_string.width(), MENU_TEXT_Y_OFFSET, COLOR_MENU_VALUE, tft_string);
|
||||||
|
|
||||||
|
|
||||||
tft.canvas(GRID_OFFSET_X + (GRID_WIDTH - 48) / 2, GRID_OFFSET_Y + GRID_HEIGHT + CONTROL_OFFSET - 5, 48, 43);
|
tft.canvas(GRID_OFFSET_X + (GRID_WIDTH - 48) / 2, GRID_OFFSET_Y + GRID_HEIGHT + CONTROL_OFFSET - 5, 48, MENU_ITEM_HEIGHT);
|
||||||
tft.set_background(COLOR_BACKGROUND);
|
tft.set_background(COLOR_BACKGROUND);
|
||||||
tft_string.set(ui8tostr3rj(x_plot));
|
tft_string.set(ui8tostr3rj(x_plot));
|
||||||
tft_string.trim();
|
tft_string.trim();
|
||||||
tft.add_text(tft_string.center(48), MENU_TEXT_Y_OFFSET, COLOR_MENU_VALUE, tft_string);
|
tft.add_text(tft_string.center(48), MENU_TEXT_Y_OFFSET, COLOR_MENU_VALUE, tft_string);
|
||||||
|
|
||||||
tft.canvas(GRID_OFFSET_X + GRID_WIDTH + CONTROL_OFFSET + 16 - 24, GRID_OFFSET_Y + (GRID_HEIGHT - 43) / 2, 48, 43);
|
tft.canvas(GRID_OFFSET_X + GRID_WIDTH + CONTROL_OFFSET + 16 - 24, GRID_OFFSET_Y + (GRID_HEIGHT - MENU_ITEM_HEIGHT) / 2, 48, MENU_ITEM_HEIGHT);
|
||||||
tft.set_background(COLOR_BACKGROUND);
|
tft.set_background(COLOR_BACKGROUND);
|
||||||
tft_string.set(ui8tostr3rj(y_plot));
|
tft_string.set(ui8tostr3rj(y_plot));
|
||||||
tft_string.trim();
|
tft_string.trim();
|
||||||
@ -586,7 +591,7 @@ void MenuItem_confirm::draw_select_screen(PGM_P const yes, PGM_P const no, const
|
|||||||
add_control(GRID_OFFSET_X + CONTROL_OFFSET, GRID_OFFSET_Y + GRID_HEIGHT + CONTROL_OFFSET, UBL, - ENCODER_STEPS_PER_MENU_ITEM, imgLeft);
|
add_control(GRID_OFFSET_X + CONTROL_OFFSET, GRID_OFFSET_Y + GRID_HEIGHT + CONTROL_OFFSET, UBL, - ENCODER_STEPS_PER_MENU_ITEM, imgLeft);
|
||||||
add_control(GRID_OFFSET_X + GRID_WIDTH - CONTROL_OFFSET - 32, GRID_OFFSET_Y + GRID_HEIGHT + CONTROL_OFFSET, UBL, ENCODER_STEPS_PER_MENU_ITEM, imgRight);
|
add_control(GRID_OFFSET_X + GRID_WIDTH - CONTROL_OFFSET - 32, GRID_OFFSET_Y + GRID_HEIGHT + CONTROL_OFFSET, UBL, ENCODER_STEPS_PER_MENU_ITEM, imgRight);
|
||||||
add_control(320, GRID_OFFSET_Y + GRID_HEIGHT + CONTROL_OFFSET, CLICK, imgLeveling);
|
add_control(320, GRID_OFFSET_Y + GRID_HEIGHT + CONTROL_OFFSET, CLICK, imgLeveling);
|
||||||
add_control(224, 286, BACK, imgBack);
|
add_control(224, TFT_HEIGHT - 34, BACK, imgBack);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
#endif // AUTO_BED_LEVELING_UBL
|
#endif // AUTO_BED_LEVELING_UBL
|
||||||
@ -644,7 +649,7 @@ void MenuItem_confirm::draw_select_screen(PGM_P const yes, PGM_P const no, const
|
|||||||
#endif // TOUCH_SCREEN_CALIBRATION
|
#endif // TOUCH_SCREEN_CALIBRATION
|
||||||
|
|
||||||
void menu_line(const uint8_t row, uint16_t color) {
|
void menu_line(const uint8_t row, uint16_t color) {
|
||||||
tft.canvas(0, 4 + 45 * row, TFT_WIDTH, 43);
|
tft.canvas(0, 4 + (MENU_ITEM_HEIGHT + 2) * row, TFT_WIDTH, MENU_ITEM_HEIGHT);
|
||||||
tft.set_background(color);
|
tft.set_background(color);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -661,7 +666,7 @@ void menu_item(const uint8_t row, bool sel ) {
|
|||||||
menu_line(row, sel ? COLOR_SELECTION_BG : COLOR_BACKGROUND);
|
menu_line(row, sel ? COLOR_SELECTION_BG : COLOR_BACKGROUND);
|
||||||
#if ENABLED(TOUCH_SCREEN)
|
#if ENABLED(TOUCH_SCREEN)
|
||||||
const TouchControlType tct = TERN(SINGLE_TOUCH_NAVIGATION, true, sel) ? MENU_CLICK : MENU_ITEM;
|
const TouchControlType tct = TERN(SINGLE_TOUCH_NAVIGATION, true, sel) ? MENU_CLICK : MENU_ITEM;
|
||||||
touch.add_control(tct, 0, 4 + 45 * row, TFT_WIDTH, 43, encoderTopLine + row);
|
touch.add_control(tct, 0, 4 + (MENU_ITEM_HEIGHT + 2) * row, TFT_WIDTH, MENU_ITEM_HEIGHT, encoderTopLine + row);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -38,8 +38,17 @@ void draw_fan_status(uint16_t x, uint16_t y, const bool blink);
|
|||||||
void menu_line(const uint8_t row, uint16_t color = COLOR_BACKGROUND);
|
void menu_line(const uint8_t row, uint16_t color = COLOR_BACKGROUND);
|
||||||
void menu_item(const uint8_t row, bool sel = false);
|
void menu_item(const uint8_t row, bool sel = false);
|
||||||
|
|
||||||
#define MENU_FONT_NAME Helvetica18
|
#if HAS_UI_480x320
|
||||||
#define SYMBOLS_FONT_NAME Helvetica18_symbols
|
#define MENU_FONT_NAME Helvetica18
|
||||||
|
#define SYMBOLS_FONT_NAME Helvetica18_symbols
|
||||||
|
#define MENU_ITEM_HEIGHT 43
|
||||||
|
#define FONT_LINE_HEIGHT 34
|
||||||
|
#elif HAS_UI_480x272
|
||||||
|
#define MENU_FONT_NAME Helvetica14
|
||||||
|
#define SYMBOLS_FONT_NAME Helvetica14_symbols
|
||||||
|
#define MENU_ITEM_HEIGHT 36
|
||||||
|
#define FONT_LINE_HEIGHT 24
|
||||||
|
#endif
|
||||||
|
|
||||||
#define ABSOLUTE_ZERO -273.15
|
#define ABSOLUTE_ZERO -273.15
|
||||||
|
|
||||||
|
@ -39,10 +39,10 @@
|
|||||||
IF_0((TFT_ORIENTATION) & TFT_INVERT_X, SSD1963_MADCTL_FH) | \
|
IF_0((TFT_ORIENTATION) & TFT_INVERT_X, SSD1963_MADCTL_FH) | \
|
||||||
IF_0((TFT_ORIENTATION) & TFT_INVERT_Y, SSD1963_MADCTL_FV)
|
IF_0((TFT_ORIENTATION) & TFT_INVERT_Y, SSD1963_MADCTL_FV)
|
||||||
|
|
||||||
#if !defined(TFT_COLOR) || TFT_COLOR == TFT_COLOR_BGR
|
#if !defined(TFT_COLOR) || TFT_COLOR == TFT_COLOR_RGB
|
||||||
#define SSD1963_COLOR SSD1963_MADCTL_BGR
|
|
||||||
#elif TFT_COLOR == TFT_COLOR_RGB
|
|
||||||
#define SSD1963_COLOR SSD1963_MADCTL_RGB
|
#define SSD1963_COLOR SSD1963_MADCTL_RGB
|
||||||
|
#elif TFT_COLOR == TFT_COLOR_BGR
|
||||||
|
#define SSD1963_COLOR SSD1963_MADCTL_BGR
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define SSD1963_MADCTL_DATA (SSD1963_ORIENTATION) | (SSD1963_COLOR)
|
#define SSD1963_MADCTL_DATA (SSD1963_ORIENTATION) | (SSD1963_COLOR)
|
||||||
|
@ -23,6 +23,11 @@
|
|||||||
|
|
||||||
#include "touch_calibration.h"
|
#include "touch_calibration.h"
|
||||||
|
|
||||||
|
#define TOUCH_CALIBRATION_MAX_RETRIES 5
|
||||||
|
|
||||||
|
#define DEBUG_OUT ENABLED(DEBUG_TOUCH_CALIBRATION)
|
||||||
|
#include "../../core/debug_out.h"
|
||||||
|
|
||||||
TouchCalibration touch_calibration;
|
TouchCalibration touch_calibration;
|
||||||
|
|
||||||
touch_calibration_t TouchCalibration::calibration;
|
touch_calibration_t TouchCalibration::calibration;
|
||||||
@ -31,23 +36,40 @@ touch_calibration_point_t TouchCalibration::calibration_points[4];
|
|||||||
uint8_t TouchCalibration::failed_count;
|
uint8_t TouchCalibration::failed_count;
|
||||||
|
|
||||||
void TouchCalibration::validate_calibration() {
|
void TouchCalibration::validate_calibration() {
|
||||||
const bool landscape = validate_precision_x(0, 1) && validate_precision_x(2, 3) && validate_precision_y(0, 2) && validate_precision_y(1, 3);
|
#define VALIDATE_PRECISION(XY, A, B) validate_precision_##XY(CALIBRATION_##A, CALIBRATION_##B)
|
||||||
const bool portrait = validate_precision_y(0, 1) && validate_precision_y(2, 3) && validate_precision_x(0, 2) && validate_precision_x(1, 3);
|
const bool landscape = VALIDATE_PRECISION(x, TOP_LEFT, BOTTOM_LEFT)
|
||||||
|
&& VALIDATE_PRECISION(x, TOP_RIGHT, BOTTOM_RIGHT)
|
||||||
|
&& VALIDATE_PRECISION(y, TOP_LEFT, TOP_RIGHT)
|
||||||
|
&& VALIDATE_PRECISION(y, BOTTOM_LEFT, BOTTOM_RIGHT);
|
||||||
|
const bool portrait = VALIDATE_PRECISION(y, TOP_LEFT, BOTTOM_LEFT)
|
||||||
|
&& VALIDATE_PRECISION(y, TOP_RIGHT, BOTTOM_RIGHT)
|
||||||
|
&& VALIDATE_PRECISION(x, TOP_LEFT, TOP_RIGHT)
|
||||||
|
&& VALIDATE_PRECISION(x, BOTTOM_LEFT, BOTTOM_RIGHT);
|
||||||
|
#undef VALIDATE_PRECISION
|
||||||
|
|
||||||
if (landscape || portrait) {
|
#define CAL_PTS(N) calibration_points[CALIBRATION_##N]
|
||||||
|
if (landscape) {
|
||||||
calibration_state = CALIBRATION_SUCCESS;
|
calibration_state = CALIBRATION_SUCCESS;
|
||||||
calibration.x = ((calibration_points[2].x - calibration_points[0].x) << 17) / (calibration_points[3].raw_x + calibration_points[2].raw_x - calibration_points[1].raw_x - calibration_points[0].raw_x);
|
calibration.x = ((CAL_PTS(TOP_RIGHT).x - CAL_PTS(TOP_LEFT).x) << 17) / (CAL_PTS(BOTTOM_RIGHT).raw_x + CAL_PTS(TOP_RIGHT).raw_x - CAL_PTS(BOTTOM_LEFT).raw_x - CAL_PTS(TOP_LEFT).raw_x);
|
||||||
calibration.y = ((calibration_points[1].y - calibration_points[0].y) << 17) / (calibration_points[3].raw_y - calibration_points[2].raw_y + calibration_points[1].raw_y - calibration_points[0].raw_y);
|
calibration.y = ((CAL_PTS(BOTTOM_LEFT).y - CAL_PTS(TOP_LEFT).y) << 17) / (CAL_PTS(BOTTOM_RIGHT).raw_y - CAL_PTS(TOP_RIGHT).raw_y + CAL_PTS(BOTTOM_LEFT).raw_y - CAL_PTS(TOP_LEFT).raw_y);
|
||||||
calibration.offset_x = calibration_points[0].x - int16_t(((calibration_points[0].raw_x + calibration_points[1].raw_x) * calibration.x) >> 17);
|
calibration.offset_x = CAL_PTS(TOP_LEFT).x - int16_t(((CAL_PTS(TOP_LEFT).raw_x + CAL_PTS(BOTTOM_LEFT).raw_x) * calibration.x) >> 17);
|
||||||
calibration.offset_y = calibration_points[0].y - int16_t(((calibration_points[0].raw_y + calibration_points[2].raw_y) * calibration.y) >> 17);
|
calibration.offset_y = CAL_PTS(TOP_LEFT).y - int16_t(((CAL_PTS(TOP_LEFT).raw_y + CAL_PTS(TOP_RIGHT).raw_y) * calibration.y) >> 17);
|
||||||
calibration.orientation = landscape ? TOUCH_LANDSCAPE : TOUCH_PORTRAIT;
|
calibration.orientation = TOUCH_LANDSCAPE;
|
||||||
|
}
|
||||||
|
else if (portrait) {
|
||||||
|
calibration_state = CALIBRATION_SUCCESS;
|
||||||
|
calibration.x = ((CAL_PTS(TOP_RIGHT).x - CAL_PTS(TOP_LEFT).x) << 17) / (CAL_PTS(BOTTOM_RIGHT).raw_y + CAL_PTS(TOP_RIGHT).raw_y - CAL_PTS(BOTTOM_LEFT).raw_y - CAL_PTS(TOP_LEFT).raw_y);
|
||||||
|
calibration.y = ((CAL_PTS(BOTTOM_LEFT).y - CAL_PTS(TOP_LEFT).y) << 17) / (CAL_PTS(BOTTOM_RIGHT).raw_x - CAL_PTS(TOP_RIGHT).raw_x + CAL_PTS(BOTTOM_LEFT).raw_x - CAL_PTS(TOP_LEFT).raw_x);
|
||||||
|
calibration.offset_x = CAL_PTS(TOP_LEFT).x - int16_t(((CAL_PTS(TOP_LEFT).raw_y + CAL_PTS(BOTTOM_LEFT).raw_y) * calibration.x) >> 17);
|
||||||
|
calibration.offset_y = CAL_PTS(TOP_LEFT).y - int16_t(((CAL_PTS(TOP_LEFT).raw_x + CAL_PTS(TOP_RIGHT).raw_x) * calibration.y) >> 17);
|
||||||
|
calibration.orientation = TOUCH_PORTRAIT;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
calibration_state = CALIBRATION_FAIL;
|
calibration_state = CALIBRATION_FAIL;
|
||||||
calibration_reset();
|
calibration_reset();
|
||||||
// Retry up to 5 times before reporting the failure
|
if (need_calibration() && failed_count++ < TOUCH_CALIBRATION_MAX_RETRIES) calibration_state = CALIBRATION_TOP_LEFT;
|
||||||
if (need_calibration() && failed_count++ < 5) calibration_state = CALIBRATION_TOP_LEFT;
|
|
||||||
}
|
}
|
||||||
|
#undef CAL_PTS
|
||||||
|
|
||||||
if (calibration_state == CALIBRATION_SUCCESS) {
|
if (calibration_state == CALIBRATION_SUCCESS) {
|
||||||
SERIAL_ECHOLNPGM("Touch screen calibration completed");
|
SERIAL_ECHOLNPGM("Touch screen calibration completed");
|
||||||
@ -55,7 +77,7 @@ void TouchCalibration::validate_calibration() {
|
|||||||
SERIAL_ECHOLNPAIR("TOUCH_CALIBRATION_Y ", calibration.y);
|
SERIAL_ECHOLNPAIR("TOUCH_CALIBRATION_Y ", calibration.y);
|
||||||
SERIAL_ECHOLNPAIR("TOUCH_OFFSET_X ", calibration.offset_x);
|
SERIAL_ECHOLNPAIR("TOUCH_OFFSET_X ", calibration.offset_x);
|
||||||
SERIAL_ECHOLNPAIR("TOUCH_OFFSET_Y ", calibration.offset_y);
|
SERIAL_ECHOLNPAIR("TOUCH_OFFSET_Y ", calibration.offset_y);
|
||||||
SERIAL_ECHOPGM("TOUCH_ORIENTATION "); if (calibration.orientation == TOUCH_LANDSCAPE) SERIAL_ECHOLNPGM("TOUCH_LANDSCAPE"); else SERIAL_ECHOLNPGM("TOUCH_PORTRAIT");
|
SERIAL_ECHO_TERNARY(calibration.orientation == TOUCH_LANDSCAPE, "TOUCH_ORIENTATION ", "TOUCH_LANDSCAPE", "TOUCH_PORTRAIT", "\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -68,6 +90,7 @@ bool TouchCalibration::handleTouch(uint16_t x, uint16_t y) {
|
|||||||
if (calibration_state < CALIBRATION_SUCCESS) {
|
if (calibration_state < CALIBRATION_SUCCESS) {
|
||||||
calibration_points[calibration_state].raw_x = x;
|
calibration_points[calibration_state].raw_x = x;
|
||||||
calibration_points[calibration_state].raw_y = y;
|
calibration_points[calibration_state].raw_y = y;
|
||||||
|
DEBUG_ECHOLNPAIR("TouchCalibration - State: ", calibration_state, ", x: ", calibration_points[calibration_state].x, ", raw_x: ", x, ", y: ", calibration_points[calibration_state].y, ", raw_y: ", y);
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (calibration_state) {
|
switch (calibration_state) {
|
||||||
|
@ -155,11 +155,6 @@
|
|||||||
#define TOUCH_INT_PIN PB1
|
#define TOUCH_INT_PIN PB1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Touchscreen calibration does not work correctly with ANET_ET5_TFT35 or ANET_ET4_TFT28
|
|
||||||
#if ENABLED(TOUCH_SCREEN_CALIBRATION)
|
|
||||||
#undef TOUCH_SCREEN_CALIBRATION
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if ENABLED(ANET_ET5_TFT35)
|
#if ENABLED(ANET_ET5_TFT35)
|
||||||
#ifndef TOUCH_CALIBRATION_X
|
#ifndef TOUCH_CALIBRATION_X
|
||||||
#define TOUCH_CALIBRATION_X 17125
|
#define TOUCH_CALIBRATION_X 17125
|
||||||
|
Loading…
Reference in New Issue
Block a user