🚸 Fix and improve MKS LVGL UI (#22783)
Co-authored-by: makerbase <4164049@qq.com> Co-authored-by: MKS-Sean <56996910+MKS-Sean@users.noreply.github.com> Co-authored-by: Scott Lahteine <thinkyhead@users.noreply.github.com>
This commit is contained in:
@@ -32,10 +32,17 @@
|
||||
|
||||
static lv_obj_t *scr;
|
||||
extern lv_group_t* g;
|
||||
static lv_obj_t *buttonType, *buttonStep;
|
||||
static lv_obj_t *buttonType, *buttonStep, *buttonAdd, *buttonDec;
|
||||
static lv_obj_t *labelType;
|
||||
static lv_obj_t *labelStep;
|
||||
static lv_obj_t *tempText1;
|
||||
static lv_obj_t *btn_pla;
|
||||
static lv_obj_t *btn_abs;
|
||||
static lv_obj_t *label_abs;
|
||||
static lv_obj_t *label_pla;
|
||||
|
||||
static lv_style_t btn_style_pre;
|
||||
static lv_style_t btn_style_rel;
|
||||
|
||||
enum {
|
||||
ID_P_ADD = 1,
|
||||
@@ -43,7 +50,9 @@ enum {
|
||||
ID_P_TYPE,
|
||||
ID_P_STEP,
|
||||
ID_P_OFF,
|
||||
ID_P_RETURN
|
||||
ID_P_RETURN,
|
||||
ID_P_ABS,
|
||||
ID_P_PLA
|
||||
};
|
||||
|
||||
static void event_handler(lv_obj_t *obj, lv_event_t event) {
|
||||
@@ -55,10 +64,11 @@ static void event_handler(lv_obj_t *obj, lv_event_t event) {
|
||||
thermalManager.temp_hotend[uiCfg.extruderIndex].target += uiCfg.stepHeat;
|
||||
if (uiCfg.extruderIndex == 0)
|
||||
max_target = HEATER_0_MAXTEMP - (WATCH_TEMP_INCREASE + TEMP_HYSTERESIS + 1);
|
||||
#if HAS_MULTI_HOTEND
|
||||
else
|
||||
else {
|
||||
#if HAS_MULTI_HOTEND
|
||||
max_target = HEATER_1_MAXTEMP - (WATCH_TEMP_INCREASE + TEMP_HYSTERESIS + 1);
|
||||
#endif
|
||||
#endif
|
||||
}
|
||||
if (thermalManager.degTargetHotend(uiCfg.extruderIndex) > max_target)
|
||||
thermalManager.setTargetHotend(max_target, uiCfg.extruderIndex);
|
||||
thermalManager.start_watching_hotend(uiCfg.extruderIndex);
|
||||
@@ -83,16 +93,16 @@ static void event_handler(lv_obj_t *obj, lv_event_t event) {
|
||||
thermalManager.setTargetHotend(0, uiCfg.extruderIndex);
|
||||
thermalManager.start_watching_hotend(uiCfg.extruderIndex);
|
||||
}
|
||||
#if HAS_HEATED_BED
|
||||
else {
|
||||
else {
|
||||
#if HAS_HEATED_BED
|
||||
if (thermalManager.degTargetBed() > uiCfg.stepHeat)
|
||||
thermalManager.temp_bed.target -= uiCfg.stepHeat;
|
||||
else
|
||||
thermalManager.setTargetBed(0);
|
||||
|
||||
thermalManager.start_watching_bed();
|
||||
}
|
||||
#endif
|
||||
#endif
|
||||
}
|
||||
disp_desire_temp();
|
||||
break;
|
||||
case ID_P_TYPE:
|
||||
@@ -102,25 +112,24 @@ static void event_handler(lv_obj_t *obj, lv_event_t event) {
|
||||
uiCfg.extruderIndex = 1;
|
||||
}
|
||||
else if (uiCfg.extruderIndex == 1) {
|
||||
if (TEMP_SENSOR_BED != 0) {
|
||||
if (ENABLED(HAS_HEATED_BED)) {
|
||||
uiCfg.curTempType = 1;
|
||||
}
|
||||
else {
|
||||
uiCfg.curTempType = 0;
|
||||
uiCfg.curTempType = 0;
|
||||
uiCfg.extruderIndex = 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
else if (uiCfg.extruderIndex == 0) {
|
||||
if (TEMP_SENSOR_BED != 0)
|
||||
uiCfg.curTempType = 1;
|
||||
else
|
||||
uiCfg.curTempType = 0;
|
||||
uiCfg.curTempType = TERN(HAS_HEATED_BED, 1, 0);
|
||||
}
|
||||
}
|
||||
else if (uiCfg.curTempType == 1) {
|
||||
uiCfg.extruderIndex = 0;
|
||||
uiCfg.curTempType = 0;
|
||||
uiCfg.curTempType = 0;
|
||||
disp_add_dec();
|
||||
disp_ext_heart();
|
||||
}
|
||||
disp_temp_type();
|
||||
break;
|
||||
@@ -138,30 +147,44 @@ static void event_handler(lv_obj_t *obj, lv_event_t event) {
|
||||
thermalManager.setTargetHotend(0, uiCfg.extruderIndex);
|
||||
thermalManager.start_watching_hotend(uiCfg.extruderIndex);
|
||||
}
|
||||
#if HAS_HEATED_BED
|
||||
else {
|
||||
else {
|
||||
#if HAS_HEATED_BED
|
||||
thermalManager.temp_bed.target = 0;
|
||||
thermalManager.start_watching_bed();
|
||||
}
|
||||
#endif
|
||||
#endif
|
||||
}
|
||||
disp_desire_temp();
|
||||
break;
|
||||
case ID_P_RETURN:
|
||||
clear_cur_ui();
|
||||
draw_return_ui();
|
||||
break;
|
||||
case ID_P_ABS:
|
||||
thermalManager.setTargetHotend(PREHEAT_2_TEMP_HOTEND, 0);
|
||||
break;
|
||||
case ID_P_PLA:
|
||||
thermalManager.setTargetHotend(PREHEAT_1_TEMP_HOTEND, 0);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void disp_add_dec() {
|
||||
// Create image buttons
|
||||
buttonAdd = lv_big_button_create(scr, "F:/bmp_Add.bin", preheat_menu.add, INTERVAL_V, titleHeight, event_handler, ID_P_ADD);
|
||||
buttonDec = lv_big_button_create(scr, "F:/bmp_Dec.bin", preheat_menu.dec, BTN_X_PIXEL * 3 + INTERVAL_V * 4, titleHeight, event_handler, ID_P_DEC);
|
||||
}
|
||||
|
||||
void lv_draw_preHeat() {
|
||||
scr = lv_screen_create(PRE_HEAT_UI);
|
||||
|
||||
// Create image buttons
|
||||
lv_big_button_create(scr, "F:/bmp_Add.bin", preheat_menu.add, INTERVAL_V, titleHeight, event_handler, ID_P_ADD);
|
||||
lv_big_button_create(scr, "F:/bmp_Dec.bin", preheat_menu.dec, BTN_X_PIXEL * 3 + INTERVAL_V * 4, titleHeight, event_handler, ID_P_DEC);
|
||||
disp_add_dec();
|
||||
|
||||
buttonType = lv_imgbtn_create(scr, nullptr, INTERVAL_V, BTN_Y_PIXEL + INTERVAL_H + titleHeight, event_handler, ID_P_TYPE);
|
||||
buttonStep = lv_imgbtn_create(scr, nullptr, BTN_X_PIXEL + INTERVAL_V * 2, BTN_Y_PIXEL + INTERVAL_H + titleHeight, event_handler, ID_P_STEP);
|
||||
|
||||
if (uiCfg.curTempType == 0) disp_ext_heart();
|
||||
|
||||
#if HAS_ROTARY_ENCODER
|
||||
if (gCfgItems.encoder_enable) {
|
||||
lv_group_add_obj(g, buttonType);
|
||||
@@ -184,26 +207,38 @@ void lv_draw_preHeat() {
|
||||
disp_desire_temp();
|
||||
}
|
||||
|
||||
void disp_ext_heart() {
|
||||
btn_abs = lv_btn_create(scr, 160, 40, 80, 40, event_handler, ID_P_ABS);
|
||||
btn_pla = lv_btn_create(scr, 260, 40, 80, 40, event_handler, ID_P_PLA);
|
||||
|
||||
lv_btn_set_style(btn_abs, LV_BTN_STYLE_PR, &btn_style_pre);
|
||||
lv_btn_set_style(btn_abs, LV_BTN_STYLE_REL, &btn_style_rel);
|
||||
lv_btn_set_style(btn_pla, LV_BTN_STYLE_PR, &btn_style_pre);
|
||||
lv_btn_set_style(btn_pla, LV_BTN_STYLE_REL, &btn_style_rel);
|
||||
|
||||
label_abs = lv_label_create(btn_abs, PREHEAT_2_LABEL);
|
||||
label_pla = lv_label_create(btn_pla, PREHEAT_1_LABEL);
|
||||
}
|
||||
|
||||
void disp_temp_type() {
|
||||
if (uiCfg.curTempType == 0) {
|
||||
if (uiCfg.extruderIndex == 1) {
|
||||
lv_imgbtn_set_src_both(buttonType, "F:/bmp_extru2.bin");
|
||||
lv_imgbtn_set_src_both(buttonType, "F:/bmp_extru2.bin");
|
||||
if (gCfgItems.multiple_language) {
|
||||
lv_label_set_text(labelType, preheat_menu.ext2);
|
||||
lv_obj_align(labelType, buttonType, LV_ALIGN_IN_BOTTOM_MID, 0, BUTTON_TEXT_Y_OFFSET);
|
||||
}
|
||||
}
|
||||
else {
|
||||
lv_imgbtn_set_src_both(buttonType, "F:/bmp_extru1.bin");
|
||||
lv_imgbtn_set_src_both(buttonType, "F:/bmp_extru1.bin");
|
||||
if (gCfgItems.multiple_language) {
|
||||
lv_label_set_text(labelType, preheat_menu.ext1);
|
||||
lv_obj_align(labelType, buttonType, LV_ALIGN_IN_BOTTOM_MID, 0, BUTTON_TEXT_Y_OFFSET);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
else {
|
||||
lv_imgbtn_set_src_both(buttonType, "F:/bmp_bed.bin");
|
||||
lv_imgbtn_set_src_both(buttonType, "F:/bmp_bed.bin");
|
||||
if (gCfgItems.multiple_language) {
|
||||
lv_label_set_text(labelType, preheat_menu.hotbed);
|
||||
lv_obj_align(labelType, buttonType, LV_ALIGN_IN_BOTTOM_MID, 0, BUTTON_TEXT_Y_OFFSET);
|
||||
|
||||
Reference in New Issue
Block a user