mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 02:01:12 -06:00 
			
		
		
		
	Fix of #2825 - Add the length of each filament used
This commit is contained in:
		
							parent
							
								
									56aa45fa1f
								
							
						
					
					
						commit
						b9910669e8
					
				
					 9 changed files with 463 additions and 164 deletions
				
			
		|  | @ -36,7 +36,7 @@ namespace Slic3r { | |||
|         Count | ||||
|     }; | ||||
| 
 | ||||
|     struct PrintEstimatedTimeStatistics | ||||
|     struct PrintEstimatedStatistics | ||||
|     { | ||||
|         enum class ETimeMode : unsigned char | ||||
|         { | ||||
|  | @ -62,14 +62,21 @@ namespace Slic3r { | |||
|             } | ||||
|         }; | ||||
| 
 | ||||
|         std::vector<double>                                 volumes_per_color_change; | ||||
|         std::map<size_t, double>                            volumes_per_extruder; | ||||
|         std::map<ExtrusionRole, std::pair<double, double>>  used_filaments_per_role; | ||||
| 
 | ||||
|         std::array<Mode, static_cast<size_t>(ETimeMode::Count)> modes; | ||||
| 
 | ||||
|         PrintEstimatedTimeStatistics() { reset(); } | ||||
|         PrintEstimatedStatistics() { reset(); } | ||||
| 
 | ||||
|         void reset() { | ||||
|             for (auto m : modes) { | ||||
|                 m.reset(); | ||||
|             } | ||||
|             volumes_per_color_change.clear(); | ||||
|             volumes_per_extruder.clear(); | ||||
|             used_filaments_per_role.clear(); | ||||
|         } | ||||
|     }; | ||||
| 
 | ||||
