mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-31 04:31:15 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			92 lines
		
	
	
	
		
			3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
	
		
			3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #ifndef slic3r_Extruder_hpp_
 | |
| #define slic3r_Extruder_hpp_
 | |
| 
 | |
| #include "libslic3r.h"
 | |
| #include "Point.hpp"
 | |
| 
 | |
| namespace Slic3r {
 | |
| 
 | |
| class GCodeConfig;
 | |
| 
 | |
| class Extruder
 | |
| {
 | |
| public:
 | |
|     Extruder(unsigned int id, GCodeConfig *config, bool share_extruder);
 | |
|     virtual ~Extruder() {}
 | |
| 
 | |
|     void   reset() {
 | |
|         // BBS
 | |
|         if (m_share_extruder) {
 | |
|             m_share_E = 0.;
 | |
|             m_share_retracted = 0.;
 | |
|         } else {
 | |
|             m_E             = 0;
 | |
|             m_retracted     = 0;
 | |
|             m_restart_extra = 0;
 | |
|         }
 | |
| 
 | |
|         m_absolute_E    = 0;
 | |
|     }
 | |
| 
 | |
|     unsigned int id() const { return m_id; }
 | |
| 
 | |
|     double extrude(double dE);
 | |
|     double retract(double length, double restart_extra);
 | |
|     double unretract();
 | |
|     double E() const { return m_share_extruder ? m_share_E : m_E; }
 | |
|     void   reset_E() { m_E = 0.; }
 | |
|     double e_per_mm(double mm3_per_mm) const { return mm3_per_mm * m_e_per_mm3; }
 | |
|     double e_per_mm3() const { return m_e_per_mm3; }
 | |
|     // Used filament volume in mm^3.
 | |
|     double extruded_volume() const;
 | |
|     // Used filament length in mm.
 | |
|     double used_filament() const;
 | |
|     
 | |
|     double filament_diameter() const;
 | |
|     double filament_crossection() const { return this->filament_diameter() * this->filament_diameter() * 0.25 * PI; }
 | |
|     double filament_density() const;
 | |
|     double filament_cost() const;
 | |
|     double filament_flow_ratio() const;
 | |
|     double retract_before_wipe() const;
 | |
|     double retraction_length() const;
 | |
|     double retract_lift() const;
 | |
|     int    retract_speed() const;
 | |
|     int    deretract_speed() const;
 | |
|     double retract_restart_extra() const;
 | |
|     double retract_length_toolchange() const;
 | |
|     double retract_restart_extra_toolchange() const;
 | |
| 
 | |
| private:
 | |
|     // Private constructor to create a key for a search in std::set.
 | |
|     Extruder(unsigned int id) : m_id(id) {}
 | |
| 
 | |
|     // Reference to GCodeWriter instance owned by GCodeWriter.
 | |
|     GCodeConfig *m_config;
 | |
|     // Print-wide global ID of this extruder.
 | |
|     unsigned int m_id;
 | |
|     // Current state of the extruder axis, may be resetted if relative_e_axis.
 | |
|     double       m_E;
 | |
|     // Current state of the extruder tachometer, used to output the extruded_volume() and used_filament() statistics.
 | |
|     double       m_absolute_E;
 | |
|     // Current positive amount of retraction.
 | |
|     double       m_retracted;
 | |
|     // When retracted, this value stores the extra amount of priming on deretraction.
 | |
|     double       m_restart_extra;
 | |
|     double       m_e_per_mm3;
 | |
| 
 | |
|     // BBS.
 | |
|     // Create shared E and retraction data for single extruder multi-material machine
 | |
|     bool          m_share_extruder;
 | |
|     static double m_share_E;
 | |
|     static double m_share_retracted;
 | |
| };
 | |
| 
 | |
| // Sort Extruder objects by the extruder id by default.
 | |
| inline bool operator==(const Extruder &e1, const Extruder &e2) { return e1.id() == e2.id(); }
 | |
| inline bool operator!=(const Extruder &e1, const Extruder &e2) { return e1.id() != e2.id(); }
 | |
| inline bool operator< (const Extruder &e1, const Extruder &e2) { return e1.id() < e2.id(); }
 | |
| inline bool operator> (const Extruder &e1, const Extruder &e2) { return e1.id() > e2.id(); }
 | |
| 
 | |
| }
 | |
| 
 | |
| #endif
 | 
