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.

DGUSDisplayDefinitionHIPRECY.cpp 20KB

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