|  | @ -314,7 +321,7 @@ namespace Slic3r { | |||
|             // Additional load / unload times for a filament exchange sequence.
 | ||||
|             std::vector<float> filament_load_times; | ||||
|             std::vector<float> filament_unload_times; | ||||
|             std::array<TimeMachine, static_cast<size_t>(PrintEstimatedTimeStatistics::ETimeMode::Count)> machines; | ||||
|             std::array<TimeMachine, static_cast<size_t>(PrintEstimatedStatistics::ETimeMode::Count)> machines; | ||||
| 
 | ||||
|             void reset(); | ||||
| 
 | ||||
|  | @ -327,6 +334,30 @@ namespace Slic3r { | |||
| #endif // ENABLE_GCODE_LINES_ID_IN_H_SLIDER
 | ||||
|         }; | ||||
| 
 | ||||
|         struct UsedFilaments  // filaments per ColorChange
 | ||||
|         { | ||||
|             double color_change_cache; | ||||
|             std::vector<double> volumes_per_color_change; | ||||
| 
 | ||||
|             double tool_change_cache; | ||||
|             std::map<size_t, double> volumes_per_extruder; | ||||
| 
 | ||||
|             double role_cache; | ||||
|             //       ExtrusionRole : <used_filament_m, used_filament_g>
 | ||||
|             std::map<ExtrusionRole, std::pair<double, double>> filaments_per_role; | ||||
| 
 | ||||
|             void reset(); | ||||
| 
 | ||||
|             void increase_caches(double extruded_volume); | ||||
| 
 | ||||
|             void process_color_change_cache(); | ||||
|             void process_extruder_cache(GCodeProcessor* processor); | ||||
|             void process_role_cache(GCodeProcessor* processor); | ||||
|             void process_caches(GCodeProcessor* processor); | ||||
| 
 | ||||
|             friend class GCodeProcessor; | ||||
|         }; | ||||
| 
 | ||||
|     public: | ||||
| #if !ENABLE_GCODE_LINES_ID_IN_H_SLIDER | ||||
|         struct MoveVertex | ||||
|  | @ -372,7 +403,7 @@ namespace Slic3r { | |||
|             SettingsIds settings_ids; | ||||
|             size_t extruders_count; | ||||
|             std::vector<std::string> extruder_colors; | ||||
|             PrintEstimatedTimeStatistics time_statistics; | ||||
|             PrintEstimatedStatistics print_statistics; | ||||
| 
 | ||||
| #if ENABLE_GCODE_VIEWER_STATISTICS | ||||
|             int64_t time{ 0 }; | ||||
|  | @ -519,6 +550,7 @@ namespace Slic3r { | |||
|         ExtruderColors m_extruder_colors; | ||||
|         ExtruderTemps m_extruder_temps; | ||||
|         std::vector<float> m_filament_diameters; | ||||
|         std::vector<float> m_filament_densities; | ||||
|         float m_extruded_last_z; | ||||
| #if ENABLE_START_GCODE_VISUALIZATION | ||||
|         float m_first_layer_height; // mm
 | ||||
|  | @ -550,6 +582,7 @@ namespace Slic3r { | |||
|         bool m_producers_enabled; | ||||
| 
 | ||||
|         TimeProcessor m_time_processor; | ||||
|         UsedFilaments m_used_filaments; | ||||
| 
 | ||||
|         Result m_result; | ||||
|         static unsigned int s_result_id; | ||||
|  | @ -566,7 +599,7 @@ namespace Slic3r { | |||
|         void apply_config(const PrintConfig& config); | ||||
|         void enable_stealth_time_estimator(bool enabled); | ||||
|         bool is_stealth_time_estimator_enabled() const { | ||||
|             return m_time_processor.machines[static_cast<size_t>(PrintEstimatedTimeStatistics::ETimeMode::Stealth)].enabled; | ||||
|             return m_time_processor.machines[static_cast<size_t>(PrintEstimatedStatistics::ETimeMode::Stealth)].enabled; | ||||
|         } | ||||
|         void enable_machine_envelope_processing(bool enabled) { m_time_processor.machine_envelope_processing_enabled = enabled; } | ||||
|         void enable_producers(bool enabled) { m_producers_enabled = enabled; } | ||||
|  | @ -579,13 +612,13 @@ namespace Slic3r { | |||
|         // throws CanceledException through print->throw_if_canceled() (sent by the caller as callback).
 | ||||
|         void process_file(const std::string& filename, bool apply_postprocess, std::function<void()> cancel_callback = nullptr); | ||||
| 
 | ||||
|         float get_time(PrintEstimatedTimeStatistics::ETimeMode mode) const; | ||||
|         std::string get_time_dhm(PrintEstimatedTimeStatistics::ETimeMode mode) const; | ||||
|         std::vector<std::pair<CustomGCode::Type, std::pair<float, float>>> get_custom_gcode_times(PrintEstimatedTimeStatistics::ETimeMode mode, bool include_remaining) const; | ||||
|         float get_time(PrintEstimatedStatistics::ETimeMode mode) const; | ||||
|         std::string get_time_dhm(PrintEstimatedStatistics::ETimeMode mode) const; | ||||
|         std::vector<std::pair<CustomGCode::Type, std::pair<float, float>>> get_custom_gcode_times(PrintEstimatedStatistics::ETimeMode mode, bool include_remaining) const; | ||||
| 
 | ||||
|         std::vector<std::pair<EMoveType, float>> get_moves_time(PrintEstimatedTimeStatistics::ETimeMode mode) const; | ||||
|         std::vector<std::pair<ExtrusionRole, float>> get_roles_time(PrintEstimatedTimeStatistics::ETimeMode mode) const; | ||||
|         std::vector<float> get_layers_time(PrintEstimatedTimeStatistics::ETimeMode mode) const; | ||||
|         std::vector<std::pair<EMoveType, float>> get_moves_time(PrintEstimatedStatistics::ETimeMode mode) const; | ||||
|         std::vector<std::pair<ExtrusionRole, float>> get_roles_time(PrintEstimatedStatistics::ETimeMode mode) const; | ||||
|         std::vector<float> get_layers_time(PrintEstimatedStatistics::ETimeMode mode) const; | ||||
| 
 | ||||
|     private: | ||||
|         void apply_config(const DynamicPrintConfig& config); | ||||
|  | @ -701,20 +734,21 @@ namespace Slic3r { | |||
| 
 | ||||
|         void store_move_vertex(EMoveType type); | ||||
| 
 | ||||
|         float minimum_feedrate(PrintEstimatedTimeStatistics::ETimeMode mode, float feedrate) const; | ||||
|         float minimum_travel_feedrate(PrintEstimatedTimeStatistics::ETimeMode mode, float feedrate) const; | ||||
|         float get_axis_max_feedrate(PrintEstimatedTimeStatistics::ETimeMode mode, Axis axis) const; | ||||
|         float get_axis_max_acceleration(PrintEstimatedTimeStatistics::ETimeMode mode, Axis axis) const; | ||||
|         float get_axis_max_jerk(PrintEstimatedTimeStatistics::ETimeMode mode, Axis axis) const; | ||||
|         float get_retract_acceleration(PrintEstimatedTimeStatistics::ETimeMode mode) const; | ||||
|         float get_acceleration(PrintEstimatedTimeStatistics::ETimeMode mode) const; | ||||
|         void  set_acceleration(PrintEstimatedTimeStatistics::ETimeMode mode, float value); | ||||
|         float get_travel_acceleration(PrintEstimatedTimeStatistics::ETimeMode mode) const; | ||||
|         void  set_travel_acceleration(PrintEstimatedTimeStatistics::ETimeMode mode, float value); | ||||
|         float minimum_feedrate(PrintEstimatedStatistics::ETimeMode mode, float feedrate) const; | ||||
|         float minimum_travel_feedrate(PrintEstimatedStatistics::ETimeMode mode, float feedrate) const; | ||||
|         float get_axis_max_feedrate(PrintEstimatedStatistics::ETimeMode mode, Axis axis) const; | ||||
|         float get_axis_max_acceleration(PrintEstimatedStatistics::ETimeMode mode, Axis axis) const; | ||||
|         float get_axis_max_jerk(PrintEstimatedStatistics::ETimeMode mode, Axis axis) const; | ||||
|         float get_retract_acceleration(PrintEstimatedStatistics::ETimeMode mode) const; | ||||
|         float get_acceleration(PrintEstimatedStatistics::ETimeMode mode) const; | ||||
|         void  set_acceleration(PrintEstimatedStatistics::ETimeMode mode, float value); | ||||
|         float get_travel_acceleration(PrintEstimatedStatistics::ETimeMode mode) const; | ||||
|         void  set_travel_acceleration(PrintEstimatedStatistics::ETimeMode mode, float value); | ||||
|         float get_filament_load_time(size_t extruder_id); | ||||
|         float get_filament_unload_time(size_t extruder_id); | ||||
| 
 | ||||
|         void process_custom_gcode_time(CustomGCode::Type code); | ||||
|         void process_filaments(CustomGCode::Type code); | ||||
| 
 | ||||
|         // Simulates firmware st_synchronize() call
 | ||||
|         void simulate_st_synchronize(float additional_time = 0.0f); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 YuSanka
						YuSanka