Add HOTEND_OVERSHOOT
This commit is contained in:
		| @@ -582,7 +582,7 @@ void GcodeSuite::G26() { | |||||||
|  |  | ||||||
|   if (parser.seenval('H')) { |   if (parser.seenval('H')) { | ||||||
|     g26_hotend_temp = parser.value_celsius(); |     g26_hotend_temp = parser.value_celsius(); | ||||||
|     if (!WITHIN(g26_hotend_temp, 165, (HEATER_0_MAXTEMP - 15))) { |     if (!WITHIN(g26_hotend_temp, 165, (HEATER_0_MAXTEMP - HOTEND_OVERSHOOT))) { | ||||||
|       SERIAL_ECHOLNPGM("?Specified nozzle temperature not plausible."); |       SERIAL_ECHOLNPGM("?Specified nozzle temperature not plausible."); | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -43,7 +43,7 @@ void GcodeSuite::M145() { | |||||||
|     int v; |     int v; | ||||||
|     if (parser.seenval('H')) { |     if (parser.seenval('H')) { | ||||||
|       v = parser.value_int(); |       v = parser.value_int(); | ||||||
|       ui.preheat_hotend_temp[material] = constrain(v, EXTRUDE_MINTEMP, HEATER_0_MAXTEMP - 15); |       ui.preheat_hotend_temp[material] = constrain(v, EXTRUDE_MINTEMP, HEATER_0_MAXTEMP - HOTEND_OVERSHOOT); | ||||||
|     } |     } | ||||||
|     if (parser.seenval('F')) { |     if (parser.seenval('F')) { | ||||||
|       v = parser.value_int(); |       v = parser.value_int(); | ||||||
|   | |||||||
| @@ -472,7 +472,10 @@ | |||||||
|  |  | ||||||
| #if HOTENDS | #if HOTENDS | ||||||
|   #define HAS_HOTEND 1 |   #define HAS_HOTEND 1 | ||||||
|   #if HOTENDS > 1 |   #ifndef HOTEND_OVERSHOOT | ||||||
|  |     #define HOTEND_OVERSHOOT 15 | ||||||
|  |   #endif | ||||||
|  |   #if HOTENDS_ > 1 | ||||||
|     #define HAS_MULTI_HOTEND 1 |     #define HAS_MULTI_HOTEND 1 | ||||||
|     #define HAS_HOTEND_OFFSET 1 |     #define HAS_HOTEND_OFFSET 1 | ||||||
|   #endif |   #endif | ||||||
|   | |||||||
| @@ -946,7 +946,7 @@ namespace ExtUI { | |||||||
|       { |       { | ||||||
|         #if HAS_HOTEND |         #if HAS_HOTEND | ||||||
|           const int16_t e = heater - H0; |           const int16_t e = heater - H0; | ||||||
|           thermalManager.setTargetHotend(LROUND(constrain(value, 0, heater_maxtemp[e] - 15)), e); |           thermalManager.setTargetHotend(LROUND(constrain(value, 0, heater_maxtemp[e] - HOTEND_OVERSHOOT)), e); | ||||||
|         #endif |         #endif | ||||||
|       } |       } | ||||||
|   } |   } | ||||||
| @@ -958,7 +958,7 @@ namespace ExtUI { | |||||||
|     #if HAS_HOTEND |     #if HAS_HOTEND | ||||||
|       const int16_t e = extruder - E0; |       const int16_t e = extruder - E0; | ||||||
|       enableHeater(extruder); |       enableHeater(extruder); | ||||||
|       thermalManager.setTargetHotend(LROUND(constrain(value, 0, heater_maxtemp[e] - 15)), e); |       thermalManager.setTargetHotend(LROUND(constrain(value, 0, heater_maxtemp[e] - HOTEND_OVERSHOOT)), e); | ||||||
|     #endif |     #endif | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -257,8 +257,8 @@ void menu_cancelobject(); | |||||||
|     // |     // | ||||||
|     #if BOTH(AUTOTEMP, HAS_TEMP_HOTEND) |     #if BOTH(AUTOTEMP, HAS_TEMP_HOTEND) | ||||||
|       EDIT_ITEM(bool, MSG_AUTOTEMP, &planner.autotemp_enabled); |       EDIT_ITEM(bool, MSG_AUTOTEMP, &planner.autotemp_enabled); | ||||||
|       EDIT_ITEM(float3, MSG_MIN, &planner.autotemp_min, 0, float(HEATER_0_MAXTEMP) - 15); |       EDIT_ITEM(float3, MSG_MIN, &planner.autotemp_min, 0, float(HEATER_0_MAXTEMP) - HOTEND_OVERSHOOT); | ||||||
|       EDIT_ITEM(float3, MSG_MAX, &planner.autotemp_max, 0, float(HEATER_0_MAXTEMP) - 15); |       EDIT_ITEM(float3, MSG_MAX, &planner.autotemp_max, 0, float(HEATER_0_MAXTEMP) - HOTEND_OVERSHOOT); | ||||||
|       EDIT_ITEM(float42_52, MSG_FACTOR, &planner.autotemp_factor, 0, 10); |       EDIT_ITEM(float42_52, MSG_FACTOR, &planner.autotemp_factor, 0, 10); | ||||||
|     #endif |     #endif | ||||||
|  |  | ||||||
| @@ -304,7 +304,7 @@ void menu_cancelobject(); | |||||||
|     #if ENABLED(PID_AUTOTUNE_MENU) |     #if ENABLED(PID_AUTOTUNE_MENU) | ||||||
|       #define PID_EDIT_MENU_ITEMS(N) \ |       #define PID_EDIT_MENU_ITEMS(N) \ | ||||||
|         _PID_EDIT_MENU_ITEMS(N); \ |         _PID_EDIT_MENU_ITEMS(N); \ | ||||||
|         EDIT_ITEM_FAST_N(int3, N, MSG_PID_AUTOTUNE_E, &autotune_temp[N], 150, heater_maxtemp[N] - 15, []{ _lcd_autotune(MenuItemBase::itemIndex); }); |         EDIT_ITEM_FAST_N(int3, N, MSG_PID_AUTOTUNE_E, &autotune_temp[N], 150, heater_maxtemp[N] - HOTEND_OVERSHOOT, []{ _lcd_autotune(MenuItemBase::itemIndex); }); | ||||||
|     #else |     #else | ||||||
|       #define PID_EDIT_MENU_ITEMS(N) _PID_EDIT_MENU_ITEMS(N); |       #define PID_EDIT_MENU_ITEMS(N) _PID_EDIT_MENU_ITEMS(N); | ||||||
|     #endif |     #endif | ||||||
|   | |||||||
| @@ -331,7 +331,7 @@ void menu_advanced_settings(); | |||||||
|     BACK_ITEM(MSG_CONFIGURATION); |     BACK_ITEM(MSG_CONFIGURATION); | ||||||
|     EDIT_ITEM(percent, MSG_FAN_SPEED, &ui.preheat_fan_speed[material], 0, 255); |     EDIT_ITEM(percent, MSG_FAN_SPEED, &ui.preheat_fan_speed[material], 0, 255); | ||||||
|     #if HAS_TEMP_HOTEND |     #if HAS_TEMP_HOTEND | ||||||
|       EDIT_ITEM(int3, MSG_NOZZLE, &ui.preheat_hotend_temp[material], MINTEMP_ALL, MAXTEMP_ALL - 15); |       EDIT_ITEM(int3, MSG_NOZZLE, &ui.preheat_hotend_temp[material], MINTEMP_ALL, MAXTEMP_ALL - HOTEND_OVERSHOOT); | ||||||
|     #endif |     #endif | ||||||
|     #if HAS_HEATED_BED |     #if HAS_HEATED_BED | ||||||
|       EDIT_ITEM(int3, MSG_BED, &ui.preheat_bed_temp[material], BED_MINTEMP, BED_MAX_TARGET); |       EDIT_ITEM(int3, MSG_BED, &ui.preheat_bed_temp[material], BED_MINTEMP, BED_MAX_TARGET); | ||||||
|   | |||||||
| @@ -83,7 +83,7 @@ void _menu_temp_filament_op(const PauseMode mode, const int8_t extruder) { | |||||||
|   BACK_ITEM(MSG_BACK); |   BACK_ITEM(MSG_BACK); | ||||||
|   ACTION_ITEM(MSG_PREHEAT_1, []{ _change_filament(ui.preheat_hotend_temp[0]); }); |   ACTION_ITEM(MSG_PREHEAT_1, []{ _change_filament(ui.preheat_hotend_temp[0]); }); | ||||||
|   ACTION_ITEM(MSG_PREHEAT_2, []{ _change_filament(ui.preheat_hotend_temp[1]); }); |   ACTION_ITEM(MSG_PREHEAT_2, []{ _change_filament(ui.preheat_hotend_temp[1]); }); | ||||||
|   EDIT_ITEM_FAST(int3, MSG_PREHEAT_CUSTOM, &thermalManager.temp_hotend[_change_filament_extruder].target, EXTRUDE_MINTEMP, heater_maxtemp[extruder] - 15, []{ |   EDIT_ITEM_FAST(int3, MSG_PREHEAT_CUSTOM, &thermalManager.temp_hotend[_change_filament_extruder].target, EXTRUDE_MINTEMP, heater_maxtemp[extruder] - HOTEND_OVERSHOOT, []{ | ||||||
|     _change_filament(thermalManager.temp_hotend[_change_filament_extruder].target); |     _change_filament(thermalManager.temp_hotend[_change_filament_extruder].target); | ||||||
|   }); |   }); | ||||||
|   END_MENU(); |   END_MENU(); | ||||||
|   | |||||||
| @@ -50,7 +50,7 @@ uint8_t MarlinUI::preheat_fan_speed[2]; | |||||||
| void Temperature::lcd_preheat(const int16_t e, const int8_t indh, const int8_t indb) { | void Temperature::lcd_preheat(const int16_t e, const int8_t indh, const int8_t indb) { | ||||||
|   #if HAS_HOTEND |   #if HAS_HOTEND | ||||||
|     if (indh >= 0 && ui.preheat_hotend_temp[indh] > 0) |     if (indh >= 0 && ui.preheat_hotend_temp[indh] > 0) | ||||||
|       setTargetHotend(_MIN(heater_maxtemp[e] - 15, ui.preheat_hotend_temp[indh]), e); |       setTargetHotend(_MIN(heater_maxtemp[e] - HOTEND_OVERSHOOT, ui.preheat_hotend_temp[indh]), e); | ||||||
|   #else |   #else | ||||||
|     UNUSED(e); |     UNUSED(e); | ||||||
|     UNUSED(temph); |     UNUSED(temph); | ||||||
| @@ -163,14 +163,14 @@ void menu_temperature() { | |||||||
|   // Nozzle [1-5]: |   // Nozzle [1-5]: | ||||||
|   // |   // | ||||||
|   #if HOTENDS == 1 |   #if HOTENDS == 1 | ||||||
|     EDIT_ITEM_FAST(int3, MSG_NOZZLE, &thermalManager.temp_hotend[0].target, 0, HEATER_0_MAXTEMP - 15, []{ thermalManager.start_watching_hotend(0); }); |     EDIT_ITEM_FAST(int3, MSG_NOZZLE, &thermalManager.temp_hotend[0].target, 0, HEATER_0_MAXTEMP - HOTEND_OVERSHOOT, []{ thermalManager.start_watching_hotend(0); }); | ||||||
|   #elif HAS_MULTI_HOTEND |   #elif HAS_MULTI_HOTEND | ||||||
|     HOTEND_LOOP() |     HOTEND_LOOP() | ||||||
|       EDIT_ITEM_FAST_N(int3, e, MSG_NOZZLE_N, &thermalManager.temp_hotend[e].target, 0, heater_maxtemp[e] - 15, []{ thermalManager.start_watching_hotend(MenuItemBase::itemIndex); }); |       EDIT_ITEM_FAST_N(int3, e, MSG_NOZZLE_N, &thermalManager.temp_hotend[e].target, 0, heater_maxtemp[e] - HOTEND_OVERSHOOT, []{ thermalManager.start_watching_hotend(MenuItemBase::itemIndex); }); | ||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
|   #if ENABLED(SINGLENOZZLE) |   #if ENABLED(SINGLENOZZLE) | ||||||
|     EDIT_ITEM_FAST(uint16_3, MSG_NOZZLE_STANDBY, &singlenozzle_temp[active_extruder ? 0 : 1], 0, HEATER_0_MAXTEMP - 15); |     EDIT_ITEM_FAST(uint16_3, MSG_NOZZLE_STANDBY, &singlenozzle_temp[active_extruder ? 0 : 1], 0, HEATER_0_MAXTEMP - HOTEND_OVERSHOOT); | ||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
|   // |   // | ||||||
|   | |||||||
| @@ -118,14 +118,14 @@ void menu_tune() { | |||||||
|   // Nozzle [1-4]: |   // Nozzle [1-4]: | ||||||
|   // |   // | ||||||
|   #if HOTENDS == 1 |   #if HOTENDS == 1 | ||||||
|     EDIT_ITEM_FAST(int3, MSG_NOZZLE, &thermalManager.temp_hotend[0].target, 0, HEATER_0_MAXTEMP - 15, []{ thermalManager.start_watching_hotend(0); }); |     EDIT_ITEM_FAST(int3, MSG_NOZZLE, &thermalManager.temp_hotend[0].target, 0, HEATER_0_MAXTEMP - HOTEND_OVERSHOOT, []{ thermalManager.start_watching_hotend(0); }); | ||||||
|   #elif HAS_MULTI_HOTEND |   #elif HAS_MULTI_HOTEND | ||||||
|     HOTEND_LOOP() |     HOTEND_LOOP() | ||||||
|       EDIT_ITEM_FAST_N(int3, e, MSG_NOZZLE_N, &thermalManager.temp_hotend[e].target, 0, heater_maxtemp[e] - 15, []{ thermalManager.start_watching_hotend(MenuItemBase::itemIndex); }); |       EDIT_ITEM_FAST_N(int3, e, MSG_NOZZLE_N, &thermalManager.temp_hotend[e].target, 0, heater_maxtemp[e] - HOTEND_OVERSHOOT, []{ thermalManager.start_watching_hotend(MenuItemBase::itemIndex); }); | ||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
|   #if ENABLED(SINGLENOZZLE) |   #if ENABLED(SINGLENOZZLE) | ||||||
|     EDIT_ITEM_FAST(uint16_3, MSG_NOZZLE_STANDBY, &singlenozzle_temp[active_extruder ? 0 : 1], 0, HEATER_0_MAXTEMP - 15); |     EDIT_ITEM_FAST(uint16_3, MSG_NOZZLE_STANDBY, &singlenozzle_temp[active_extruder ? 0 : 1], 0, HEATER_0_MAXTEMP - HOTEND_OVERSHOOT); | ||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
|   // |   // | ||||||
|   | |||||||
| @@ -128,7 +128,7 @@ void _lcd_ubl_build_custom_mesh() { | |||||||
| void _lcd_ubl_custom_mesh() { | void _lcd_ubl_custom_mesh() { | ||||||
|   START_MENU(); |   START_MENU(); | ||||||
|   BACK_ITEM(MSG_UBL_BUILD_MESH_MENU); |   BACK_ITEM(MSG_UBL_BUILD_MESH_MENU); | ||||||
|   EDIT_ITEM(int3, MSG_UBL_HOTEND_TEMP_CUSTOM, &custom_hotend_temp, EXTRUDE_MINTEMP, (HEATER_0_MAXTEMP - 15)); |   EDIT_ITEM(int3, MSG_UBL_HOTEND_TEMP_CUSTOM, &custom_hotend_temp, EXTRUDE_MINTEMP, HEATER_0_MAXTEMP - HOTEND_OVERSHOOT); | ||||||
|   #if HAS_HEATED_BED |   #if HAS_HEATED_BED | ||||||
|     EDIT_ITEM(int3, MSG_UBL_BED_TEMP_CUSTOM, &custom_bed_temp, BED_MINTEMP, BED_MAX_TARGET); |     EDIT_ITEM(int3, MSG_UBL_BED_TEMP_CUSTOM, &custom_bed_temp, BED_MINTEMP, BED_MAX_TARGET); | ||||||
|   #endif |   #endif | ||||||
|   | |||||||
| @@ -400,7 +400,7 @@ volatile bool Temperature::raw_temps_ready = false; | |||||||
|  |  | ||||||
|     TERN_(HAS_AUTO_FAN, next_auto_fan_check_ms = next_temp_ms + 2500UL); |     TERN_(HAS_AUTO_FAN, next_auto_fan_check_ms = next_temp_ms + 2500UL); | ||||||
|  |  | ||||||
|     if (target > GHV(BED_MAX_TARGET, temp_range[heater].maxtemp - 15)) { |     if (target > GHV(BED_MAX_TARGET, temp_range[heater].maxtemp - HOTEND_OVERSHOOT)) { | ||||||
|       SERIAL_ECHOLNPGM(STR_PID_TEMP_TOO_HIGH); |       SERIAL_ECHOLNPGM(STR_PID_TEMP_TOO_HIGH); | ||||||
|       TERN_(EXTENSIBLE_UI, ExtUI::onPidTuning(ExtUI::result_t::PID_TEMP_TOO_HIGH)); |       TERN_(EXTENSIBLE_UI, ExtUI::onPidTuning(ExtUI::result_t::PID_TEMP_TOO_HIGH)); | ||||||
|       return; |       return; | ||||||
|   | |||||||
| @@ -588,7 +588,7 @@ class Temperature { | |||||||
|             start_preheat_time(ee); |             start_preheat_time(ee); | ||||||
|         #endif |         #endif | ||||||
|         TERN_(AUTO_POWER_CONTROL, powerManager.power_on()); |         TERN_(AUTO_POWER_CONTROL, powerManager.power_on()); | ||||||
|         temp_hotend[ee].target = _MIN(celsius, temp_range[ee].maxtemp - 15); |         temp_hotend[ee].target = _MIN(celsius, temp_range[ee].maxtemp - HOTEND_OVERSHOOT); | ||||||
|         start_watching_hotend(ee); |         start_watching_hotend(ee); | ||||||
|       } |       } | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user