My Marlin configs for Fabrikator Mini and CTC i3 Pro B
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

DGUSDisplayDef.cpp 19KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486
  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. /* DGUS VPs changed by George Fu in 2019 for Marlin */
  23. #include "../../../../../inc/MarlinConfigPre.h"
  24. #if ENABLED(DGUS_LCD_UI_FYSETC)
  25. #include "../DGUSDisplayDef.h"
  26. #include "../DGUSDisplay.h"
  27. #include "../DGUSScreenHandler.h"
  28. #include "../../../../../module/temperature.h"
  29. #include "../../../../../module/motion.h"
  30. #include "../../../../../module/planner.h"
  31. #include "../../../ui_api.h"
  32. #include "../../../../ultralcd.h"
  33. #if ENABLED(DGUS_UI_MOVE_DIS_OPTION)
  34. uint16_t distanceToMove = 10;
  35. #endif
  36. const uint16_t VPList_Boot[] PROGMEM = {
  37. VP_MARLIN_VERSION,
  38. 0x0000
  39. };
  40. const uint16_t VPList_Main[] PROGMEM = {
  41. /* VP_M117, for completeness, but it cannot be auto-uploaded. */
  42. #if HOTENDS >= 1
  43. VP_T_E0_Is, VP_T_E0_Set, VP_E0_STATUS,
  44. #endif
  45. #if HOTENDS >= 2
  46. VP_T_E1_Is, VP_T_E1_Set,
  47. #endif
  48. #if HAS_HEATED_BED
  49. VP_T_Bed_Is, VP_T_Bed_Set, VP_BED_STATUS,
  50. #endif
  51. #if HAS_FAN
  52. VP_Fan0_Percentage, VP_FAN0_STATUS,
  53. #endif
  54. VP_XPos, VP_YPos, VP_ZPos,
  55. VP_Fan0_Percentage,
  56. VP_Feedrate_Percentage,
  57. #if ENABLED(LCD_SET_PROGRESS_MANUALLY)
  58. VP_PrintProgress_Percentage,
  59. #endif
  60. 0x0000
  61. };
  62. const uint16_t VPList_Temp[] PROGMEM = {
  63. #if HOTENDS >= 1
  64. VP_T_E0_Is, VP_T_E0_Set,
  65. #endif
  66. #if HOTENDS >= 2
  67. VP_T_E1_Is, VP_T_E1_Set,
  68. #endif
  69. #if HAS_HEATED_BED
  70. VP_T_Bed_Is, VP_T_Bed_Set,
  71. #endif
  72. 0x0000
  73. };
  74. const uint16_t VPList_Status[] PROGMEM = {
  75. /* VP_M117, for completeness, but it cannot be auto-uploaded */
  76. #if HOTENDS >= 1
  77. VP_T_E0_Is, VP_T_E0_Set,
  78. #endif
  79. #if HOTENDS >= 2
  80. VP_T_E1_Is, VP_T_E1_Set,
  81. #endif
  82. #if HAS_HEATED_BED
  83. VP_T_Bed_Is, VP_T_Bed_Set,
  84. #endif
  85. #if HAS_FAN
  86. VP_Fan0_Percentage,
  87. #endif
  88. VP_XPos, VP_YPos, VP_ZPos,
  89. VP_Fan0_Percentage,
  90. VP_Feedrate_Percentage,
  91. VP_PrintProgress_Percentage,
  92. 0x0000
  93. };
  94. const uint16_t VPList_Status2[] PROGMEM = {
  95. /* VP_M117, for completeness, but it cannot be auto-uploaded */
  96. #if HOTENDS >= 1
  97. VP_Flowrate_E0,
  98. #endif
  99. #if HOTENDS >= 2
  100. VP_Flowrate_E1,
  101. #endif
  102. VP_PrintProgress_Percentage,
  103. VP_PrintTime,
  104. 0x0000
  105. };
  106. const uint16_t VPList_Preheat[] PROGMEM = {
  107. #if HOTENDS >= 1
  108. VP_T_E0_Is, VP_T_E0_Set,
  109. #endif
  110. #if HOTENDS >= 2
  111. VP_T_E1_Is, VP_T_E1_Set,
  112. #endif
  113. #if HAS_HEATED_BED
  114. VP_T_Bed_Is, VP_T_Bed_Set,
  115. #endif
  116. 0x0000
  117. };
  118. const uint16_t VPList_ManualMove[] PROGMEM = {
  119. VP_XPos, VP_YPos, VP_ZPos,
  120. 0x0000
  121. };
  122. const uint16_t VPList_ManualExtrude[] PROGMEM = {
  123. #if HOTENDS >= 1
  124. VP_T_E0_Is, VP_T_E0_Set,
  125. #endif
  126. #if HOTENDS >= 2
  127. VP_T_E1_Is, VP_T_E1_Set,
  128. #endif
  129. VP_EPos,
  130. 0x0000
  131. };
  132. const uint16_t VPList_FanAndFeedrate[] PROGMEM = {
  133. VP_Feedrate_Percentage, VP_Fan0_Percentage,
  134. 0x0000
  135. };
  136. const uint16_t VPList_SD_FlowRates[] PROGMEM = {
  137. VP_Flowrate_E0, VP_Flowrate_E1,
  138. 0x0000
  139. };
  140. const uint16_t VPList_Filament_heating[] PROGMEM = {
  141. #if HOTENDS >= 1
  142. VP_T_E0_Is, VP_T_E0_Set,
  143. VP_E0_FILAMENT_LOAD_UNLOAD,
  144. #endif
  145. #if HOTENDS >= 2
  146. VP_T_E1_Is, VP_T_E1_Set,
  147. VP_E1_FILAMENT_LOAD_UNLOAD,
  148. #endif
  149. 0x0000
  150. };
  151. const uint16_t VPList_Filament_load_unload[] PROGMEM = {
  152. #if HOTENDS >= 1
  153. VP_E0_FILAMENT_LOAD_UNLOAD,
  154. #endif
  155. #if HOTENDS >= 2
  156. VP_E1_FILAMENT_LOAD_UNLOAD,
  157. #endif
  158. 0x0000
  159. };
  160. const uint16_t VPList_SDFileList[] PROGMEM = {
  161. VP_SD_FileName0, VP_SD_FileName1, VP_SD_FileName2, VP_SD_FileName3, VP_SD_FileName4,
  162. 0x0000
  163. };
  164. const uint16_t VPList_SD_PrintManipulation[] PROGMEM = {
  165. VP_PrintProgress_Percentage, VP_PrintTime,
  166. #if HOTENDS >= 1
  167. VP_T_E0_Is, VP_T_E0_Set,
  168. #endif
  169. #if HOTENDS >= 2
  170. VP_T_E1_Is, VP_T_E1_Set,
  171. #endif
  172. #if HAS_HEATED_BED
  173. VP_T_Bed_Is, VP_T_Bed_Set,
  174. #endif
  175. #if HAS_FAN
  176. VP_Fan0_Percentage,
  177. #if FAN_COUNT > 1
  178. VP_Fan1_Percentage,
  179. #endif
  180. #endif
  181. VP_Flowrate_E0,
  182. 0x0000
  183. };
  184. const uint16_t VPList_SDPrintTune[] PROGMEM = {
  185. #if HOTENDS >= 1
  186. VP_T_E0_Is, VP_T_E0_Set, VP_Flowrate_E0,
  187. #endif
  188. #if HOTENDS >= 2
  189. VP_T_E1_Is, VP_T_E1_Set, VP_Flowrate_E1,
  190. #endif
  191. #if HAS_HEATED_BED
  192. VP_T_Bed_Is, VP_T_Bed_Set,
  193. #endif
  194. VP_Feedrate_Percentage,
  195. VP_SD_Print_ProbeOffsetZ,
  196. 0x0000
  197. };
  198. const uint16_t VPList_StepPerMM[] PROGMEM = {
  199. VP_X_STEP_PER_MM,
  200. VP_Y_STEP_PER_MM,
  201. VP_Z_STEP_PER_MM,
  202. #if HOTENDS >= 1
  203. VP_E0_STEP_PER_MM,
  204. #endif
  205. #if HOTENDS >= 2
  206. VP_E1_STEP_PER_MM,
  207. #endif
  208. 0x0000
  209. };
  210. const uint16_t VPList_PIDE0[] PROGMEM = {
  211. #if ENABLED(PIDTEMP)
  212. VP_E0_PID_P,
  213. VP_E0_PID_I,
  214. VP_E0_PID_D,
  215. #endif
  216. 0x0000
  217. };
  218. const uint16_t VPList_PIDBED[] PROGMEM = {
  219. #if ENABLED(PIDTEMP)
  220. VP_BED_PID_P,
  221. VP_BED_PID_I,
  222. VP_BED_PID_D,
  223. #endif
  224. 0x0000
  225. };
  226. const uint16_t VPList_Infos[] PROGMEM = {
  227. VP_MARLIN_VERSION,
  228. VP_PrintTime,
  229. #if ENABLED(PRINTCOUNTER)
  230. VP_PrintAccTime,
  231. VP_PrintsTotal,
  232. #endif
  233. 0x0000
  234. };
  235. const uint16_t VPList_PIDTuningWaiting[] PROGMEM = {
  236. VP_WAITING_STATUS,
  237. 0x0000
  238. };
  239. const uint16_t VPList_FLCPreheat[] PROGMEM = {
  240. #if HOTENDS >= 1
  241. VP_T_E0_Is, VP_T_E0_Set,
  242. #endif
  243. #if HAS_HEATED_BED
  244. VP_T_Bed_Is, VP_T_Bed_Set,
  245. #endif
  246. 0x0000
  247. };
  248. const uint16_t VPList_FLCPrinting[] PROGMEM = {
  249. #if HOTENDS >= 1
  250. VP_SD_Print_ProbeOffsetZ,
  251. #endif
  252. 0x0000
  253. };
  254. const uint16_t VPList_Z_Offset[] PROGMEM = {
  255. #if HOTENDS >= 1
  256. VP_SD_Print_ProbeOffsetZ,
  257. #endif
  258. 0x0000
  259. };
  260. const struct VPMapping VPMap[] PROGMEM = {
  261. { DGUSLCD_SCREEN_BOOT, VPList_Boot },
  262. { DGUSLCD_SCREEN_MAIN, VPList_Main },
  263. { DGUSLCD_SCREEN_TEMPERATURE, VPList_Temp },
  264. { DGUSLCD_SCREEN_STATUS, VPList_Status },
  265. { DGUSLCD_SCREEN_STATUS2, VPList_Status2 },
  266. { DGUSLCD_SCREEN_PREHEAT, VPList_Preheat },
  267. { DGUSLCD_SCREEN_MANUALMOVE, VPList_ManualMove },
  268. { DGUSLCD_SCREEN_MANUALEXTRUDE, VPList_ManualExtrude },
  269. { DGUSLCD_SCREEN_FILAMENT_HEATING, VPList_Filament_heating },
  270. { DGUSLCD_SCREEN_FILAMENT_LOADING, VPList_Filament_load_unload },
  271. { DGUSLCD_SCREEN_FILAMENT_UNLOADING, VPList_Filament_load_unload },
  272. { DGUSLCD_SCREEN_SDPRINTMANIPULATION, VPList_SD_PrintManipulation },
  273. { DGUSLCD_SCREEN_SDFILELIST, VPList_SDFileList },
  274. { DGUSLCD_SCREEN_SDPRINTTUNE, VPList_SDPrintTune },
  275. { DGUSLCD_SCREEN_WAITING, VPList_PIDTuningWaiting },
  276. { DGUSLCD_SCREEN_FLC_PREHEAT, VPList_FLCPreheat },
  277. { DGUSLCD_SCREEN_FLC_PRINTING, VPList_FLCPrinting },
  278. { DGUSLCD_SCREEN_Z_OFFSET, VPList_Z_Offset },
  279. { DGUSLCD_SCREEN_STEPPERMM, VPList_StepPerMM },
  280. { DGUSLCD_SCREEN_PID_E, VPList_PIDE0 },
  281. { DGUSLCD_SCREEN_PID_BED, VPList_PIDBED },
  282. { DGUSLCD_SCREEN_INFOS, VPList_Infos },
  283. { 0 , nullptr } // List is terminated with an nullptr as table entry.
  284. };
  285. const char MarlinVersion[] PROGMEM = SHORT_BUILD_VERSION;
  286. // Helper to define a DGUS_VP_Variable for common use cases.
  287. #define VPHELPER(VPADR, VPADRVAR, RXFPTR, TXFPTR ) { .VP=VPADR, .memadr=VPADRVAR, .size=sizeof(VPADRVAR), \
  288. .set_by_display_handler = RXFPTR, .send_to_display_handler = TXFPTR }
  289. // Helper to define a DGUS_VP_Variable when the sizeo of the var cannot be determined automaticalyl (eg. a string)
  290. #define VPHELPER_STR(VPADR, VPADRVAR, STRLEN, RXFPTR, TXFPTR ) { .VP=VPADR, .memadr=VPADRVAR, .size=STRLEN, \
  291. .set_by_display_handler = RXFPTR, .send_to_display_handler = TXFPTR }
  292. const struct DGUS_VP_Variable ListOfVP[] PROGMEM = {
  293. // Helper to detect touch events
  294. VPHELPER(VP_SCREENCHANGE, nullptr, ScreenHandler.ScreenChangeHook, nullptr),
  295. VPHELPER(VP_SCREENCHANGE_ASK, nullptr, ScreenHandler.ScreenChangeHookIfIdle, nullptr),
  296. #if ENABLED(SDSUPPORT)
  297. VPHELPER(VP_SCREENCHANGE_WHENSD, nullptr, ScreenHandler.ScreenChangeHookIfSD, nullptr),
  298. #endif
  299. VPHELPER(VP_CONFIRMED, nullptr, ScreenHandler.ScreenConfirmedOK, nullptr),
  300. VPHELPER(VP_TEMP_ALL_OFF, nullptr, &ScreenHandler.HandleAllHeatersOff, nullptr),
  301. #if ENABLED(DGUS_UI_MOVE_DIS_OPTION)
  302. VPHELPER(VP_MOVE_OPTION, &distanceToMove, &ScreenHandler.HandleManualMoveOption, nullptr),
  303. #endif
  304. #if ENABLED(DGUS_UI_MOVE_DIS_OPTION)
  305. VPHELPER(VP_MOVE_X, &distanceToMove, &ScreenHandler.HandleManualMove, nullptr),
  306. VPHELPER(VP_MOVE_Y, &distanceToMove, &ScreenHandler.HandleManualMove, nullptr),
  307. VPHELPER(VP_MOVE_Z, &distanceToMove, &ScreenHandler.HandleManualMove, nullptr),
  308. VPHELPER(VP_HOME_ALL, &distanceToMove, &ScreenHandler.HandleManualMove, nullptr),
  309. #else
  310. VPHELPER(VP_MOVE_X, nullptr, &ScreenHandler.HandleManualMove, nullptr),
  311. VPHELPER(VP_MOVE_Y, nullptr, &ScreenHandler.HandleManualMove, nullptr),
  312. VPHELPER(VP_MOVE_Z, nullptr, &ScreenHandler.HandleManualMove, nullptr),
  313. VPHELPER(VP_HOME_ALL, nullptr, &ScreenHandler.HandleManualMove, nullptr),
  314. #endif
  315. VPHELPER(VP_MOTOR_LOCK_UNLOK, nullptr, &ScreenHandler.HandleMotorLockUnlock, nullptr),
  316. #if ENABLED(POWER_LOSS_RECOVERY)
  317. VPHELPER(VP_POWER_LOSS_RECOVERY, nullptr, &ScreenHandler.HandlePowerLossRecovery, nullptr),
  318. #endif
  319. VPHELPER(VP_SETTINGS, nullptr, &ScreenHandler.HandleSettings, nullptr),
  320. #if ENABLED(SINGLE_Z_CALIBRATION)
  321. VPHELPER(VP_Z_CALIBRATE, nullptr, &ScreenHandler.HandleZCalibration, nullptr),
  322. #endif
  323. #if ENABLED(FIRST_LAYER_CAL)
  324. VPHELPER(VP_Z_FIRST_LAYER_CAL, nullptr, &ScreenHandler.HandleFirstLayerCal, nullptr),
  325. #endif
  326. { .VP = VP_MARLIN_VERSION, .memadr = (void*)MarlinVersion, .size = VP_MARLIN_VERSION_LEN, .set_by_display_handler = nullptr, .send_to_display_handler =&ScreenHandler.DGUSLCD_SendStringToDisplayPGM },
  327. // M117 LCD String (We don't need the string in memory but "just" push it to the display on demand, hence the nullptr
  328. { .VP = VP_M117, .memadr = nullptr, .size = VP_M117_LEN, .set_by_display_handler = nullptr, .send_to_display_handler =&ScreenHandler.DGUSLCD_SendStringToDisplay },
  329. // Temperature Data
  330. #if HOTENDS >= 1
  331. VPHELPER(VP_T_E0_Is, &thermalManager.temp_hotend[0].celsius, nullptr, ScreenHandler.DGUSLCD_SendFloatAsLongValueToDisplay<0>),
  332. VPHELPER(VP_T_E0_Set, &thermalManager.temp_hotend[0].target, ScreenHandler.HandleTemperatureChanged, &ScreenHandler.DGUSLCD_SendWordValueToDisplay),
  333. VPHELPER(VP_Flowrate_E0, &planner.flow_percentage[ExtUI::extruder_t::E0], ScreenHandler.HandleFlowRateChanged, &ScreenHandler.DGUSLCD_SendWordValueToDisplay),
  334. VPHELPER(VP_EPos, &destination.e, nullptr, ScreenHandler.DGUSLCD_SendFloatAsLongValueToDisplay<2>),
  335. VPHELPER(VP_MOVE_E0, nullptr, &ScreenHandler.HandleManualExtrude, nullptr),
  336. VPHELPER(VP_E0_CONTROL, &thermalManager.temp_hotend[0].target, &ScreenHandler.HandleHeaterControl, nullptr),
  337. VPHELPER(VP_E0_STATUS, &thermalManager.temp_hotend[0].target, nullptr, &ScreenHandler.DGUSLCD_SendHeaterStatusToDisplay),
  338. #if ENABLED(DGUS_PREHEAT_UI)
  339. VPHELPER(VP_E0_BED_PREHEAT, nullptr, &ScreenHandler.HandlePreheat, nullptr),
  340. #endif
  341. #if ENABLED(PIDTEMP)
  342. VPHELPER(VP_E0_PID_P, &thermalManager.temp_hotend[0].pid.Kp, ScreenHandler.HandleTemperaturePIDChanged, ScreenHandler.DGUSLCD_SendTemperaturePID),
  343. VPHELPER(VP_E0_PID_I, &thermalManager.temp_hotend[0].pid.Ki, ScreenHandler.HandleTemperaturePIDChanged, ScreenHandler.DGUSLCD_SendTemperaturePID),
  344. VPHELPER(VP_E0_PID_D, &thermalManager.temp_hotend[0].pid.Kd, ScreenHandler.HandleTemperaturePIDChanged, ScreenHandler.DGUSLCD_SendTemperaturePID),
  345. VPHELPER(VP_PID_AUTOTUNE_E0, nullptr, &ScreenHandler.HandlePIDAutotune, nullptr),
  346. #endif
  347. #if ENABLED(DGUS_FILAMENT_LOADUNLOAD)
  348. VPHELPER(VP_E0_FILAMENT_LOAD_UNLOAD, nullptr, &ScreenHandler.HandleFilamentOption, &ScreenHandler.HandleFilamentLoadUnload),
  349. #endif
  350. #endif
  351. #if HOTENDS >= 2
  352. VPHELPER(VP_T_E1_Is, &thermalManager.temp_hotend[1].celsius, nullptr, ScreenHandler.DGUSLCD_SendFloatAsLongValueToDisplay<0>),
  353. VPHELPER(VP_T_E1_Set, &thermalManager.temp_hotend[1].target, ScreenHandler.HandleTemperatureChanged, &ScreenHandler.DGUSLCD_SendWordValueToDisplay),
  354. VPHELPER(VP_Flowrate_E1, &planner.flow_percentage[ExtUI::extruder_t::E1], ScreenHandler.HandleFlowRateChanged, &ScreenHandler.DGUSLCD_SendWordValueToDisplay),
  355. VPHELPER(VP_MOVE_E1, nullptr, &ScreenHandler.HandleManualExtrude, nullptr),
  356. VPHELPER(VP_E1_CONTROL, &thermalManager.temp_hotend[1].target, &ScreenHandler.HandleHeaterControl, nullptr),
  357. VPHELPER(VP_E1_STATUS, &thermalManager.temp_hotend[1].target, nullptr, &ScreenHandler.DGUSLCD_SendHeaterStatusToDisplay),
  358. #if ENABLED(PIDTEMP)
  359. VPHELPER(VP_PID_AUTOTUNE_E1, nullptr, &ScreenHandler.HandlePIDAutotune, nullptr),
  360. #endif
  361. VPHELPER(VP_E1_FILAMENT_LOAD_UNLOAD, nullptr, &ScreenHandler.HandleFilamentOption, &ScreenHandler.HandleFilamentLoadUnload),
  362. #endif
  363. #if HAS_HEATED_BED
  364. VPHELPER(VP_T_Bed_Is, &thermalManager.temp_bed.celsius, nullptr, ScreenHandler.DGUSLCD_SendFloatAsLongValueToDisplay<0>),
  365. VPHELPER(VP_T_Bed_Set, &thermalManager.temp_bed.target, ScreenHandler.HandleTemperatureChanged, &ScreenHandler.DGUSLCD_SendWordValueToDisplay),
  366. VPHELPER(VP_BED_CONTROL, &thermalManager.temp_bed.target, &ScreenHandler.HandleHeaterControl, nullptr),
  367. VPHELPER(VP_BED_STATUS, &thermalManager.temp_bed.target, nullptr, &ScreenHandler.DGUSLCD_SendHeaterStatusToDisplay),
  368. #if ENABLED(PIDTEMPBED)
  369. VPHELPER(VP_BED_PID_P, &thermalManager.temp_bed.pid.Kp, ScreenHandler.HandleTemperaturePIDChanged, ScreenHandler.DGUSLCD_SendTemperaturePID),
  370. VPHELPER(VP_BED_PID_I, &thermalManager.temp_bed.pid.Ki, ScreenHandler.HandleTemperaturePIDChanged, ScreenHandler.DGUSLCD_SendTemperaturePID),
  371. VPHELPER(VP_BED_PID_D, &thermalManager.temp_bed.pid.Kd, ScreenHandler.HandleTemperaturePIDChanged, ScreenHandler.DGUSLCD_SendTemperaturePID),
  372. VPHELPER(VP_PID_AUTOTUNE_BED, nullptr, &ScreenHandler.HandlePIDAutotune, nullptr),
  373. #endif
  374. #endif
  375. // Fan Data
  376. #if HAS_FAN
  377. #define FAN_VPHELPER(N) \
  378. VPHELPER(VP_Fan##N##_Percentage, &thermalManager.fan_speed[N], ScreenHandler.DGUSLCD_PercentageToUint8, &ScreenHandler.DGUSLCD_SendPercentageToDisplay), \
  379. VPHELPER(VP_FAN##N##_CONTROL, &thermalManager.fan_speed[N], &ScreenHandler.HandleFanControl, nullptr), \
  380. VPHELPER(VP_FAN##N##_STATUS, &thermalManager.fan_speed[N], nullptr, &ScreenHandler.DGUSLCD_SendFanStatusToDisplay),
  381. REPEAT(FAN_COUNT, FAN_VPHELPER)
  382. #endif
  383. // Feedrate
  384. VPHELPER(VP_Feedrate_Percentage, &feedrate_percentage, ScreenHandler.DGUSLCD_SetValueDirectly<int16_t>, &ScreenHandler.DGUSLCD_SendWordValueToDisplay ),
  385. // Position Data
  386. VPHELPER(VP_XPos, &current_position.x, nullptr, ScreenHandler.DGUSLCD_SendFloatAsLongValueToDisplay<2>),
  387. VPHELPER(VP_YPos, &current_position.y, nullptr, ScreenHandler.DGUSLCD_SendFloatAsLongValueToDisplay<2>),
  388. VPHELPER(VP_ZPos, &current_position.z, nullptr, ScreenHandler.DGUSLCD_SendFloatAsLongValueToDisplay<2>),
  389. // Print Progress
  390. VPHELPER(VP_PrintProgress_Percentage, nullptr, nullptr, ScreenHandler.DGUSLCD_SendPrintProgressToDisplay ),
  391. // Print Time
  392. VPHELPER_STR(VP_PrintTime, nullptr, VP_PrintTime_LEN, nullptr, ScreenHandler.DGUSLCD_SendPrintTimeToDisplay),
  393. #if ENABLED(PRINTCOUNTER)
  394. VPHELPER_STR(VP_PrintAccTime, nullptr, VP_PrintAccTime_LEN, nullptr, ScreenHandler.DGUSLCD_SendPrintAccTimeToDisplay),
  395. VPHELPER_STR(VP_PrintsTotal, nullptr, VP_PrintsTotal_LEN, nullptr, ScreenHandler.DGUSLCD_SendPrintsTotalToDisplay),
  396. #endif
  397. VPHELPER(VP_X_STEP_PER_MM, &planner.settings.axis_steps_per_mm[X_AXIS], ScreenHandler.HandleStepPerMMChanged, ScreenHandler.DGUSLCD_SendFloatAsIntValueToDisplay<1>),
  398. VPHELPER(VP_Y_STEP_PER_MM, &planner.settings.axis_steps_per_mm[Y_AXIS], ScreenHandler.HandleStepPerMMChanged, ScreenHandler.DGUSLCD_SendFloatAsIntValueToDisplay<1>),
  399. VPHELPER(VP_Z_STEP_PER_MM, &planner.settings.axis_steps_per_mm[Z_AXIS], ScreenHandler.HandleStepPerMMChanged, ScreenHandler.DGUSLCD_SendFloatAsIntValueToDisplay<1>),
  400. #if HOTENDS >= 1
  401. VPHELPER(VP_E0_STEP_PER_MM, &planner.settings.axis_steps_per_mm[E_AXIS_N(0)], ScreenHandler.HandleStepPerMMExtruderChanged, ScreenHandler.DGUSLCD_SendFloatAsIntValueToDisplay<1>),
  402. #endif
  403. #if HOTENDS >= 2
  404. VPHELPER(VP_E1_STEP_PER_MM, &planner.settings.axis_steps_per_mm[E_AXIS_N(1)], ScreenHandler.HandleStepPerMMExtruderChanged, ScreenHandler.DGUSLCD_SendFloatAsIntValueToDisplay<1>),
  405. #endif
  406. // SDCard File listing.
  407. #if ENABLED(SDSUPPORT)
  408. VPHELPER(VP_SD_ScrollEvent, nullptr, ScreenHandler.DGUSLCD_SD_ScrollFilelist, nullptr),
  409. VPHELPER(VP_SD_FileSelected, nullptr, ScreenHandler.DGUSLCD_SD_FileSelected, nullptr),
  410. VPHELPER(VP_SD_FileSelectConfirm, nullptr, ScreenHandler.DGUSLCD_SD_StartPrint, nullptr),
  411. VPHELPER_STR(VP_SD_FileName0, nullptr, VP_SD_FileName_LEN, nullptr, ScreenHandler.DGUSLCD_SD_SendFilename),
  412. VPHELPER_STR(VP_SD_FileName1, nullptr, VP_SD_FileName_LEN, nullptr, ScreenHandler.DGUSLCD_SD_SendFilename),
  413. VPHELPER_STR(VP_SD_FileName2, nullptr, VP_SD_FileName_LEN, nullptr, ScreenHandler.DGUSLCD_SD_SendFilename),
  414. VPHELPER_STR(VP_SD_FileName3, nullptr, VP_SD_FileName_LEN, nullptr, ScreenHandler.DGUSLCD_SD_SendFilename),
  415. VPHELPER_STR(VP_SD_FileName4, nullptr, VP_SD_FileName_LEN, nullptr, ScreenHandler.DGUSLCD_SD_SendFilename),
  416. VPHELPER(VP_SD_ResumePauseAbort, nullptr, ScreenHandler.DGUSLCD_SD_ResumePauseAbort, nullptr),
  417. VPHELPER(VP_SD_AbortPrintConfirmed, nullptr, ScreenHandler.DGUSLCD_SD_ReallyAbort, nullptr),
  418. VPHELPER(VP_SD_Print_Setting, nullptr, ScreenHandler.DGUSLCD_SD_PrintTune, nullptr),
  419. #if HAS_BED_PROBE
  420. VPHELPER(VP_SD_Print_ProbeOffsetZ, &probe.offset.z, ScreenHandler.HandleProbeOffsetZChanged, &ScreenHandler.DGUSLCD_SendFloatAsIntValueToDisplay<2>),
  421. #if ENABLED(BABYSTEPPING)
  422. VPHELPER(VP_SD_Print_LiveAdjustZ, nullptr, ScreenHandler.HandleLiveAdjustZ, nullptr),
  423. #endif
  424. #endif
  425. #endif
  426. #if ENABLED(DGUS_UI_WAITING)
  427. VPHELPER(VP_WAITING_STATUS, nullptr, nullptr, ScreenHandler.DGUSLCD_SendWaitingStatusToDisplay),
  428. #endif
  429. // Messages for the User, shared by the popup and the kill screen. They cant be autouploaded as we do not buffer content.
  430. { .VP = VP_MSGSTR1, .memadr = nullptr, .size = VP_MSGSTR1_LEN, .set_by_display_handler = nullptr, .send_to_display_handler = &ScreenHandler.DGUSLCD_SendStringToDisplayPGM },
  431. { .VP = VP_MSGSTR2, .memadr = nullptr, .size = VP_MSGSTR2_LEN, .set_by_display_handler = nullptr, .send_to_display_handler = &ScreenHandler.DGUSLCD_SendStringToDisplayPGM },
  432. { .VP = VP_MSGSTR3, .memadr = nullptr, .size = VP_MSGSTR3_LEN, .set_by_display_handler = nullptr, .send_to_display_handler = &ScreenHandler.DGUSLCD_SendStringToDisplayPGM },
  433. { .VP = VP_MSGSTR4, .memadr = nullptr, .size = VP_MSGSTR4_LEN, .set_by_display_handler = nullptr, .send_to_display_handler = &ScreenHandler.DGUSLCD_SendStringToDisplayPGM },
  434. VPHELPER(0, 0, 0, 0) // must be last entry.
  435. };
  436. #endif // DGUS_LCD_UI_FYSETC