My Marlin configs for Fabrikator Mini and CTC i3 Pro B
Du kannst nicht mehr als 25 Themen auswählen Themen müssen mit entweder einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.

menu_configuration.cpp 13KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407
  1. /**
  2. * Marlin 3D Printer Firmware
  3. * Copyright (c) 2020 MarlinFirmware [https://github.com/MarlinFirmware/Marlin]
  4. *
  5. * Based on Sprinter and grbl.
  6. * Copyright (c) 2011 Camiel Gubbels / Erik van der Zalm
  7. *
  8. * This program is free software: you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License as published by
  10. * the Free Software Foundation, either version 3 of the License, or
  11. * (at your option) any later version.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  20. *
  21. */
  22. //
  23. // Configuration Menu
  24. //
  25. #include "../../inc/MarlinConfigPre.h"
  26. #if HAS_LCD_MENU
  27. #include "menu.h"
  28. #include "../../module/configuration_store.h"
  29. #if HAS_FILAMENT_SENSOR
  30. #include "../../feature/runout.h"
  31. #endif
  32. #if ENABLED(POWER_LOSS_RECOVERY)
  33. #include "../../feature/power_loss_recovery.h"
  34. #endif
  35. #if HAS_BED_PROBE
  36. #include "../../module/probe.h"
  37. #if ENABLED(BLTOUCH)
  38. #include "../../feature/bltouch.h"
  39. #endif
  40. #endif
  41. #define HAS_DEBUG_MENU ENABLED(LCD_PROGRESS_BAR_TEST)
  42. void menu_advanced_settings();
  43. #if EITHER(DELTA_CALIBRATION_MENU, DELTA_AUTO_CALIBRATION)
  44. void menu_delta_calibrate();
  45. #endif
  46. #if ENABLED(LCD_PROGRESS_BAR_TEST)
  47. #include "../lcdprint.h"
  48. static void progress_bar_test() {
  49. static int8_t bar_percent = 0;
  50. if (ui.use_click()) {
  51. ui.goto_previous_screen();
  52. ui.set_custom_characters(CHARSET_MENU);
  53. return;
  54. }
  55. bar_percent += (int8_t)ui.encoderPosition;
  56. LIMIT(bar_percent, 0, 100);
  57. ui.encoderPosition = 0;
  58. MenuItem_static::draw(0, GET_TEXT(MSG_PROGRESS_BAR_TEST), SS_CENTER|SS_INVERT);
  59. lcd_put_int((LCD_WIDTH) / 2 - 2, LCD_HEIGHT - 2, bar_percent); lcd_put_wchar('%');
  60. lcd_moveto(0, LCD_HEIGHT - 1); ui.draw_progress_bar(bar_percent);
  61. }
  62. void _progress_bar_test() {
  63. ui.goto_screen(progress_bar_test);
  64. ui.set_custom_characters(CHARSET_INFO);
  65. }
  66. #endif // LCD_PROGRESS_BAR_TEST
  67. #if HAS_DEBUG_MENU
  68. void menu_debug() {
  69. START_MENU();
  70. BACK_ITEM(MSG_CONFIGURATION);
  71. #if ENABLED(LCD_PROGRESS_BAR_TEST)
  72. SUBMENU(MSG_PROGRESS_BAR_TEST, _progress_bar_test);
  73. #endif
  74. END_MENU();
  75. }
  76. #endif
  77. #if EXTRUDERS > 1
  78. #include "../../module/tool_change.h"
  79. void menu_tool_change() {
  80. START_MENU();
  81. BACK_ITEM(MSG_CONFIGURATION);
  82. #if ENABLED(TOOLCHANGE_FILAMENT_SWAP)
  83. static constexpr float max_extrude =
  84. #if ENABLED(PREVENT_LENGTHY_EXTRUDE)
  85. EXTRUDE_MAXLENGTH
  86. #else
  87. 500
  88. #endif
  89. ;
  90. EDIT_ITEM(float3, MSG_FILAMENT_SWAP_LENGTH, &toolchange_settings.swap_length, 0, max_extrude);
  91. EDIT_ITEM(float3, MSG_FILAMENT_PURGE_LENGTH, &toolchange_settings.extra_prime, 0, max_extrude);
  92. EDIT_ITEM_FAST(int4, MSG_SINGLENOZZLE_RETRACT_SPD, &toolchange_settings.retract_speed, 10, 5400);
  93. EDIT_ITEM_FAST(int4, MSG_SINGLENOZZLE_PRIME_SPD, &toolchange_settings.prime_speed, 10, 5400);
  94. #endif
  95. EDIT_ITEM(float3, MSG_TOOL_CHANGE_ZLIFT, &toolchange_settings.z_raise, 0, 10);
  96. END_MENU();
  97. }
  98. #endif
  99. #if HAS_HOTEND_OFFSET
  100. #include "../../module/motion.h"
  101. #include "../../gcode/queue.h"
  102. void menu_tool_offsets() {
  103. auto _recalc_offsets = []{
  104. if (active_extruder && all_axes_known()) { // For the 2nd extruder re-home so the next tool-change gets the new offsets.
  105. queue.inject_P(G28_STR); // In future, we can babystep the 2nd extruder (if active), making homing unnecessary.
  106. active_extruder = 0;
  107. }
  108. };
  109. START_MENU();
  110. BACK_ITEM(MSG_CONFIGURATION);
  111. #if ENABLED(DUAL_X_CARRIAGE)
  112. EDIT_ITEM_FAST(float51, MSG_HOTEND_OFFSET_X, &hotend_offset[1].x, float(X2_HOME_POS - 25), float(X2_HOME_POS + 25), _recalc_offsets);
  113. #else
  114. EDIT_ITEM_FAST(float41sign, MSG_HOTEND_OFFSET_X, &hotend_offset[1].x, -99.0, 99.0, _recalc_offsets);
  115. #endif
  116. EDIT_ITEM_FAST(float41sign, MSG_HOTEND_OFFSET_Y, &hotend_offset[1].y, -99.0, 99.0, _recalc_offsets);
  117. EDIT_ITEM_FAST(float41sign, MSG_HOTEND_OFFSET_Z, &hotend_offset[1].z, Z_PROBE_LOW_POINT, 10.0, _recalc_offsets);
  118. #if ENABLED(EEPROM_SETTINGS)
  119. ACTION_ITEM(MSG_STORE_EEPROM, lcd_store_settings);
  120. #endif
  121. END_MENU();
  122. }
  123. #endif
  124. #if ENABLED(DUAL_X_CARRIAGE)
  125. void menu_idex() {
  126. START_MENU();
  127. BACK_ITEM(MSG_CONFIGURATION);
  128. GCODES_ITEM(MSG_IDEX_MODE_AUTOPARK, PSTR("M605 S1\nG28 X\nG1 X100"));
  129. const bool need_g28 = !(TEST(axis_known_position, Y_AXIS) && TEST(axis_known_position, Z_AXIS));
  130. GCODES_ITEM(MSG_IDEX_MODE_DUPLICATE, need_g28
  131. ? PSTR("M605 S1\nT0\nG28\nM605 S2 X200\nG28 X\nG1 X100") // If Y or Z is not homed, do a full G28 first
  132. : PSTR("M605 S1\nT0\nM605 S2 X200\nG28 X\nG1 X100")
  133. );
  134. GCODES_ITEM(MSG_IDEX_MODE_MIRRORED_COPY, need_g28
  135. ? PSTR("M605 S1\nT0\nG28\nM605 S2 X200\nG28 X\nG1 X100\nM605 S3 X200") // If Y or Z is not homed, do a full G28 first
  136. : PSTR("M605 S1\nT0\nM605 S2 X200\nG28 X\nG1 X100\nM605 S3 X200")
  137. );
  138. GCODES_ITEM(MSG_IDEX_MODE_FULL_CTRL, PSTR("M605 S0\nG28 X"));
  139. END_MENU();
  140. }
  141. #endif
  142. #if ENABLED(BLTOUCH)
  143. #if ENABLED(BLTOUCH_LCD_VOLTAGE_MENU)
  144. void bltouch_report() {
  145. SERIAL_ECHOLNPAIR("EEPROM Last BLTouch Mode - ", (int)bltouch.last_written_mode);
  146. SERIAL_ECHOLNPGM("Configuration BLTouch Mode - "
  147. #if ENABLED(BLTOUCH_SET_5V_MODE)
  148. "5V"
  149. #else
  150. "OD"
  151. #endif
  152. );
  153. char mess[21];
  154. strcpy_P(mess, PSTR("BLTouch Mode - "));
  155. strcpy_P(&mess[15], bltouch.last_written_mode ? PSTR("5V") : PSTR("OD"));
  156. ui.set_status(mess);
  157. ui.return_to_status();
  158. }
  159. #endif
  160. void menu_bltouch() {
  161. START_MENU();
  162. BACK_ITEM(MSG_CONFIGURATION);
  163. ACTION_ITEM(MSG_BLTOUCH_RESET, bltouch._reset);
  164. ACTION_ITEM(MSG_BLTOUCH_SELFTEST, bltouch._selftest);
  165. ACTION_ITEM(MSG_BLTOUCH_DEPLOY, bltouch._deploy);
  166. ACTION_ITEM(MSG_BLTOUCH_STOW, bltouch._stow);
  167. ACTION_ITEM(MSG_BLTOUCH_SW_MODE, bltouch._set_SW_mode);
  168. #if ENABLED(BLTOUCH_LCD_VOLTAGE_MENU)
  169. CONFIRM_ITEM(MSG_BLTOUCH_5V_MODE, MSG_BLTOUCH_5V_MODE, MSG_BUTTON_CANCEL, bltouch._set_5V_mode, ui.goto_previous_screen, GET_TEXT(MSG_BLTOUCH_MODE_CHANGE));
  170. CONFIRM_ITEM(MSG_BLTOUCH_OD_MODE, MSG_BLTOUCH_OD_MODE, MSG_BUTTON_CANCEL, bltouch._set_OD_mode, ui.goto_previous_screen, GET_TEXT(MSG_BLTOUCH_MODE_CHANGE));
  171. ACTION_ITEM(MSG_BLTOUCH_MODE_STORE, bltouch._mode_store);
  172. CONFIRM_ITEM(MSG_BLTOUCH_MODE_STORE_5V, MSG_BLTOUCH_MODE_STORE_5V, MSG_BUTTON_CANCEL, bltouch.mode_conv_5V, ui.goto_previous_screen, GET_TEXT(MSG_BLTOUCH_MODE_CHANGE));
  173. CONFIRM_ITEM(MSG_BLTOUCH_MODE_STORE_OD, MSG_BLTOUCH_MODE_STORE_OD, MSG_BUTTON_CANCEL, bltouch.mode_conv_OD, ui.goto_previous_screen, GET_TEXT(MSG_BLTOUCH_MODE_CHANGE));
  174. ACTION_ITEM(MSG_BLTOUCH_MODE_ECHO, bltouch_report);
  175. #endif
  176. END_MENU();
  177. }
  178. #endif
  179. #if ENABLED(TOUCH_MI_PROBE)
  180. void menu_touchmi() {
  181. START_MENU();
  182. ui.defer_status_screen();
  183. BACK_ITEM(MSG_CONFIGURATION);
  184. GCODES_ITEM(MSG_TOUCHMI_INIT, PSTR("M851 Z0\nG28\nG1 F200 Z0"));
  185. SUBMENU(MSG_ZPROBE_ZOFFSET, lcd_babystep_zoffset);
  186. GCODES_ITEM(MSG_TOUCHMI_SAVE, PSTR("M500\nG1 F200 Z10"));
  187. GCODES_ITEM(MSG_TOUCHMI_ZTEST, PSTR("G28\nG1 F200 Z0"));
  188. END_MENU();
  189. }
  190. #endif
  191. #if ENABLED(CASE_LIGHT_MENU)
  192. #include "../../feature/caselight.h"
  193. #if DISABLED(CASE_LIGHT_NO_BRIGHTNESS)
  194. void menu_case_light() {
  195. START_MENU();
  196. BACK_ITEM(MSG_CONFIGURATION);
  197. EDIT_ITEM(percent, MSG_CASE_LIGHT_BRIGHTNESS, &case_light_brightness, 0, 255, update_case_light, true);
  198. EDIT_ITEM(bool, MSG_CASE_LIGHT, (bool*)&case_light_on, update_case_light);
  199. END_MENU();
  200. }
  201. #endif
  202. #endif
  203. #if ENABLED(FWRETRACT)
  204. #include "../../feature/fwretract.h"
  205. void menu_config_retract() {
  206. START_MENU();
  207. BACK_ITEM(MSG_CONFIGURATION);
  208. #if ENABLED(FWRETRACT_AUTORETRACT)
  209. EDIT_ITEM(bool, MSG_AUTORETRACT, &fwretract.autoretract_enabled, fwretract.refresh_autoretract);
  210. #endif
  211. EDIT_ITEM(float52sign, MSG_CONTROL_RETRACT, &fwretract.settings.retract_length, 0, 100);
  212. #if EXTRUDERS > 1
  213. EDIT_ITEM(float52sign, MSG_CONTROL_RETRACT_SWAP, &fwretract.settings.swap_retract_length, 0, 100);
  214. #endif
  215. EDIT_ITEM(float3, MSG_CONTROL_RETRACTF, &fwretract.settings.retract_feedrate_mm_s, 1, 999);
  216. EDIT_ITEM(float52sign, MSG_CONTROL_RETRACT_ZHOP, &fwretract.settings.retract_zraise, 0, 999);
  217. EDIT_ITEM(float52sign, MSG_CONTROL_RETRACT_RECOVER, &fwretract.settings.retract_recover_extra, -100, 100);
  218. #if EXTRUDERS > 1
  219. EDIT_ITEM(float52sign, MSG_CONTROL_RETRACT_RECOVER_SWAP, &fwretract.settings.swap_retract_recover_extra, -100, 100);
  220. #endif
  221. EDIT_ITEM(float3, MSG_CONTROL_RETRACT_RECOVERF, &fwretract.settings.retract_recover_feedrate_mm_s, 1, 999);
  222. #if EXTRUDERS > 1
  223. EDIT_ITEM(float3, MSG_CONTROL_RETRACT_RECOVER_SWAPF, &fwretract.settings.swap_retract_recover_feedrate_mm_s, 1, 999);
  224. #endif
  225. END_MENU();
  226. }
  227. #endif
  228. #if DISABLED(SLIM_LCD_MENUS)
  229. void _menu_configuration_preheat_settings(const uint8_t material) {
  230. #define _MINTEMP_ITEM(N) HEATER_##N##_MINTEMP,
  231. #define _MAXTEMP_ITEM(N) HEATER_##N##_MAXTEMP,
  232. #define MINTEMP_ALL _MIN(REPEAT(HOTENDS, _MINTEMP_ITEM) 999)
  233. #define MAXTEMP_ALL _MAX(REPEAT(HOTENDS, _MAXTEMP_ITEM) 0)
  234. START_MENU();
  235. BACK_ITEM(MSG_CONFIGURATION);
  236. EDIT_ITEM(percent, MSG_FAN_SPEED, &ui.preheat_fan_speed[material], 0, 255);
  237. #if HAS_TEMP_HOTEND
  238. EDIT_ITEM(int3, MSG_NOZZLE, &ui.preheat_hotend_temp[material], MINTEMP_ALL, MAXTEMP_ALL - 15);
  239. #endif
  240. #if HAS_HEATED_BED
  241. EDIT_ITEM(int3, MSG_BED, &ui.preheat_bed_temp[material], BED_MINTEMP, BED_MAXTEMP - 10);
  242. #endif
  243. #if ENABLED(EEPROM_SETTINGS)
  244. ACTION_ITEM(MSG_STORE_EEPROM, lcd_store_settings);
  245. #endif
  246. END_MENU();
  247. }
  248. void menu_preheat_material1_settings() { _menu_configuration_preheat_settings(0); }
  249. void menu_preheat_material2_settings() { _menu_configuration_preheat_settings(1); }
  250. #endif
  251. void menu_configuration() {
  252. START_MENU();
  253. BACK_ITEM(MSG_MAIN);
  254. //
  255. // Debug Menu when certain options are enabled
  256. //
  257. #if HAS_DEBUG_MENU
  258. SUBMENU(MSG_DEBUG_MENU, menu_debug);
  259. #endif
  260. SUBMENU(MSG_ADVANCED_SETTINGS, menu_advanced_settings);
  261. #if ENABLED(BABYSTEP_ZPROBE_OFFSET)
  262. SUBMENU(MSG_ZPROBE_ZOFFSET, lcd_babystep_zoffset);
  263. #elif HAS_BED_PROBE
  264. EDIT_ITEM(LCD_Z_OFFSET_TYPE, MSG_ZPROBE_ZOFFSET, &probe.offset.z, Z_PROBE_OFFSET_RANGE_MIN, Z_PROBE_OFFSET_RANGE_MAX);
  265. #endif
  266. const bool busy = printer_busy();
  267. if (!busy) {
  268. #if EITHER(DELTA_CALIBRATION_MENU, DELTA_AUTO_CALIBRATION)
  269. SUBMENU(MSG_DELTA_CALIBRATE, menu_delta_calibrate);
  270. #endif
  271. #if HAS_HOTEND_OFFSET
  272. SUBMENU(STR_OFFSETS_MENU, menu_tool_offsets);
  273. #endif
  274. #if ENABLED(DUAL_X_CARRIAGE)
  275. SUBMENU(MSG_IDEX_MENU, menu_idex);
  276. #endif
  277. #if ENABLED(BLTOUCH)
  278. SUBMENU(MSG_BLTOUCH, menu_bltouch);
  279. #endif
  280. #if ENABLED(TOUCH_MI_PROBE)
  281. SUBMENU(MSG_TOUCHMI_PROBE, menu_touchmi);
  282. #endif
  283. }
  284. //
  285. // Set single nozzle filament retract and prime length
  286. //
  287. #if EXTRUDERS > 1
  288. SUBMENU(MSG_TOOL_CHANGE, menu_tool_change);
  289. #endif
  290. //
  291. // Set Case light on/off/brightness
  292. //
  293. #if ENABLED(CASE_LIGHT_MENU)
  294. #if DISABLED(CASE_LIGHT_NO_BRIGHTNESS)
  295. if (true
  296. #if DISABLED(CASE_LIGHT_USE_NEOPIXEL)
  297. && PWM_PIN(CASE_LIGHT_PIN)
  298. #endif
  299. )
  300. SUBMENU(MSG_CASE_LIGHT, menu_case_light);
  301. else
  302. #endif
  303. EDIT_ITEM(bool, MSG_CASE_LIGHT, (bool*)&case_light_on, update_case_light);
  304. #endif
  305. #if HAS_LCD_CONTRAST
  306. EDIT_ITEM(int3, MSG_CONTRAST, &ui.contrast, LCD_CONTRAST_MIN, LCD_CONTRAST_MAX, ui.refresh_contrast, true);
  307. #endif
  308. #if ENABLED(FWRETRACT)
  309. SUBMENU(MSG_RETRACT, menu_config_retract);
  310. #endif
  311. #if HAS_FILAMENT_SENSOR
  312. EDIT_ITEM(bool, MSG_RUNOUT_SENSOR, &runout.enabled, runout.reset);
  313. #endif
  314. #if ENABLED(POWER_LOSS_RECOVERY)
  315. EDIT_ITEM(bool, MSG_OUTAGE_RECOVERY, &recovery.enabled, recovery.changed);
  316. #endif
  317. #if DISABLED(SLIM_LCD_MENUS)
  318. // Preheat configurations
  319. SUBMENU(MSG_PREHEAT_1_SETTINGS, menu_preheat_material1_settings);
  320. SUBMENU(MSG_PREHEAT_2_SETTINGS, menu_preheat_material2_settings);
  321. #endif
  322. #if ENABLED(EEPROM_SETTINGS)
  323. ACTION_ITEM(MSG_STORE_EEPROM, lcd_store_settings);
  324. if (!busy)
  325. ACTION_ITEM(MSG_LOAD_EEPROM, lcd_load_settings);
  326. #endif
  327. if (!busy)
  328. ACTION_ITEM(MSG_RESTORE_DEFAULTS, []{
  329. settings.reset();
  330. #if HAS_BUZZER
  331. ui.completion_feedback();
  332. #endif
  333. });
  334. END_MENU();
  335. }
  336. #endif // HAS_LCD_MENU