mirror of
				https://git.mirrors.martin98.com/https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-21 02:41:09 +08:00 
			
		
		
		
	Implemented configurable speed and acceleration settings for the first
object layer over raft interface: "first_layer_speed_over_raft", "first_layer_acceleration_over_raft". Fixes I have a question about the speed of the first layer after the raft. #6623 Fixes Layer After Raft Is Not Considered First Layer! #6166
This commit is contained in:
		
							parent
							
								
									ccf671dcc9
								
							
						
					
					
						commit
						b29c0ead7d
					
				| @ -1977,6 +1977,7 @@ void GCode::process_layer( | |||||||
|     } |     } | ||||||
|     gcode += this->change_layer(print_z);  // this will increase m_layer_index
 |     gcode += this->change_layer(print_z);  // this will increase m_layer_index
 | ||||||
|     m_layer = &layer; |     m_layer = &layer; | ||||||
|  |     m_object_layer_over_raft = false; | ||||||
|     if (! print.config().layer_gcode.value.empty()) { |     if (! print.config().layer_gcode.value.empty()) { | ||||||
|         DynamicConfig config; |         DynamicConfig config; | ||||||
|         config.set_key_value("layer_num", new ConfigOptionInt(m_layer_index)); |         config.set_key_value("layer_num", new ConfigOptionInt(m_layer_index)); | ||||||
| @ -2235,8 +2236,13 @@ void GCode::process_layer( | |||||||
|                 gcode+="; PURGING FINISHED\n"; |                 gcode+="; PURGING FINISHED\n"; | ||||||
| 
 | 
 | ||||||
|             for (InstanceToPrint &instance_to_print : instances_to_print) { |             for (InstanceToPrint &instance_to_print : instances_to_print) { | ||||||
|  |                 const LayerToPrint &layer_to_print = layers[instance_to_print.layer_id]; | ||||||
|  |                 // To control print speed of the 1st object layer printed over raft interface.
 | ||||||
|  |                 bool object_layer_over_raft = layer_to_print.object_layer && layer_to_print.object_layer->id() > 0 &&  | ||||||
|  |                     instance_to_print.print_object.slicing_parameters().raft_layers() == layer_to_print.object_layer->id(); | ||||||
|                 m_config.apply(instance_to_print.print_object.config(), true); |                 m_config.apply(instance_to_print.print_object.config(), true); | ||||||
|                 m_layer = layers[instance_to_print.layer_id].layer(); |                 m_layer = layer_to_print.layer(); | ||||||
|  |                 m_object_layer_over_raft = object_layer_over_raft; | ||||||
|                 if (m_config.avoid_crossing_perimeters) |                 if (m_config.avoid_crossing_perimeters) | ||||||
|                     m_avoid_crossing_perimeters.init_layer(*m_layer); |                     m_avoid_crossing_perimeters.init_layer(*m_layer); | ||||||
|                 if (this->config().gcode_label_objects) |                 if (this->config().gcode_label_objects) | ||||||
| @ -2249,11 +2255,13 @@ void GCode::process_layer( | |||||||
|                 m_last_obj_copy = this_object_copy; |                 m_last_obj_copy = this_object_copy; | ||||||
|                 this->set_origin(unscale(offset)); |                 this->set_origin(unscale(offset)); | ||||||
|                 if (instance_to_print.object_by_extruder.support != nullptr && !print_wipe_extrusions) { |                 if (instance_to_print.object_by_extruder.support != nullptr && !print_wipe_extrusions) { | ||||||
|                     m_layer = layers[instance_to_print.layer_id].support_layer; |                     m_layer = layer_to_print.support_layer; | ||||||
|  |                     m_object_layer_over_raft = false; | ||||||
|                     gcode += this->extrude_support( |                     gcode += this->extrude_support( | ||||||
|                         // support_extrusion_role is erSupportMaterial, erSupportMaterialInterface or erMixed for all extrusion paths.
 |                         // support_extrusion_role is erSupportMaterial, erSupportMaterialInterface or erMixed for all extrusion paths.
 | ||||||
|                         instance_to_print.object_by_extruder.support->chained_path_from(m_last_pos, instance_to_print.object_by_extruder.support_extrusion_role)); |                         instance_to_print.object_by_extruder.support->chained_path_from(m_last_pos, instance_to_print.object_by_extruder.support_extrusion_role)); | ||||||
|                     m_layer = layers[instance_to_print.layer_id].layer(); |                     m_layer = layer_to_print.layer(); | ||||||
|  |                     m_object_layer_over_raft = object_layer_over_raft; | ||||||
|                 } |                 } | ||||||
|                 //FIXME order islands?
 |                 //FIXME order islands?
 | ||||||
|                 // Sequential tool path ordering of multiple parts within the same object, aka. perimeter tracking (#5511)
 |                 // Sequential tool path ordering of multiple parts within the same object, aka. perimeter tracking (#5511)
 | ||||||
| @ -2705,6 +2713,8 @@ std::string GCode::_extrude(const ExtrusionPath &path, std::string description, | |||||||
|         double acceleration; |         double acceleration; | ||||||
|         if (this->on_first_layer() && m_config.first_layer_acceleration.value > 0) { |         if (this->on_first_layer() && m_config.first_layer_acceleration.value > 0) { | ||||||
|             acceleration = m_config.first_layer_acceleration.value; |             acceleration = m_config.first_layer_acceleration.value; | ||||||
|  |         } else if (this->object_layer_over_raft() && m_config.first_layer_acceleration_over_raft.value > 0) { | ||||||
|  |             acceleration = m_config.first_layer_acceleration_over_raft.value; | ||||||
|         } else if (m_config.perimeter_acceleration.value > 0 && is_perimeter(path.role())) { |         } else if (m_config.perimeter_acceleration.value > 0 && is_perimeter(path.role())) { | ||||||
|             acceleration = m_config.perimeter_acceleration.value; |             acceleration = m_config.perimeter_acceleration.value; | ||||||
|         } else if (m_config.bridge_acceleration.value > 0 && is_bridge(path.role())) { |         } else if (m_config.bridge_acceleration.value > 0 && is_bridge(path.role())) { | ||||||
| @ -2749,6 +2759,8 @@ std::string GCode::_extrude(const ExtrusionPath &path, std::string description, | |||||||
|         speed = m_volumetric_speed / path.mm3_per_mm; |         speed = m_volumetric_speed / path.mm3_per_mm; | ||||||
|     if (this->on_first_layer()) |     if (this->on_first_layer()) | ||||||
|         speed = m_config.get_abs_value("first_layer_speed", speed); |         speed = m_config.get_abs_value("first_layer_speed", speed); | ||||||
|  |     else if (this->object_layer_over_raft()) | ||||||
|  |         speed = m_config.get_abs_value("first_layer_speed_over_raft", speed); | ||||||
|     if (m_config.max_volumetric_speed.value > 0) { |     if (m_config.max_volumetric_speed.value > 0) { | ||||||
|         // cap speed with max_volumetric_speed anyway (even if user is not using autospeed)
 |         // cap speed with max_volumetric_speed anyway (even if user is not using autospeed)
 | ||||||
|         speed = std::min( |         speed = std::min( | ||||||
|  | |||||||
| @ -126,6 +126,7 @@ public: | |||||||
|         m_layer_count(0), |         m_layer_count(0), | ||||||
|         m_layer_index(-1),  |         m_layer_index(-1),  | ||||||
|         m_layer(nullptr), |         m_layer(nullptr), | ||||||
|  |         m_object_layer_over_raft(false), | ||||||
|         m_volumetric_speed(0), |         m_volumetric_speed(0), | ||||||
|         m_last_pos_defined(false), |         m_last_pos_defined(false), | ||||||
|         m_last_extrusion_role(erNone), |         m_last_extrusion_role(erNone), | ||||||
| @ -138,7 +139,7 @@ public: | |||||||
|         m_silent_time_estimator_enabled(false), |         m_silent_time_estimator_enabled(false), | ||||||
|         m_last_obj_copy(nullptr, Point(std::numeric_limits<coord_t>::max(), std::numeric_limits<coord_t>::max())) |         m_last_obj_copy(nullptr, Point(std::numeric_limits<coord_t>::max(), std::numeric_limits<coord_t>::max())) | ||||||
|         {} |         {} | ||||||
|     ~GCode() {} |     ~GCode() = default; | ||||||
| 
 | 
 | ||||||
|     // throws std::runtime_exception on error,
 |     // throws std::runtime_exception on error,
 | ||||||
|     // throws CanceledException through print->throw_if_canceled().
 |     // throws CanceledException through print->throw_if_canceled().
 | ||||||
| @ -316,9 +317,11 @@ private: | |||||||
|     unsigned int                        m_layer_count; |     unsigned int                        m_layer_count; | ||||||
|     // Progress bar indicator. Increments from -1 up to layer_count.
 |     // Progress bar indicator. Increments from -1 up to layer_count.
 | ||||||
|     int                                 m_layer_index; |     int                                 m_layer_index; | ||||||
|     // Current layer processed. Insequential printing mode, only a single copy will be printed.
 |     // Current layer processed. In sequential printing mode, only a single copy will be printed.
 | ||||||
|     // In non-sequential mode, all its copies will be printed.
 |     // In non-sequential mode, all its copies will be printed.
 | ||||||
|     const Layer*                        m_layer; |     const Layer*                        m_layer; | ||||||
|  |     // m_layer is an object layer and it is being printed over raft surface.
 | ||||||
|  |     bool                                m_object_layer_over_raft; | ||||||
|     double                              m_volumetric_speed; |     double                              m_volumetric_speed; | ||||||
|     // Support for the extrusion role markers. Which marker is active?
 |     // Support for the extrusion role markers. Which marker is active?
 | ||||||
|     ExtrusionRole                       m_last_extrusion_role; |     ExtrusionRole                       m_last_extrusion_role; | ||||||
| @ -373,6 +376,8 @@ private: | |||||||
|     void _print_first_layer_extruder_temperatures(FILE *file, Print &print, const std::string &gcode, unsigned int first_printing_extruder_id, bool wait); |     void _print_first_layer_extruder_temperatures(FILE *file, Print &print, const std::string &gcode, unsigned int first_printing_extruder_id, bool wait); | ||||||
|     // On the first printing layer. This flag triggers first layer speeds.
 |     // On the first printing layer. This flag triggers first layer speeds.
 | ||||||
|     bool                                on_first_layer() const { return m_layer != nullptr && m_layer->id() == 0; } |     bool                                on_first_layer() const { return m_layer != nullptr && m_layer->id() == 0; } | ||||||
|  |     // To control print speed of 1st object layer over raft interface.
 | ||||||
|  |     bool                                object_layer_over_raft() const { return m_object_layer_over_raft; } | ||||||
| 
 | 
 | ||||||
|     friend ObjectByExtruder& object_by_extruder( |     friend ObjectByExtruder& object_by_extruder( | ||||||
|         std::map<unsigned int, std::vector<ObjectByExtruder>> &by_extruder,  |         std::map<unsigned int, std::vector<ObjectByExtruder>> &by_extruder,  | ||||||
|  | |||||||
| @ -428,8 +428,8 @@ static std::vector<std::string> s_Preset_print_options { | |||||||
| #endif /* HAS_PRESSURE_EQUALIZER */ | #endif /* HAS_PRESSURE_EQUALIZER */ | ||||||
|     "perimeter_speed", "small_perimeter_speed", "external_perimeter_speed", "infill_speed", "solid_infill_speed", |     "perimeter_speed", "small_perimeter_speed", "external_perimeter_speed", "infill_speed", "solid_infill_speed", | ||||||
|     "top_solid_infill_speed", "support_material_speed", "support_material_xy_spacing", "support_material_interface_speed", |     "top_solid_infill_speed", "support_material_speed", "support_material_xy_spacing", "support_material_interface_speed", | ||||||
|     "bridge_speed", "gap_fill_speed", "gap_fill_enabled", "travel_speed", "travel_speed_z", "first_layer_speed", "perimeter_acceleration", "infill_acceleration", |     "bridge_speed", "gap_fill_speed", "gap_fill_enabled", "travel_speed", "travel_speed_z", "first_layer_speed", "first_layer_speed_over_raft", "perimeter_acceleration", "infill_acceleration", | ||||||
|     "bridge_acceleration", "first_layer_acceleration", "default_acceleration", "skirts", "skirt_distance", "skirt_height", "draft_shield", |     "bridge_acceleration", "first_layer_acceleration", "first_layer_acceleration_over_raft", "default_acceleration", "skirts", "skirt_distance", "skirt_height", "draft_shield", | ||||||
|     "min_skirt_length", "brim_width", "brim_separation", "brim_type", "support_material", "support_material_auto", "support_material_threshold", "support_material_enforce_layers", |     "min_skirt_length", "brim_width", "brim_separation", "brim_type", "support_material", "support_material_auto", "support_material_threshold", "support_material_enforce_layers", | ||||||
|     "raft_layers", "raft_first_layer_density", "raft_first_layer_expansion", "raft_contact_distance", "raft_expansion", |     "raft_layers", "raft_first_layer_density", "raft_first_layer_expansion", "raft_contact_distance", "raft_expansion", | ||||||
|     "support_material_pattern", "support_material_with_sheath", "support_material_spacing", "support_material_closing_radius", "support_material_style", |     "support_material_pattern", "support_material_with_sheath", "support_material_spacing", "support_material_closing_radius", "support_material_style", | ||||||
|  | |||||||
| @ -88,7 +88,9 @@ bool Print::invalidate_state_by_config_options(const ConfigOptionResolver & /* n | |||||||
|         "filament_cost", |         "filament_cost", | ||||||
|         "filament_spool_weight", |         "filament_spool_weight", | ||||||
|         "first_layer_acceleration", |         "first_layer_acceleration", | ||||||
|  |         "first_layer_acceleration_over_raft", | ||||||
|         "first_layer_bed_temperature", |         "first_layer_bed_temperature", | ||||||
|  |         "first_layer_speed_over_raft", | ||||||
|         "gcode_comments", |         "gcode_comments", | ||||||
|         "gcode_label_objects", |         "gcode_label_objects", | ||||||
|         "infill_acceleration", |         "infill_acceleration", | ||||||
|  | |||||||
| @ -1152,6 +1152,15 @@ void PrintConfigDef::init_fff_params() | |||||||
|     def->mode = comExpert; |     def->mode = comExpert; | ||||||
|     def->set_default_value(new ConfigOptionFloat(0)); |     def->set_default_value(new ConfigOptionFloat(0)); | ||||||
| 
 | 
 | ||||||
|  |     def = this->add("first_layer_acceleration_over_raft", coFloat); | ||||||
|  |     def->label = L("First object layer over raft interface"); | ||||||
|  |     def->tooltip = L("This is the acceleration your printer will use for first layer of object above raft interface. Set zero " | ||||||
|  |                    "to disable acceleration control for first layer of object above raft interface."); | ||||||
|  |     def->sidetext = L("mm/s²"); | ||||||
|  |     def->min = 0; | ||||||
|  |     def->mode = comExpert; | ||||||
|  |     def->set_default_value(new ConfigOptionFloat(0)); | ||||||
|  | 
 | ||||||
|     def = this->add("first_layer_bed_temperature", coInts); |     def = this->add("first_layer_bed_temperature", coInts); | ||||||
|     def->label = L("First layer"); |     def->label = L("First layer"); | ||||||
|     def->full_label = L("First layer bed temperature"); |     def->full_label = L("First layer bed temperature"); | ||||||
| @ -1194,6 +1203,16 @@ void PrintConfigDef::init_fff_params() | |||||||
|     def->mode = comAdvanced; |     def->mode = comAdvanced; | ||||||
|     def->set_default_value(new ConfigOptionFloatOrPercent(30, false)); |     def->set_default_value(new ConfigOptionFloatOrPercent(30, false)); | ||||||
| 
 | 
 | ||||||
|  |     def = this->add("first_layer_speed_over_raft", coFloatOrPercent); | ||||||
|  |     def->label = L("Speed of object first layer over raft interface"); | ||||||
|  |     def->tooltip = L("If expressed as absolute value in mm/s, this speed will be applied to all the print moves " | ||||||
|  |                    "of the first object layer above raft interface, regardless of their type. If expressed as a percentage " | ||||||
|  |                    "(for example: 40%) it will scale the default speeds."); | ||||||
|  |     def->sidetext = L("mm/s or %"); | ||||||
|  |     def->min = 0; | ||||||
|  |     def->mode = comAdvanced; | ||||||
|  |     def->set_default_value(new ConfigOptionFloatOrPercent(30, false)); | ||||||
|  | 
 | ||||||
|     def = this->add("first_layer_temperature", coInts); |     def = this->add("first_layer_temperature", coInts); | ||||||
|     def->label = L("First layer"); |     def->label = L("First layer"); | ||||||
|     def->full_label = L("First layer nozzle temperature"); |     def->full_label = L("First layer nozzle temperature"); | ||||||
|  | |||||||
| @ -456,6 +456,8 @@ PRINT_CONFIG_CLASS_DEFINE( | |||||||
|     ((ConfigOptionBool,                dont_support_bridges)) |     ((ConfigOptionBool,                dont_support_bridges)) | ||||||
|     ((ConfigOptionFloat,               elefant_foot_compensation)) |     ((ConfigOptionFloat,               elefant_foot_compensation)) | ||||||
|     ((ConfigOptionFloatOrPercent,      extrusion_width)) |     ((ConfigOptionFloatOrPercent,      extrusion_width)) | ||||||
|  |     ((ConfigOptionFloat,               first_layer_acceleration_over_raft)) | ||||||
|  |     ((ConfigOptionFloatOrPercent,      first_layer_speed_over_raft)) | ||||||
|     ((ConfigOptionBool,                infill_only_where_needed)) |     ((ConfigOptionBool,                infill_only_where_needed)) | ||||||
|     // Force the generation of solid shells between adjacent materials/volumes.
 |     // Force the generation of solid shells between adjacent materials/volumes.
 | ||||||
|     ((ConfigOptionBool,                interface_shells)) |     ((ConfigOptionBool,                interface_shells)) | ||||||
|  | |||||||
| @ -312,7 +312,8 @@ void ConfigManipulation::toggle_print_fff_options(DynamicPrintConfig* config) | |||||||
|     toggle_field("support_material_speed", have_support_material || have_brim || have_skirt); |     toggle_field("support_material_speed", have_support_material || have_brim || have_skirt); | ||||||
| 
 | 
 | ||||||
|     toggle_field("raft_contact_distance", have_raft && !have_support_soluble); |     toggle_field("raft_contact_distance", have_raft && !have_support_soluble); | ||||||
|     toggle_field("raft_expansion", have_raft); |     for (auto el : { "raft_expansion", "first_layer_acceleration_over_raft", "first_layer_speed_over_raft" }) | ||||||
|  |         toggle_field(el, have_raft); | ||||||
| 
 | 
 | ||||||
|     bool has_ironing = config->opt_bool("ironing"); |     bool has_ironing = config->opt_bool("ironing"); | ||||||
|     for (auto el : { "ironing_type", "ironing_flowrate", "ironing_spacing", "ironing_speed" }) |     for (auto el : { "ironing_type", "ironing_flowrate", "ironing_spacing", "ironing_speed" }) | ||||||
|  | |||||||
| @ -1565,12 +1565,14 @@ void TabPrint::build() | |||||||
| 
 | 
 | ||||||
|         optgroup = page->new_optgroup(L("Modifiers")); |         optgroup = page->new_optgroup(L("Modifiers")); | ||||||
|         optgroup->append_single_option_line("first_layer_speed"); |         optgroup->append_single_option_line("first_layer_speed"); | ||||||
|  |         optgroup->append_single_option_line("first_layer_speed_over_raft"); | ||||||
| 
 | 
 | ||||||
|         optgroup = page->new_optgroup(L("Acceleration control (advanced)")); |         optgroup = page->new_optgroup(L("Acceleration control (advanced)")); | ||||||
|         optgroup->append_single_option_line("perimeter_acceleration"); |         optgroup->append_single_option_line("perimeter_acceleration"); | ||||||
|         optgroup->append_single_option_line("infill_acceleration"); |         optgroup->append_single_option_line("infill_acceleration"); | ||||||
|         optgroup->append_single_option_line("bridge_acceleration"); |         optgroup->append_single_option_line("bridge_acceleration"); | ||||||
|         optgroup->append_single_option_line("first_layer_acceleration"); |         optgroup->append_single_option_line("first_layer_acceleration"); | ||||||
|  |         optgroup->append_single_option_line("first_layer_acceleration_over_raft"); | ||||||
|         optgroup->append_single_option_line("default_acceleration"); |         optgroup->append_single_option_line("default_acceleration"); | ||||||
| 
 | 
 | ||||||
|         optgroup = page->new_optgroup(L("Autospeed (advanced)")); |         optgroup = page->new_optgroup(L("Autospeed (advanced)")); | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Vojtech Bubnik
						Vojtech Bubnik