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

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