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.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  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. #include "../../inc/MarlinConfig.h"
  23. #if IS_KINEMATIC
  24. #include "../gcode.h"
  25. #include "../../module/motion.h"
  26. #if ENABLED(DELTA)
  27. #include "../../module/delta.h"
  28. /**
  29. * M665: Set delta configurations
  30. *
  31. * H = delta height
  32. * L = diagonal rod
  33. * R = delta radius
  34. * S = segments per second
  35. * X = Alpha (Tower 1) angle trim
  36. * Y = Beta (Tower 2) angle trim
  37. * Z = Gamma (Tower 3) angle trim
  38. * A = Alpha (Tower 1) digonal rod trim
  39. * B = Beta (Tower 2) digonal rod trim
  40. * C = Gamma (Tower 3) digonal rod trim
  41. */
  42. void GcodeSuite::M665() {
  43. if (parser.seen('H')) delta_height = parser.value_linear_units();
  44. if (parser.seen('L')) delta_diagonal_rod = parser.value_linear_units();
  45. if (parser.seen('R')) delta_radius = parser.value_linear_units();
  46. if (parser.seen('S')) delta_segments_per_second = parser.value_float();
  47. if (parser.seen('X')) delta_tower_angle_trim.a = parser.value_float();
  48. if (parser.seen('Y')) delta_tower_angle_trim.b = parser.value_float();
  49. if (parser.seen('Z')) delta_tower_angle_trim.c = parser.value_float();
  50. if (parser.seen('A')) delta_diagonal_rod_trim.a = parser.value_float();
  51. if (parser.seen('B')) delta_diagonal_rod_trim.b = parser.value_float();
  52. if (parser.seen('C')) delta_diagonal_rod_trim.c = parser.value_float();
  53. recalc_delta_settings();
  54. }
  55. #elif IS_SCARA
  56. #include "../../module/scara.h"
  57. /**
  58. * M665: Set SCARA settings
  59. *
  60. * Parameters:
  61. *
  62. * S[segments-per-second] - Segments-per-second
  63. * P[theta-psi-offset] - Theta-Psi offset, added to the shoulder (A/X) angle
  64. * T[theta-offset] - Theta offset, added to the elbow (B/Y) angle
  65. * Z[z-offset] - Z offset, added to Z
  66. *
  67. * A, P, and X are all aliases for the shoulder angle
  68. * B, T, and Y are all aliases for the elbow angle
  69. */
  70. void GcodeSuite::M665() {
  71. if (parser.seenval('S')) delta_segments_per_second = parser.value_float();
  72. #if HAS_SCARA_OFFSET
  73. if (parser.seenval('Z')) scara_home_offset.z = parser.value_linear_units();
  74. const bool hasA = parser.seenval('A'), hasP = parser.seenval('P'), hasX = parser.seenval('X');
  75. const uint8_t sumAPX = hasA + hasP + hasX;
  76. if (sumAPX) {
  77. if (sumAPX == 1)
  78. scara_home_offset.a = parser.value_float();
  79. else {
  80. SERIAL_ERROR_MSG("Only one of A, P, or X is allowed.");
  81. return;
  82. }
  83. }
  84. const bool hasB = parser.seenval('B'), hasT = parser.seenval('T'), hasY = parser.seenval('Y');
  85. const uint8_t sumBTY = hasB + hasT + hasY;
  86. if (sumBTY) {
  87. if (sumBTY == 1)
  88. scara_home_offset.b = parser.value_float();
  89. else {
  90. SERIAL_ERROR_MSG("Only one of B, T, or Y is allowed.");
  91. return;
  92. }
  93. }
  94. #endif // HAS_SCARA_OFFSET
  95. }
  96. #endif
  97. #endif // IS_KINEMATIC