|
|
@ -1098,9 +1098,11 @@ void kill_screen(const char* lcd_msg) {
|
|
|
|
#endif // HOTENDS > 1
|
|
|
|
#endif // HOTENDS > 1
|
|
|
|
#endif // HAS_TEMP_HOTEND
|
|
|
|
#endif // HAS_TEMP_HOTEND
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void watch_temp_callback_bed() {
|
|
|
|
#if WATCH_THE_BED
|
|
|
|
#if WATCH_THE_BED
|
|
|
|
void watch_temp_callback_bed() { thermalManager.start_watching_bed(); }
|
|
|
|
thermalManager.start_watching_bed();
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(ADVANCED_PAUSE_FEATURE)
|
|
|
|
#if ENABLED(ADVANCED_PAUSE_FEATURE)
|
|
|
|
|
|
|
|
|
|
|
@ -1162,7 +1164,7 @@ void kill_screen(const char* lcd_msg) {
|
|
|
|
//
|
|
|
|
//
|
|
|
|
// Bed:
|
|
|
|
// Bed:
|
|
|
|
//
|
|
|
|
//
|
|
|
|
#if WATCH_THE_BED
|
|
|
|
#if HAS_TEMP_BED
|
|
|
|
MENU_MULTIPLIER_ITEM_EDIT_CALLBACK(int3, MSG_BED, &thermalManager.target_temperature_bed, 0, BED_MAXTEMP - 15, watch_temp_callback_bed);
|
|
|
|
MENU_MULTIPLIER_ITEM_EDIT_CALLBACK(int3, MSG_BED, &thermalManager.target_temperature_bed, 0, BED_MAXTEMP - 15, watch_temp_callback_bed);
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
@ -1810,7 +1812,7 @@ void kill_screen(const char* lcd_msg) {
|
|
|
|
void _lcd_ubl_build_custom_mesh() {
|
|
|
|
void _lcd_ubl_build_custom_mesh() {
|
|
|
|
char UBL_LCD_GCODE[20];
|
|
|
|
char UBL_LCD_GCODE[20];
|
|
|
|
enqueue_and_echo_commands_P(PSTR("G28"));
|
|
|
|
enqueue_and_echo_commands_P(PSTR("G28"));
|
|
|
|
#if WATCH_THE_BED
|
|
|
|
#if HAS_TEMP_BED
|
|
|
|
sprintf_P(UBL_LCD_GCODE, PSTR("M190 S%i"), custom_bed_temp);
|
|
|
|
sprintf_P(UBL_LCD_GCODE, PSTR("M190 S%i"), custom_bed_temp);
|
|
|
|
enqueue_and_echo_command(UBL_LCD_GCODE);
|
|
|
|
enqueue_and_echo_command(UBL_LCD_GCODE);
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
@ -1826,7 +1828,7 @@ void kill_screen(const char* lcd_msg) {
|
|
|
|
START_MENU();
|
|
|
|
START_MENU();
|
|
|
|
MENU_BACK(MSG_UBL_BUILD_MESH_MENU);
|
|
|
|
MENU_BACK(MSG_UBL_BUILD_MESH_MENU);
|
|
|
|
MENU_ITEM_EDIT(int3, MSG_UBL_CUSTOM_HOTEND_TEMP, &custom_hotend_temp, EXTRUDE_MINTEMP, (HEATER_0_MAXTEMP - 10));
|
|
|
|
MENU_ITEM_EDIT(int3, MSG_UBL_CUSTOM_HOTEND_TEMP, &custom_hotend_temp, EXTRUDE_MINTEMP, (HEATER_0_MAXTEMP - 10));
|
|
|
|
#if WATCH_THE_BED
|
|
|
|
#if HAS_TEMP_BED
|
|
|
|
MENU_ITEM_EDIT(int3, MSG_UBL_CUSTOM_BED_TEMP, &custom_bed_temp, BED_MINTEMP, (BED_MAXTEMP - 5));
|
|
|
|
MENU_ITEM_EDIT(int3, MSG_UBL_CUSTOM_BED_TEMP, &custom_bed_temp, BED_MINTEMP, (BED_MAXTEMP - 5));
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
MENU_ITEM(function, MSG_UBL_BUILD_CUSTOM_MESH, _lcd_ubl_build_custom_mesh);
|
|
|
|
MENU_ITEM(function, MSG_UBL_BUILD_CUSTOM_MESH, _lcd_ubl_build_custom_mesh);
|
|
|
@ -1875,7 +1877,7 @@ void kill_screen(const char* lcd_msg) {
|
|
|
|
void _lcd_ubl_validate_custom_mesh() {
|
|
|
|
void _lcd_ubl_validate_custom_mesh() {
|
|
|
|
char UBL_LCD_GCODE[24];
|
|
|
|
char UBL_LCD_GCODE[24];
|
|
|
|
const int temp =
|
|
|
|
const int temp =
|
|
|
|
#if WATCH_THE_BED
|
|
|
|
#if HAS_TEMP_BED
|
|
|
|
custom_bed_temp
|
|
|
|
custom_bed_temp
|
|
|
|
#else
|
|
|
|
#else
|
|
|
|
0
|
|
|
|
0
|
|
|
@ -1891,7 +1893,7 @@ void kill_screen(const char* lcd_msg) {
|
|
|
|
void _lcd_ubl_validate_mesh() {
|
|
|
|
void _lcd_ubl_validate_mesh() {
|
|
|
|
START_MENU();
|
|
|
|
START_MENU();
|
|
|
|
MENU_BACK(MSG_UBL_TOOLS);
|
|
|
|
MENU_BACK(MSG_UBL_TOOLS);
|
|
|
|
#if WATCH_THE_BED
|
|
|
|
#if HAS_TEMP_BED
|
|
|
|
MENU_ITEM(gcode, MSG_UBL_VALIDATE_PLA_MESH, PSTR("G28\nG26 C B" STRINGIFY(PREHEAT_1_TEMP_BED) " H" STRINGIFY(PREHEAT_1_TEMP_HOTEND) " P"));
|
|
|
|
MENU_ITEM(gcode, MSG_UBL_VALIDATE_PLA_MESH, PSTR("G28\nG26 C B" STRINGIFY(PREHEAT_1_TEMP_BED) " H" STRINGIFY(PREHEAT_1_TEMP_HOTEND) " P"));
|
|
|
|
MENU_ITEM(gcode, MSG_UBL_VALIDATE_ABS_MESH, PSTR("G28\nG26 C B" STRINGIFY(PREHEAT_2_TEMP_BED) " H" STRINGIFY(PREHEAT_2_TEMP_HOTEND) " P"));
|
|
|
|
MENU_ITEM(gcode, MSG_UBL_VALIDATE_ABS_MESH, PSTR("G28\nG26 C B" STRINGIFY(PREHEAT_2_TEMP_BED) " H" STRINGIFY(PREHEAT_2_TEMP_HOTEND) " P"));
|
|
|
|
#else
|
|
|
|
#else
|
|
|
@ -1978,7 +1980,7 @@ void kill_screen(const char* lcd_msg) {
|
|
|
|
void _lcd_ubl_build_mesh() {
|
|
|
|
void _lcd_ubl_build_mesh() {
|
|
|
|
START_MENU();
|
|
|
|
START_MENU();
|
|
|
|
MENU_BACK(MSG_UBL_TOOLS);
|
|
|
|
MENU_BACK(MSG_UBL_TOOLS);
|
|
|
|
#if WATCH_THE_BED
|
|
|
|
#if HAS_TEMP_BED
|
|
|
|
MENU_ITEM(gcode, MSG_UBL_BUILD_PLA_MESH, PSTR(
|
|
|
|
MENU_ITEM(gcode, MSG_UBL_BUILD_PLA_MESH, PSTR(
|
|
|
|
"G28\n"
|
|
|
|
"G28\n"
|
|
|
|
"M190 S" STRINGIFY(PREHEAT_1_TEMP_BED) "\n"
|
|
|
|
"M190 S" STRINGIFY(PREHEAT_1_TEMP_BED) "\n"
|
|
|
@ -2075,7 +2077,7 @@ void kill_screen(const char* lcd_msg) {
|
|
|
|
enqueue_and_echo_command(ubl_lcd_gcode);
|
|
|
|
enqueue_and_echo_command(ubl_lcd_gcode);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef DOGLCD
|
|
|
|
#if ENABLED(DOGLCD)
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* UBL LCD "radar" map data
|
|
|
|
* UBL LCD "radar" map data
|
|
|
@ -2086,8 +2088,8 @@ void kill_screen(const char* lcd_msg) {
|
|
|
|
#define MAP_MAX_PIXELS_Y 49
|
|
|
|
#define MAP_MAX_PIXELS_Y 49
|
|
|
|
|
|
|
|
|
|
|
|
void _lcd_ubl_plot_drawing_prep() {
|
|
|
|
void _lcd_ubl_plot_drawing_prep() {
|
|
|
|
uint8_t i, j, x_offset, y_offset, x_map_pixels, y_map_pixels;
|
|
|
|
uint8_t i, j, x_offset, y_offset, x_map_pixels, y_map_pixels,
|
|
|
|
uint8_t pixels_per_X_mesh_pnt, pixels_per_Y_mesh_pnt, inverted_y;
|
|
|
|
pixels_per_X_mesh_pnt, pixels_per_Y_mesh_pnt, inverted_y;
|
|
|
|
|
|
|
|
|
|
|
|
/*********************************************************/
|
|
|
|
/*********************************************************/
|
|
|
|
/************ Scale the box pixels appropriately *********/
|
|
|
|
/************ Scale the box pixels appropriately *********/
|
|
|
@ -2147,11 +2149,11 @@ void kill_screen(const char* lcd_msg) {
|
|
|
|
|
|
|
|
|
|
|
|
// Print plot position
|
|
|
|
// Print plot position
|
|
|
|
u8g.setPrintPos(5, 64);
|
|
|
|
u8g.setPrintPos(5, 64);
|
|
|
|
lcd_print("(");
|
|
|
|
lcd_print('(');
|
|
|
|
u8g.print(x_plot);
|
|
|
|
u8g.print(x_plot);
|
|
|
|
lcd_print(",");
|
|
|
|
lcd_print(',');
|
|
|
|
u8g.print(y_plot);
|
|
|
|
u8g.print(y_plot);
|
|
|
|
lcd_print(")");
|
|
|
|
lcd_print(')');
|
|
|
|
|
|
|
|
|
|
|
|
// Show the location value
|
|
|
|
// Show the location value
|
|
|
|
u8g.setPrintPos(74, 64);
|
|
|
|
u8g.setPrintPos(74, 64);
|
|
|
@ -2968,7 +2970,7 @@ void kill_screen(const char* lcd_msg) {
|
|
|
|
//
|
|
|
|
//
|
|
|
|
// Bed:
|
|
|
|
// Bed:
|
|
|
|
//
|
|
|
|
//
|
|
|
|
#if WATCH_THE_BED
|
|
|
|
#if HAS_TEMP_BED
|
|
|
|
MENU_MULTIPLIER_ITEM_EDIT_CALLBACK(int3, MSG_BED, &thermalManager.target_temperature_bed, 0, BED_MAXTEMP - 15, watch_temp_callback_bed);
|
|
|
|
MENU_MULTIPLIER_ITEM_EDIT_CALLBACK(int3, MSG_BED, &thermalManager.target_temperature_bed, 0, BED_MAXTEMP - 15, watch_temp_callback_bed);
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|