🐛 Fix Air Assist (#22159)
Co-authored-by: Scott Lahteine <thinkyhead@users.noreply.github.com>
This commit is contained in:
		
				
					committed by
					
						 Scott Lahteine
						Scott Lahteine
					
				
			
			
				
	
			
			
			
						parent
						
							f22c5d3cc6
						
					
				
				
					commit
					3ecc99e95d
				
			| @@ -20,9 +20,9 @@ | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| #include "../../inc/MarlinConfig.h" | ||||
| #include "../../inc/MarlinConfigPre.h" | ||||
|  | ||||
| #if ENABLED(COOLANT_CONTROL) | ||||
| #if ANY(COOLANT_MIST, COOLANT_FLOOD, AIR_ASSIST) | ||||
|  | ||||
| #include "../gcode.h" | ||||
| #include "../../module/planner.h" | ||||
| @@ -37,51 +37,41 @@ | ||||
|   } | ||||
| #endif | ||||
|  | ||||
| #if ENABLED(COOLANT_FLOOD) | ||||
| #if EITHER(COOLANT_FLOOD, AIR_ASSIST) | ||||
|  | ||||
|   #if ENABLED(AIR_ASSIST) | ||||
|     #include "../../feature/spindle_laser.h" | ||||
|   #endif | ||||
|  | ||||
|   /** | ||||
|    * M8: Flood Coolant On | ||||
|    * M8: Flood Coolant / Air Assist ON | ||||
|    */ | ||||
|   void GcodeSuite::M8() { | ||||
|     planner.synchronize();                              // Wait for move to arrive | ||||
|     WRITE(COOLANT_FLOOD_PIN, !(COOLANT_FLOOD_INVERT));  // Turn on Flood coolant | ||||
|     planner.synchronize();                            // Wait for move to arrive | ||||
|     #if ENABLED(COOLANT_FLOOD) | ||||
|       WRITE(COOLANT_FLOOD_PIN, !(COOLANT_FLOOD_INVERT)); // Turn on Flood coolant | ||||
|     #endif | ||||
|     #if ENABLED(AIR_ASSIST) | ||||
|       cutter.air_assist_enable();                     // Turn on Air Assist | ||||
|     #endif | ||||
|   } | ||||
|  | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * M9: Coolant OFF | ||||
|  * M9: Coolant / Air Assist OFF | ||||
|  */ | ||||
| void GcodeSuite::M9() { | ||||
|   planner.synchronize();                            // Wait for move to arrive | ||||
|   planner.synchronize();                              // Wait for move to arrive | ||||
|   #if ENABLED(COOLANT_MIST) | ||||
|     WRITE(COOLANT_MIST_PIN, COOLANT_MIST_INVERT);   // Turn off Mist coolant | ||||
|     WRITE(COOLANT_MIST_PIN, COOLANT_MIST_INVERT);     // Turn off Mist coolant | ||||
|   #endif | ||||
|   #if ENABLED(COOLANT_FLOOD) | ||||
|     WRITE(COOLANT_FLOOD_PIN, COOLANT_FLOOD_INVERT); // Turn off Flood coolant | ||||
|     WRITE(COOLANT_FLOOD_PIN, COOLANT_FLOOD_INVERT);   // Turn off Flood coolant | ||||
|   #endif | ||||
|   #if ENABLED(AIR_ASSIST) | ||||
|     cutter.air_assist_disable();                      // Turn off Air Assist | ||||
|   #endif | ||||
| } | ||||
|  | ||||
| #endif // COOLANT_CONTROL | ||||
|  | ||||
| #if ENABLED(AIR_ASSIST) | ||||
|  | ||||
| #include "../gcode.h" | ||||
| #include "../../module/planner.h" | ||||
| #include "../../feature/spindle_laser.h" | ||||
|  | ||||
| /** | ||||
|  * M8: Air Assist On | ||||
|  */ | ||||
| void GcodeSuite::M8() { | ||||
|   planner.synchronize(); | ||||
|   cutter.air_assist_enable();   // Turn on Air Assist pin | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * M9: Air Assist Off | ||||
|  */ | ||||
| void GcodeSuite::M9() { | ||||
|   planner.synchronize(); | ||||
|   cutter.air_assist_disable();  // Turn off Air Assist pin | ||||
| } | ||||
|  | ||||
| #endif // AIR_ASSIST | ||||
| #endif // COOLANT_MIST | COOLANT_FLOOD | AIR_ASSIST | ||||
|   | ||||
| @@ -441,20 +441,23 @@ void GcodeSuite::process_parsed_command(const bool no_ok/*=false*/) { | ||||
|         case 3: M3_M4(false); break;                              // M3: Turn ON Laser | Spindle (clockwise), set Power | Speed | ||||
|         case 4: M3_M4(true ); break;                              // M4: Turn ON Laser | Spindle (counter-clockwise), set Power | Speed | ||||
|         case 5: M5(); break;                                      // M5: Turn OFF Laser | Spindle | ||||
|         #if ENABLED(AIR_EVACUATION) | ||||
|           case 10: M10(); break;                                  // M10: Vacuum or Blower motor ON | ||||
|           case 11: M11(); break;                                  // M11: Vacuum or Blower motor OFF | ||||
|         #endif | ||||
|       #endif | ||||
|  | ||||
|       #if ENABLED(COOLANT_CONTROL) | ||||
|         #if ENABLED(COOLANT_MIST) | ||||
|           case 7: M7(); break;                                    // M7: Mist coolant ON | ||||
|         #endif | ||||
|         #if ENABLED(COOLANT_FLOOD) | ||||
|           case 8: M8(); break;                                    // M8: Flood coolant ON | ||||
|         #endif | ||||
|         case 9: M9(); break;                                      // M9: Coolant OFF | ||||
|       #if ENABLED(COOLANT_MIST) | ||||
|         case 7: M7(); break;                                      // M7: Coolant Mist ON | ||||
|       #endif | ||||
|  | ||||
|       #if EITHER(AIR_ASSIST, COOLANT_FLOOD) | ||||
|         case 8: M8(); break;                                      // M8: Air Assist / Coolant Flood ON | ||||
|       #endif | ||||
|  | ||||
|       #if EITHER(AIR_ASSIST, COOLANT_CONTROL) | ||||
|         case 9: M9(); break;                                      // M9: Air Assist / Coolant OFF | ||||
|       #endif | ||||
|  | ||||
|       #if ENABLED(AIR_EVACUATION) | ||||
|         case 10: M10(); break;                                    // M10: Vacuum or Blower motor ON | ||||
|         case 11: M11(); break;                                    // M11: Vacuum or Blower motor OFF | ||||
|       #endif | ||||
|  | ||||
|       #if ENABLED(EXTERNAL_CLOSED_LOOP_CONTROLLER) | ||||
|   | ||||
| @@ -564,22 +564,25 @@ private: | ||||
|   #if HAS_CUTTER | ||||
|     static void M3_M4(const bool is_M4); | ||||
|     static void M5(); | ||||
|     #if ENABLED(AIR_EVACUATION) | ||||
|       static void M10(); | ||||
|       static void M11(); | ||||
|     #endif | ||||
|   #endif | ||||
|  | ||||
|   #if ENABLED(COOLANT_CONTROL) | ||||
|     #if ENABLED(COOLANT_MIST) | ||||
|       static void M7(); | ||||
|     #endif | ||||
|     #if ENABLED(COOLANT_FLOOD) | ||||
|       static void M8(); | ||||
|     #endif | ||||
|   #if ENABLED(COOLANT_MIST) | ||||
|     static void M7(); | ||||
|   #endif | ||||
|  | ||||
|   #if EITHER(AIR_ASSIST, COOLANT_FLOOD) | ||||
|     static void M8(); | ||||
|   #endif | ||||
|  | ||||
|   #if EITHER(AIR_ASSIST, COOLANT_CONTROL) | ||||
|     static void M9(); | ||||
|   #endif | ||||
|  | ||||
|   #if ENABLED(AIR_EVACUATION) | ||||
|     static void M10(); | ||||
|     static void M11(); | ||||
|   #endif | ||||
|  | ||||
|   #if ENABLED(EXTERNAL_CLOSED_LOOP_CONTROLLER) | ||||
|     static void M12(); | ||||
|   #endif | ||||
|   | ||||
		Reference in New Issue
	
	Block a user