IDEX clean up (#11690)
This commit is contained in:
		| @@ -174,6 +174,11 @@ void GcodeSuite::G28(const bool always_home_all) { | ||||
|     } | ||||
|   #endif | ||||
|  | ||||
|   #if ENABLED(DUAL_X_CARRIAGE) | ||||
|     bool IDEX_saved_duplication_state = extruder_duplication_enabled; | ||||
|     DualXMode IDEX_saved_mode = dual_x_carriage_mode; | ||||
|   #endif | ||||
|  | ||||
|   #if ENABLED(MARLIN_DEV_MODE) | ||||
|     if (parser.seen('S')) { | ||||
|       LOOP_XYZ(a) set_axis_is_at_home((AxisEnum)a); | ||||
| @@ -229,7 +234,7 @@ void GcodeSuite::G28(const bool always_home_all) { | ||||
|     tool_change(0, 0, true); | ||||
|   #endif | ||||
|  | ||||
|   #if ENABLED(DUAL_X_CARRIAGE) | ||||
|   #if ENABLED(DUAL_X_CARRIAGE) || ENABLED(DUAL_NOZZLE_DUPLICATION_MODE) | ||||
|     extruder_duplication_enabled = false; | ||||
|   #endif | ||||
|  | ||||
| @@ -354,6 +359,39 @@ void GcodeSuite::G28(const bool always_home_all) { | ||||
|  | ||||
|   #endif // !DELTA (G28) | ||||
|  | ||||
| /** | ||||
|  *  | ||||
|  * This code block allows the DXC mode to survive (and function) across a G28 if it is an IDEX | ||||
|  * machine and the printer is currently in DXC_DUPLICATION_MODE. | ||||
|  * This is important because it lets a user use the LCD Panel to set an IDEX Duplication mode, and  | ||||
|  * then print a standard GCode file that contains a single print that does a G28 and has no other | ||||
|  * IDEX specific commands in it. | ||||
|  *  | ||||
|  **/ | ||||
|  | ||||
|   #if ENABLED(DUAL_X_CARRIAGE) | ||||
|     if (dual_x_carriage_mode == DXC_DUPLICATION_MODE) { | ||||
|  | ||||
|         // Always home the 2nd (right) extruder first | ||||
|         active_extruder = 1; | ||||
|         homeaxis(X_AXIS); | ||||
|  | ||||
|         // Remember this extruder's position for later tool change | ||||
|         inactive_extruder_x_pos = current_position[X_AXIS]; | ||||
|  | ||||
|         // Home the 1st (left) extruder | ||||
|         active_extruder = 0; | ||||
|         homeaxis(X_AXIS); | ||||
|  | ||||
|         // Consider the active extruder to be parked | ||||
|         COPY(raised_parked_position, current_position); | ||||
|         delayed_move_time = 0; | ||||
|         active_extruder_parked = true; | ||||
|         extruder_duplication_enabled = IDEX_saved_duplication_state; | ||||
|         dual_x_carriage_mode         = IDEX_saved_mode; | ||||
|     } | ||||
|   #endif | ||||
|  | ||||
|   endstops.not_homing(); | ||||
|  | ||||
|   #if ENABLED(DELTA) && ENABLED(DELTA_HOME_TO_SAFE_ZONE) | ||||
|   | ||||
| @@ -27,24 +27,37 @@ | ||||
| #include "../gcode.h" | ||||
| #include "../../module/motion.h" | ||||
| #include "../../module/stepper.h" | ||||
| #include "../../module/tool_change.h" | ||||
| #include "../../module/planner.h" | ||||
|  | ||||
| #if ENABLED(DUAL_X_CARRIAGE) | ||||
|  | ||||
|   /** | ||||
|    * M605: Set dual x-carriage movement mode | ||||
|    * | ||||
|    *    M605    : Restore user specified DEFAULT_DUAL_X_CARRIAGE_MODE | ||||
|    *    M605 S0: Full control mode. The slicer has full control over x-carriage movement | ||||
|    *    M605 S1: Auto-park mode. The inactive head will auto park/unpark without slicer involvement | ||||
|    *    M605 S2 [Xnnn] [Rmmm]: Duplication mode. The second extruder will duplicate the first with nnn | ||||
|    *                         units x-offset and an optional differential hotend temperature of | ||||
|    *                         mmm degrees. E.g., with "M605 S2 X100 R2" the second extruder will duplicate | ||||
|    *                         the first with a spacing of 100mm in the x direction and 2 degrees hotter. | ||||
|    *    M605 S3 : Enable Symmetric Duplication mode.  The second extruder will duplicate the first extruder's | ||||
|    *              movement similar to the M605 S2 mode.   However, the second extruder will be producing | ||||
|    *              a mirror image of the first extruder.  The initial x-offset and temperature differential are | ||||
|    *              set with M605 S2 [Xnnn] [Rmmm] and then followed with a M605 S3 to start the mirrored movement. | ||||
|    *    M605 W  : IDEX What? command. | ||||
|    * | ||||
|    *    Note: the X axis should be homed after changing dual x-carriage mode. | ||||
|    */ | ||||
|   void GcodeSuite::M605() { | ||||
|     planner.synchronize(); | ||||
|     if (parser.seen('S')) dual_x_carriage_mode = (DualXMode)parser.value_byte(); | ||||
|  | ||||
|     if (parser.seen('S')) {  | ||||
|       DualXMode  previous_mode, requested_mode = (DualXMode)parser.value_byte(); | ||||
|       previous_mode = dual_x_carriage_mode; | ||||
|       dual_x_carriage_mode = (DualXMode)parser.value_byte(); | ||||
|  | ||||
|     switch (dual_x_carriage_mode) { | ||||
|       case DXC_FULL_CONTROL_MODE: | ||||
|       case DXC_AUTO_PARK_MODE: | ||||
| @@ -52,16 +65,7 @@ | ||||
|       case DXC_DUPLICATION_MODE: | ||||
|         if (parser.seen('X')) duplicate_extruder_x_offset = MAX(parser.value_linear_units(), X2_MIN_POS - x_home_pos(0)); | ||||
|         if (parser.seen('R')) duplicate_extruder_temp_offset = parser.value_celsius_diff(); | ||||
|         SERIAL_ECHO_START(); | ||||
|         SERIAL_ECHOPGM(MSG_HOTEND_OFFSET); | ||||
|         SERIAL_CHAR(' '); | ||||
|         SERIAL_ECHO(hotend_offset[X_AXIS][0]); | ||||
|         SERIAL_CHAR(','); | ||||
|         SERIAL_ECHO(hotend_offset[Y_AXIS][0]); | ||||
|         SERIAL_CHAR(' '); | ||||
|         SERIAL_ECHO(duplicate_extruder_x_offset); | ||||
|         SERIAL_CHAR(','); | ||||
|         SERIAL_ECHOLN(hotend_offset[Y_AXIS][1]); | ||||
|           if (active_extruder != 0) tool_change(0); | ||||
|         break; | ||||
|       default: | ||||
|         dual_x_carriage_mode = DEFAULT_DUAL_X_CARRIAGE_MODE; | ||||
| @@ -70,6 +74,55 @@ | ||||
|     active_extruder_parked = false; | ||||
|     extruder_duplication_enabled = false; | ||||
|     delayed_move_time = 0; | ||||
|     } else | ||||
|       if (!parser.seen('W'))  // if no S or W parameter, the DXC mode gets reset to the user's default  | ||||
|         dual_x_carriage_mode = DEFAULT_DUAL_X_CARRIAGE_MODE; | ||||
|  | ||||
|     if (parser.seen('W')) { | ||||
|       SERIAL_ECHO_START(); | ||||
|       SERIAL_ECHOPGM("IDEX mode: "); | ||||
|       switch (dual_x_carriage_mode) { | ||||
|         case DXC_FULL_CONTROL_MODE: | ||||
|           SERIAL_ECHOPGM("DXC_FULL_CONTROL_MODE\n"); | ||||
|           break; | ||||
|         case DXC_AUTO_PARK_MODE: | ||||
|           SERIAL_ECHOPGM("DXC_AUTO_PARK_MODE\n"); | ||||
|           break; | ||||
|         case DXC_DUPLICATION_MODE: | ||||
|           SERIAL_ECHOPGM("DXC_DUPLICATION_MODE\n"); | ||||
|           break; | ||||
|       } | ||||
|       SERIAL_ECHOPGM("Active Ext: "); | ||||
|       SERIAL_ECHO((int) active_extruder); | ||||
|  | ||||
|       if (active_extruder_parked == false) | ||||
|         SERIAL_ECHOPGM(" NOT "); | ||||
|       SERIAL_ECHOPGM(" parked.\n"); | ||||
|  | ||||
|       SERIAL_ECHOPGM("active_extruder_x_pos: "); | ||||
|       SERIAL_ECHO( current_position[X_AXIS]); | ||||
|  | ||||
|       SERIAL_ECHOPGM("   inactive_extruder_x_pos: "); | ||||
|       SERIAL_ECHO( inactive_extruder_x_pos); | ||||
|  | ||||
|       SERIAL_ECHOPGM("\n1st extruder x_home_pos(): "); | ||||
|       SERIAL_ECHO(x_home_pos(0)); | ||||
|       SERIAL_ECHOPGM("\n2nd extruder x_home_pos(): "); | ||||
|       SERIAL_ECHO(x_home_pos(1)); | ||||
|  | ||||
|       SERIAL_ECHOPGM("\nextruder_duplication_enabled: "); | ||||
|       SERIAL_ECHO(extruder_duplication_enabled); | ||||
|  | ||||
|       SERIAL_ECHOPGM("\nduplicate_extruder_x_offset: "); | ||||
|       SERIAL_ECHO(duplicate_extruder_x_offset); | ||||
|  | ||||
|       SERIAL_ECHOPGM("\nduplicate_extruder_temp_offset: "); | ||||
|       SERIAL_ECHO(duplicate_extruder_temp_offset); | ||||
|  | ||||
|       SERIAL_ECHOPGM("\ndelayed_move_time: "); | ||||
|       SERIAL_ECHO(delayed_move_time); | ||||
|       SERIAL_ECHOPGM("\n");  | ||||
|     } | ||||
|   } | ||||
|  | ||||
| #elif ENABLED(DUAL_NOZZLE_DUPLICATION_MODE) | ||||
|   | ||||
| @@ -138,6 +138,17 @@ inline bool _enqueuecommand(const char* cmd, bool say_ok=false | ||||
|  * Enqueue with Serial Echo | ||||
|  */ | ||||
| bool enqueue_and_echo_command(const char* cmd) { | ||||
|  | ||||
| //SERIAL_ECHO("enqueue_and_echo_command(\""); | ||||
| //SERIAL_ECHO(cmd); | ||||
| //SERIAL_ECHO("\") \n"); | ||||
| // | ||||
|   if ( *cmd == 0 || *cmd == '\n' || *cmd == 'r') | ||||
| //{ | ||||
| //SERIAL_ECHO("Null command found...   Did not queue!\n"); | ||||
|     return true; | ||||
| //} | ||||
|  | ||||
|   if (_enqueuecommand(cmd)) { | ||||
|     SERIAL_ECHO_START(); | ||||
|     SERIAL_ECHOPAIR(MSG_ENQUEUEING, cmd); | ||||
| @@ -155,7 +166,7 @@ bool enqueue_and_echo_command(const char* cmd) { | ||||
| static bool drain_injected_commands_P() { | ||||
|   if (injected_commands_P != NULL) { | ||||
|     size_t i = 0; | ||||
|     char c, cmd[30]; | ||||
|     char c, cmd[60]; | ||||
|     strncpy_P(cmd, injected_commands_P, sizeof(cmd) - 1); | ||||
|     cmd[sizeof(cmd) - 1] = '\0'; | ||||
|     while ((c = cmd[i]) && c != '\n') i++; // find the end of this gcode command | ||||
|   | ||||
		Reference in New Issue
	
	Block a user