Option to disable all volumetric extrusion
This commit is contained in:
		| @@ -159,11 +159,14 @@ class Planner { | ||||
|  | ||||
|     static int16_t flow_percentage[EXTRUDERS];      // Extrusion factor for each extruder | ||||
|  | ||||
|     static float e_factor[EXTRUDERS],               // The flow percentage and volumetric multiplier combine to scale E movement | ||||
|                  filament_size[EXTRUDERS],          // diameter of filament (in millimeters), typically around 1.75 or 2.85, 0 disables the volumetric calculations for the extruder | ||||
|                  volumetric_area_nominal,           // Nominal cross-sectional area | ||||
|                  volumetric_multiplier[EXTRUDERS];  // Reciprocal of cross-sectional area of filament (in mm^2). Pre-calculated to reduce computation in the planner | ||||
|                                                     // May be auto-adjusted by a filament width sensor | ||||
|     static float e_factor[EXTRUDERS];               // The flow percentage and volumetric multiplier combine to scale E movement | ||||
|  | ||||
|     #if DISABLED(NO_VOLUMETRICS) | ||||
|       static float filament_size[EXTRUDERS],          // diameter of filament (in millimeters), typically around 1.75 or 2.85, 0 disables the volumetric calculations for the extruder | ||||
|                    volumetric_area_nominal,           // Nominal cross-sectional area | ||||
|                    volumetric_multiplier[EXTRUDERS];  // Reciprocal of cross-sectional area of filament (in mm^2). Pre-calculated to reduce computation in the planner | ||||
|                                                       // May be auto-adjusted by a filament width sensor | ||||
|     #endif | ||||
|  | ||||
|     static float max_feedrate_mm_s[XYZE_N],         // Max speeds in mm per second | ||||
|                  axis_steps_per_mm[XYZE_N], | ||||
| @@ -277,7 +280,11 @@ class Planner { | ||||
|     static void refresh_positioning(); | ||||
|  | ||||
|     FORCE_INLINE static void refresh_e_factor(const uint8_t e) { | ||||
|       e_factor[e] = volumetric_multiplier[e] * flow_percentage[e] * 0.01; | ||||
|       e_factor[e] = (flow_percentage[e] * 0.01 | ||||
|         #if DISABLED(NO_VOLUMETRICS) | ||||
|           * volumetric_multiplier[e] | ||||
|         #endif | ||||
|       ); | ||||
|     } | ||||
|  | ||||
|     // Manage fans, paste pressure, etc. | ||||
| @@ -297,12 +304,16 @@ class Planner { | ||||
|       void calculate_volumetric_for_width_sensor(const int8_t encoded_ratio); | ||||
|     #endif | ||||
|  | ||||
|     FORCE_INLINE static void set_filament_size(const uint8_t e, const float &v) { | ||||
|       filament_size[e] = v; | ||||
|       // make sure all extruders have some sane value for the filament size | ||||
|       for (uint8_t i = 0; i < COUNT(filament_size); i++) | ||||
|         if (!filament_size[i]) filament_size[i] = DEFAULT_NOMINAL_FILAMENT_DIA; | ||||
|     } | ||||
|     #if DISABLED(NO_VOLUMETRICS) | ||||
|  | ||||
|       FORCE_INLINE static void set_filament_size(const uint8_t e, const float &v) { | ||||
|         filament_size[e] = v; | ||||
|         // make sure all extruders have some sane value for the filament size | ||||
|         for (uint8_t i = 0; i < COUNT(filament_size); i++) | ||||
|           if (!filament_size[i]) filament_size[i] = DEFAULT_NOMINAL_FILAMENT_DIA; | ||||
|       } | ||||
|  | ||||
|     #endif | ||||
|  | ||||
|     #if ENABLED(ENABLE_LEVELING_FADE_HEIGHT) | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user