268 lines
8.8 KiB
C++
268 lines
8.8 KiB
C++
/**
|
|
* Marlin 3D Printer Firmware
|
|
* Copyright (c) 2020 MarlinFirmware [https://github.com/MarlinFirmware/Marlin]
|
|
*
|
|
* Based on Sprinter and grbl.
|
|
* Copyright (c) 2011 Camiel Gubbels / Erik van der Zalm
|
|
*
|
|
* 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 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
*
|
|
*/
|
|
#include "../../../inc/MarlinConfigPre.h"
|
|
|
|
#if HAS_TFT_LVGL_UI
|
|
|
|
#include "draw_ui.h"
|
|
#include <lv_conf.h>
|
|
|
|
#include "../../../module/temperature.h"
|
|
#include "../../../inc/MarlinConfig.h"
|
|
|
|
static lv_obj_t *scr;
|
|
extern lv_group_t* g;
|
|
static lv_obj_t *buttonType, *buttonStep;
|
|
static lv_obj_t *labelType;
|
|
static lv_obj_t *labelStep;
|
|
static lv_obj_t *tempText1;
|
|
|
|
enum {
|
|
ID_P_ADD = 1,
|
|
ID_P_DEC,
|
|
ID_P_TYPE,
|
|
ID_P_STEP,
|
|
ID_P_OFF,
|
|
ID_P_RETURN
|
|
};
|
|
|
|
static void event_handler(lv_obj_t *obj, lv_event_t event) {
|
|
if (event != LV_EVENT_RELEASED) return;
|
|
switch (obj->mks_obj_id) {
|
|
case ID_P_ADD: {
|
|
if (uiCfg.curTempType == 0) {
|
|
int16_t max_target;
|
|
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
|
|
max_target = HEATER_1_MAXTEMP - (WATCH_TEMP_INCREASE + TEMP_HYSTERESIS + 1);
|
|
#endif
|
|
if (thermalManager.degTargetHotend(uiCfg.extruderIndex) > max_target)
|
|
thermalManager.setTargetHotend(max_target, uiCfg.extruderIndex);
|
|
thermalManager.start_watching_hotend(uiCfg.extruderIndex);
|
|
}
|
|
else {
|
|
#if HAS_HEATED_BED
|
|
constexpr int16_t max_target = BED_MAXTEMP - (WATCH_BED_TEMP_INCREASE + TEMP_BED_HYSTERESIS + 1);
|
|
thermalManager.temp_bed.target += uiCfg.stepHeat;
|
|
if (thermalManager.degTargetBed() > max_target)
|
|
thermalManager.setTargetBed(max_target);
|
|
thermalManager.start_watching_bed();
|
|
#endif
|
|
}
|
|
disp_desire_temp();
|
|
} break;
|
|
|
|
case ID_P_DEC:
|
|
if (uiCfg.curTempType == 0) {
|
|
if (thermalManager.degTargetHotend(uiCfg.extruderIndex) > uiCfg.stepHeat)
|
|
thermalManager.temp_hotend[uiCfg.extruderIndex].target -= uiCfg.stepHeat;
|
|
else
|
|
thermalManager.setTargetHotend(0, uiCfg.extruderIndex);
|
|
thermalManager.start_watching_hotend(uiCfg.extruderIndex);
|
|
}
|
|
#if HAS_HEATED_BED
|
|
else {
|
|
if (thermalManager.degTargetBed() > uiCfg.stepHeat)
|
|
thermalManager.temp_bed.target -= uiCfg.stepHeat;
|
|
else
|
|
thermalManager.setTargetBed(0);
|
|
|
|
thermalManager.start_watching_bed();
|
|
}
|
|
#endif
|
|
disp_desire_temp();
|
|
break;
|
|
case ID_P_TYPE:
|
|
if (uiCfg.curTempType == 0) {
|
|
if (ENABLED(HAS_MULTI_EXTRUDER)) {
|
|
if (uiCfg.extruderIndex == 0) {
|
|
uiCfg.extruderIndex = 1;
|
|
}
|
|
else if (uiCfg.extruderIndex == 1) {
|
|
if (TEMP_SENSOR_BED != 0) {
|
|
uiCfg.curTempType = 1;
|
|
}
|
|
else {
|
|
uiCfg.curTempType = 0;
|
|
uiCfg.extruderIndex = 0;
|
|
}
|
|
}
|
|
}
|
|
else if (uiCfg.extruderIndex == 0) {
|
|
if (TEMP_SENSOR_BED != 0)
|
|
uiCfg.curTempType = 1;
|
|
else
|
|
uiCfg.curTempType = 0;
|
|
}
|
|
}
|
|
else if (uiCfg.curTempType == 1) {
|
|
uiCfg.extruderIndex = 0;
|
|
uiCfg.curTempType = 0;
|
|
}
|
|
disp_temp_type();
|
|
break;
|
|
case ID_P_STEP:
|
|
switch (uiCfg.stepHeat) {
|
|
case 1: uiCfg.stepHeat = 5; break;
|
|
case 5: uiCfg.stepHeat = 10; break;
|
|
case 10: uiCfg.stepHeat = 1; break;
|
|
default: break;
|
|
}
|
|
disp_step_heat();
|
|
break;
|
|
case ID_P_OFF:
|
|
if (uiCfg.curTempType == 0) {
|
|
thermalManager.setTargetHotend(0, uiCfg.extruderIndex);
|
|
thermalManager.start_watching_hotend(uiCfg.extruderIndex);
|
|
}
|
|
#if HAS_HEATED_BED
|
|
else {
|
|
thermalManager.temp_bed.target = 0;
|
|
thermalManager.start_watching_bed();
|
|
}
|
|
#endif
|
|
disp_desire_temp();
|
|
break;
|
|
case ID_P_RETURN:
|
|
clear_cur_ui();
|
|
draw_return_ui();
|
|
break;
|
|
}
|
|
}
|
|
|
|
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);
|
|
|
|
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 HAS_ROTARY_ENCODER
|
|
if (gCfgItems.encoder_enable) {
|
|
lv_group_add_obj(g, buttonType);
|
|
lv_group_add_obj(g, buttonStep);
|
|
}
|
|
#endif
|
|
|
|
lv_big_button_create(scr, "F:/bmp_speed0.bin", preheat_menu.off, BTN_X_PIXEL * 2 + INTERVAL_V * 3, BTN_Y_PIXEL + INTERVAL_H + titleHeight, event_handler, ID_P_OFF);
|
|
lv_big_button_create(scr, "F:/bmp_return.bin", common_menu.text_back, BTN_X_PIXEL * 3 + INTERVAL_V * 4, BTN_Y_PIXEL + INTERVAL_H + titleHeight, event_handler, ID_P_RETURN);
|
|
|
|
// Create labels on the image buttons
|
|
labelType = lv_label_create_empty(buttonType);
|
|
labelStep = lv_label_create_empty(buttonStep);
|
|
|
|
disp_temp_type();
|
|
disp_step_heat();
|
|
|
|
tempText1 = lv_label_create_empty(scr);
|
|
lv_obj_set_style(tempText1, &tft_style_label_rel);
|
|
disp_desire_temp();
|
|
}
|
|
|
|
void disp_temp_type() {
|
|
if (uiCfg.curTempType == 0) {
|
|
if (uiCfg.extruderIndex == 1) {
|
|
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");
|
|
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");
|
|
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);
|
|
}
|
|
}
|
|
}
|
|
|
|
void disp_desire_temp() {
|
|
char buf[20] = { 0 };
|
|
public_buf_l[0] = '\0';
|
|
|
|
if (uiCfg.curTempType == 0) {
|
|
strcat(public_buf_l, uiCfg.extruderIndex < 1 ? preheat_menu.ext1 : preheat_menu.ext2);
|
|
sprintf(buf, preheat_menu.value_state, thermalManager.wholeDegHotend(uiCfg.extruderIndex), thermalManager.degTargetHotend(uiCfg.extruderIndex));
|
|
}
|
|
else {
|
|
#if HAS_HEATED_BED
|
|
strcat(public_buf_l, preheat_menu.hotbed);
|
|
sprintf(buf, preheat_menu.value_state, thermalManager.wholeDegBed(), thermalManager.degTargetBed());
|
|
#endif
|
|
}
|
|
strcat_P(public_buf_l, PSTR(": "));
|
|
strcat(public_buf_l, buf);
|
|
lv_label_set_text(tempText1, public_buf_l);
|
|
lv_obj_align(tempText1, nullptr, LV_ALIGN_CENTER, 0, -50);
|
|
}
|
|
|
|
void disp_step_heat() {
|
|
if (uiCfg.stepHeat == 1) {
|
|
lv_imgbtn_set_src_both(buttonStep, "F:/bmp_step1_degree.bin");
|
|
}
|
|
else if (uiCfg.stepHeat == 5) {
|
|
lv_imgbtn_set_src_both(buttonStep, "F:/bmp_step5_degree.bin");
|
|
}
|
|
else if (uiCfg.stepHeat == 10) {
|
|
lv_imgbtn_set_src_both(buttonStep, "F:/bmp_step10_degree.bin");
|
|
}
|
|
|
|
if (gCfgItems.multiple_language) {
|
|
if (uiCfg.stepHeat == 1) {
|
|
lv_label_set_text(labelStep, preheat_menu.step_1c);
|
|
lv_obj_align(labelStep, buttonStep, LV_ALIGN_IN_BOTTOM_MID, 0, BUTTON_TEXT_Y_OFFSET);
|
|
}
|
|
else if (uiCfg.stepHeat == 5) {
|
|
lv_label_set_text(labelStep, preheat_menu.step_5c);
|
|
lv_obj_align(labelStep, buttonStep, LV_ALIGN_IN_BOTTOM_MID, 0, BUTTON_TEXT_Y_OFFSET);
|
|
}
|
|
else if (uiCfg.stepHeat == 10) {
|
|
lv_label_set_text(labelStep, preheat_menu.step_10c);
|
|
lv_obj_align(labelStep, buttonStep, LV_ALIGN_IN_BOTTOM_MID, 0, BUTTON_TEXT_Y_OFFSET);
|
|
}
|
|
}
|
|
}
|
|
|
|
void lv_clear_preHeat() {
|
|
#if HAS_ROTARY_ENCODER
|
|
if (gCfgItems.encoder_enable) lv_group_remove_all_objs(g);
|
|
#endif
|
|
lv_obj_del(scr);
|
|
}
|
|
|
|
#endif // HAS_TFT_LVGL_UI
|