mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	1) Storing the physical_printer_settings_id into the 3MF, AMF, GCode.
2) Activating the physical_printer_settings_id when loading from 3MF, AMF, GCode. The physical printer is only activated if it references the printer_settings_id loaded from the same file. 3) When loading the presets from 3MF, AMF, GCode, the "external" profiles are no more created for profiles which differ from the local profiles the loaded profiles reference. Instead, the referenced profile is activated and modified with the loaded preset. If the referenced profile does not exist, but the profile refers to a system profile with the "inherits" fileds, the system profile is loaded and modified instead. This works for all profiles with the exception of multi-extruder printer with multiple filament profiles modified. In that case the first modified filament profile will be loaded as modified, while the other modified profiles will be loaded as "external". This should fix Physical printer + 3mf file, wrong preset used to generate gcode #5178 and possibly https://github.com/prusa3d/PrusaSlicer/issues/5272
This commit is contained in:
		
							parent
							
								
									15b56c9950
								
							
						
					
					
						commit
						e42e25c933
					
				
					 8 changed files with 118 additions and 57 deletions
				
			
		|  | @ -193,9 +193,10 @@ SLAPrint::ApplyStatus SLAPrint::apply(const Model &model, DynamicPrintConfig con | |||
| #endif /* _DEBUG */ | ||||
| 
 | ||||
|     // Normalize the config.
 | ||||
|     config.option("sla_print_settings_id",    true); | ||||
|     config.option("sla_material_settings_id", true); | ||||
|     config.option("printer_settings_id",      true); | ||||
|     config.option("sla_print_settings_id",        true); | ||||
|     config.option("sla_material_settings_id",     true); | ||||
|     config.option("printer_settings_id",          true); | ||||
|     config.option("physical_printer_settings_id", true); | ||||
|     // Collect changes to print config.
 | ||||
|     t_config_option_keys print_diff    = m_print_config.diff(config); | ||||
|     t_config_option_keys printer_diff  = m_printer_config.diff(config); | ||||
|  | @ -228,9 +229,10 @@ SLAPrint::ApplyStatus SLAPrint::apply(const Model &model, DynamicPrintConfig con | |||
|         // update_apply_status(this->invalidate_step(slapsRasterize));
 | ||||
|         m_placeholder_parser.apply_config(config); | ||||
|         // Set the profile aliases for the PrintBase::output_filename()
 | ||||
|         m_placeholder_parser.set("print_preset",    config.option("sla_print_settings_id")->clone()); | ||||
|         m_placeholder_parser.set("material_preset", config.option("sla_material_settings_id")->clone()); | ||||
|         m_placeholder_parser.set("printer_preset",  config.option("printer_settings_id")->clone()); | ||||
|         m_placeholder_parser.set("print_preset",            config.option("sla_print_settings_id")->clone()); | ||||
|         m_placeholder_parser.set("material_preset",         config.option("sla_material_settings_id")->clone()); | ||||
|         m_placeholder_parser.set("printer_preset",          config.option("printer_settings_id")->clone()); | ||||
|         m_placeholder_parser.set("physical_printer_preset", config.option("physical_printer_settings_id")->clone()); | ||||
|     } | ||||
| 
 | ||||
|     // It is also safe to change m_config now after this->invalidate_state_by_config_options() call.
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Vojtech Bubnik
						Vojtech Bubnik