Add custom preheat temp to filament change (#11475)
This commit is contained in:
parent
69d0ed5791
commit
2ebfe90be9
@ -154,6 +154,9 @@
|
|||||||
#ifndef MSG_PREHEAT_2_SETTINGS
|
#ifndef MSG_PREHEAT_2_SETTINGS
|
||||||
#define MSG_PREHEAT_2_SETTINGS MSG_PREHEAT_2 _UxGT(" conf")
|
#define MSG_PREHEAT_2_SETTINGS MSG_PREHEAT_2 _UxGT(" conf")
|
||||||
#endif
|
#endif
|
||||||
|
#ifndef MSG_PREHEAT_CUSTOM
|
||||||
|
#define MSG_PREHEAT_CUSTOM _UxGT("Preheat Custom")
|
||||||
|
#endif
|
||||||
#ifndef MSG_COOLDOWN
|
#ifndef MSG_COOLDOWN
|
||||||
#define MSG_COOLDOWN _UxGT("Cooldown")
|
#define MSG_COOLDOWN _UxGT("Cooldown")
|
||||||
#endif
|
#endif
|
||||||
|
@ -4330,14 +4330,15 @@ void lcd_quick_feedback(const bool clear_buttons) {
|
|||||||
return PSTR(MSG_FILAMENTCHANGE);
|
return PSTR(MSG_FILAMENTCHANGE);
|
||||||
}
|
}
|
||||||
|
|
||||||
void _change_filament_temp(const uint8_t index) {
|
void _change_filament_temp(const uint16_t temperature) {
|
||||||
char cmd[11];
|
char cmd[11];
|
||||||
sprintf_P(cmd, _change_filament_temp_command(), _change_filament_temp_extruder);
|
sprintf_P(cmd, _change_filament_temp_command(), _change_filament_temp_extruder);
|
||||||
thermalManager.setTargetHotend(index == 1 ? PREHEAT_1_TEMP_HOTEND : PREHEAT_2_TEMP_HOTEND, _change_filament_temp_extruder);
|
thermalManager.setTargetHotend(temperature, _change_filament_temp_extruder);
|
||||||
lcd_enqueue_command(cmd);
|
lcd_enqueue_command(cmd);
|
||||||
}
|
}
|
||||||
void _lcd_change_filament_temp_1_menu() { _change_filament_temp(1); }
|
void _lcd_change_filament_temp_1_menu() { _change_filament_temp(PREHEAT_1_TEMP_HOTEND); }
|
||||||
void _lcd_change_filament_temp_2_menu() { _change_filament_temp(2); }
|
void _lcd_change_filament_temp_2_menu() { _change_filament_temp(PREHEAT_2_TEMP_HOTEND); }
|
||||||
|
void _lcd_change_filament_temp_custom_menu() { _change_filament_temp(thermalManager.target_temperature[_change_filament_temp_extruder]); }
|
||||||
|
|
||||||
static const char* change_filament_header(const AdvancedPauseMode mode) {
|
static const char* change_filament_header(const AdvancedPauseMode mode) {
|
||||||
switch (mode) {
|
switch (mode) {
|
||||||
@ -4358,6 +4359,23 @@ void lcd_quick_feedback(const bool clear_buttons) {
|
|||||||
MENU_BACK(MSG_FILAMENTCHANGE);
|
MENU_BACK(MSG_FILAMENTCHANGE);
|
||||||
MENU_ITEM(submenu, MSG_PREHEAT_1, _lcd_change_filament_temp_1_menu);
|
MENU_ITEM(submenu, MSG_PREHEAT_1, _lcd_change_filament_temp_1_menu);
|
||||||
MENU_ITEM(submenu, MSG_PREHEAT_2, _lcd_change_filament_temp_2_menu);
|
MENU_ITEM(submenu, MSG_PREHEAT_2, _lcd_change_filament_temp_2_menu);
|
||||||
|
uint16_t max_temp;
|
||||||
|
switch (extruder) {
|
||||||
|
default: max_temp = HEATER_0_MAXTEMP;
|
||||||
|
#if HOTENDS > 1
|
||||||
|
case 1: max_temp = HEATER_1_MAXTEMP; break;
|
||||||
|
#if HOTENDS > 2
|
||||||
|
case 2: max_temp = HEATER_2_MAXTEMP; break;
|
||||||
|
#if HOTENDS > 3
|
||||||
|
case 3: max_temp = HEATER_3_MAXTEMP; break;
|
||||||
|
#if HOTENDS > 4
|
||||||
|
case 4: max_temp = HEATER_4_MAXTEMP; break;
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
MENU_MULTIPLIER_ITEM_EDIT_CALLBACK(int3, MSG_PREHEAT_CUSTOM, &thermalManager.target_temperature[_change_filament_temp_extruder], EXTRUDE_MINTEMP, max_temp - 15, _lcd_change_filament_temp_custom_menu);
|
||||||
END_MENU();
|
END_MENU();
|
||||||
}
|
}
|
||||||
void lcd_temp_menu_e0_filament_change() { _lcd_temp_menu_filament_op(ADVANCED_PAUSE_MODE_PAUSE_PRINT, 0); }
|
void lcd_temp_menu_e0_filament_change() { _lcd_temp_menu_filament_op(ADVANCED_PAUSE_MODE_PAUSE_PRINT, 0); }
|
||||||
|
Loading…
x
Reference in New Issue
Block a user