mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-21 15:51:10 -06:00 
			
		
		
		
	Improved loading of the config wizard results.
Fixed some updates of the "compatible with printer" flags at the print and filament presets.
This commit is contained in:
		
							parent
							
								
									c49d6a3ec7
								
							
						
					
					
						commit
						558a0753c1
					
				
					 6 changed files with 77 additions and 40 deletions
				
			
		|  | @ -610,8 +610,6 @@ sub load_configbundle { | ||||||
| 
 | 
 | ||||||
| # Load a provied DynamicConfig into the Print / Filament / Printer tabs, thus modifying the active preset. | # Load a provied DynamicConfig into the Print / Filament / Printer tabs, thus modifying the active preset. | ||||||
| # Also update the platter with the new presets. | # Also update the platter with the new presets. | ||||||
| # This method is used to update the configuration from mainpulations in the 3D scene (for example moving the wipe tower), |  | ||||||
| # and to load the configuration from the config wizard. |  | ||||||
| sub load_config { | sub load_config { | ||||||
|     my ($self, $config) = @_;     |     my ($self, $config) = @_;     | ||||||
|     $_->load_config($config) foreach values %{$self->{options_tabs}}; |     $_->load_config($config) foreach values %{$self->{options_tabs}}; | ||||||
|  | @ -636,31 +634,22 @@ sub config_wizard { | ||||||
|     } |     } | ||||||
|     # Open the wizard. |     # Open the wizard. | ||||||
|     if (my $result = Slic3r::GUI::ConfigWizard->new($self, \@profiles, $fresh_start)->run) { |     if (my $result = Slic3r::GUI::ConfigWizard->new($self, \@profiles, $fresh_start)->run) { | ||||||
|         if ($result->{reset_user_profile}) { |         eval { | ||||||
|             eval { wxTheApp->{preset_bundle}->reset(1) }; |             if ($result->{reset_user_profile}) { | ||||||
|         } |                 wxTheApp->{preset_bundle}->reset(1); | ||||||
|         if (defined $result->{config}) { |  | ||||||
|             # Wizard returned a config. Add the config to each of the preset types. |  | ||||||
|             # Select and load the "-- default --" preset, start with the printer tab as it may revert |  | ||||||
|             # the print and filament profile to the first visible one, which may have some |  | ||||||
|             # printer compatibility configuration set, which we don't want to inherit. |  | ||||||
|             foreach my $tab (qw(printer print filament)) { |  | ||||||
|                 $self->{options_tabs}->$tab->select_preset(undef, 1); |  | ||||||
|             } |             } | ||||||
|             # Load the config over the previously selected defaults. |             if (defined $result->{config}) { | ||||||
|             $self->load_config($result->{config}); |                 # Load and save the settings into print, filament and printer presets. | ||||||
|             for my $tab (values %{$self->{options_tabs}}) { |                 wxTheApp->{preset_bundle}->load_config('My Settings', $result->{config}); | ||||||
|                 # Save the settings under a new name, select the name. |             } else { | ||||||
|                 $tab->save_preset('My Settings'); |                 # Wizard returned a name of a preset bundle bundled with the installation. Unpack it. | ||||||
|             } |                 wxTheApp->{preset_bundle}->load_configbundle($directory . '/' . $result->{preset_name} . '.ini'); | ||||||
|         } else { |  | ||||||
|             # Wizard returned a name of a preset bundle bundled with the installation. Unpack it. |  | ||||||
|             eval { wxTheApp->{preset_bundle}->load_configbundle($directory . '/' . $result->{preset_name} . '.ini'); }; |  | ||||||
|             Slic3r::GUI::catch_error($self) and return; |  | ||||||
|             # Load the currently selected preset into the GUI, update the preset selection box. |  | ||||||
|             foreach my $tab (values %{$self->{options_tabs}}) { |  | ||||||
|                 $tab->load_current_preset; |  | ||||||
|             } |             } | ||||||
|  |         }; | ||||||
|  |         Slic3r::GUI::catch_error($self) and return; | ||||||
|  |         # Load the currently selected preset into the GUI, update the preset selection box. | ||||||
|  |         foreach my $tab (values %{$self->{options_tabs}}) { | ||||||
|  |             $tab->load_current_preset; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -350,11 +350,8 @@ void PresetCollection::save_current_preset(const std::string &new_name) | ||||||
|     } else { |     } else { | ||||||
|         // Creating a new preset.
 |         // Creating a new preset.
 | ||||||
| 		Preset &preset = *m_presets.insert(it, m_edited_preset); | 		Preset &preset = *m_presets.insert(it, m_edited_preset); | ||||||
|         std::string file_name = new_name; |  | ||||||
|         if (! boost::iends_with(file_name, ".ini")) |  | ||||||
|             file_name += ".ini"; |  | ||||||
|         preset.name = new_name; |         preset.name = new_name; | ||||||
| 		preset.file = (boost::filesystem::path(m_dir_path) / file_name).make_preferred().string(); | 		preset.file = this->path_from_name(new_name); | ||||||
|     } |     } | ||||||
| 	// 2) Activate the saved preset.
 | 	// 2) Activate the saved preset.
 | ||||||
| 	this->select_preset_by_name(new_name, true); | 	this->select_preset_by_name(new_name, true); | ||||||
|  | @ -591,4 +588,11 @@ std::string PresetCollection::name() const | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | // Generate a file path from a profile name. Add the ".ini" suffix if it is missing.
 | ||||||
|  | std::string PresetCollection::path_from_name(const std::string &new_name) const | ||||||
|  | { | ||||||
|  | 	std::string file_name = boost::iends_with(new_name, ".ini") ? new_name : (new_name + ".ini"); | ||||||
|  |     return (boost::filesystem::path(m_dir_path) / file_name).make_preferred().string(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| } // namespace Slic3r
 | } // namespace Slic3r
 | ||||||
|  |  | ||||||
|  | @ -211,6 +211,9 @@ public: | ||||||
|     // With force, the changes are reverted if the new index is the same as the old index.
 |     // With force, the changes are reverted if the new index is the same as the old index.
 | ||||||
|     bool            select_preset_by_name(const std::string &name, bool force); |     bool            select_preset_by_name(const std::string &name, bool force); | ||||||
| 
 | 
 | ||||||
|  |     // Generate a file path from a profile name. Add the ".ini" suffix if it is missing.
 | ||||||
|  |     std::string     path_from_name(const std::string &new_name) const; | ||||||
|  | 
 | ||||||
| private: | private: | ||||||
|     PresetCollection(); |     PresetCollection(); | ||||||
|     PresetCollection(const PresetCollection &other); |     PresetCollection(const PresetCollection &other); | ||||||
|  |  | ||||||
|  | @ -133,6 +133,7 @@ void PresetBundle::load_presets() | ||||||
|         errors_cummulative += err.what(); |         errors_cummulative += err.what(); | ||||||
|     } |     } | ||||||
|     this->update_multi_material_filament_presets(); |     this->update_multi_material_filament_presets(); | ||||||
|  |     this->update_compatible_with_printer(false); | ||||||
|     if (! errors_cummulative.empty()) |     if (! errors_cummulative.empty()) | ||||||
|         throw std::runtime_error(errors_cummulative); |         throw std::runtime_error(errors_cummulative); | ||||||
| } | } | ||||||
|  | @ -163,8 +164,10 @@ void PresetBundle::load_selections(const AppConfig &config) | ||||||
|         this->set_filament_preset(i, remove_ini_suffix(config.get("presets", name))); |         this->set_filament_preset(i, remove_ini_suffix(config.get("presets", name))); | ||||||
|     } |     } | ||||||
|     // Update visibility of presets based on their compatibility with the active printer.
 |     // Update visibility of presets based on their compatibility with the active printer.
 | ||||||
|     // This will switch the print or filament presets to compatible if the active presets are incompatible.
 |     // Always try to select a compatible print and filament preset to the current printer preset,
 | ||||||
|     this->update_compatible_with_printer(false); |     // as the application may have been closed with an active "external" preset, which does not
 | ||||||
|  |     // exist.
 | ||||||
|  |     this->update_compatible_with_printer(true); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // Export selections (current print, current filaments, current printer) into config.ini
 | // Export selections (current print, current filaments, current printer) into config.ini
 | ||||||
|  | @ -279,7 +282,7 @@ void PresetBundle::load_config_file(const std::string &path) | ||||||
| 		config.apply(FullPrintConfig::defaults()); | 		config.apply(FullPrintConfig::defaults()); | ||||||
| 		config.load_from_gcode(path); | 		config.load_from_gcode(path); | ||||||
| 		Preset::normalize(config); | 		Preset::normalize(config); | ||||||
| 		load_config_file_config(path, std::move(config)); | 		load_config_file_config(path, true, std::move(config)); | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | @ -308,7 +311,7 @@ void PresetBundle::load_config_file(const std::string &path) | ||||||
| 		config.apply(FullPrintConfig::defaults()); | 		config.apply(FullPrintConfig::defaults()); | ||||||
| 		config.load(tree); | 		config.load(tree); | ||||||
| 		Preset::normalize(config); | 		Preset::normalize(config); | ||||||
| 		load_config_file_config(path, std::move(config)); | 		load_config_file_config(path, true, std::move(config)); | ||||||
| 		break; | 		break; | ||||||
| 	} | 	} | ||||||
|     case CONFIG_FILE_TYPE_CONFIG_BUNDLE: |     case CONFIG_FILE_TYPE_CONFIG_BUNDLE: | ||||||
|  | @ -318,7 +321,7 @@ void PresetBundle::load_config_file(const std::string &path) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // Load a config file from a boost property_tree. This is a private method called from load_config_file.
 | // Load a config file from a boost property_tree. This is a private method called from load_config_file.
 | ||||||
| void PresetBundle::load_config_file_config(const std::string &path, DynamicPrintConfig &&config) | void PresetBundle::load_config_file_config(const std::string &name_or_path, bool is_external, DynamicPrintConfig &&config) | ||||||
| { | { | ||||||
|     // The "compatible_printers" field should not have been exported into a config.ini or a G-code anyway, 
 |     // The "compatible_printers" field should not have been exported into a config.ini or a G-code anyway, 
 | ||||||
|     // but some of the alpha versions of Slic3r did.
 |     // but some of the alpha versions of Slic3r did.
 | ||||||
|  | @ -333,13 +336,17 @@ void PresetBundle::load_config_file_config(const std::string &path, DynamicPrint | ||||||
| 
 | 
 | ||||||
|     // 1) Create a name from the file name.
 |     // 1) Create a name from the file name.
 | ||||||
|     // Keep the suffix (.ini, .gcode, .amf, .3mf etc) to differentiate it from the normal profiles.
 |     // Keep the suffix (.ini, .gcode, .amf, .3mf etc) to differentiate it from the normal profiles.
 | ||||||
|     std::string name = boost::filesystem::path(path).filename().string(); |     std::string name = is_external ? boost::filesystem::path(name_or_path).filename().string() : name_or_path; | ||||||
| 
 | 
 | ||||||
|     // 2) If the loading succeeded, split and load the config into print / filament / printer settings.
 |     // 2) If the loading succeeded, split and load the config into print / filament / printer settings.
 | ||||||
|     // First load the print and printer presets.
 |     // First load the print and printer presets.
 | ||||||
|     for (size_t i_group = 0; i_group < 2; ++ i_group) { |     for (size_t i_group = 0; i_group < 2; ++ i_group) { | ||||||
|         PresetCollection &presets = (i_group == 0) ? this->prints : this->printers; |         PresetCollection &presets = (i_group == 0) ? this->prints : this->printers; | ||||||
|         presets.load_preset(path, name, config).is_external = true; | 		Preset &preset = presets.load_preset(is_external ? name_or_path : presets.path_from_name(name), name, config); | ||||||
|  |         if (is_external) | ||||||
|  |             preset.is_external = true; | ||||||
|  |         else | ||||||
|  |             preset.save(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // 3) Now load the filaments. If there are multiple filament presets, split them and load them.
 |     // 3) Now load the filaments. If there are multiple filament presets, split them and load them.
 | ||||||
|  | @ -347,7 +354,12 @@ void PresetBundle::load_config_file_config(const std::string &path, DynamicPrint | ||||||
|     auto   *filament_diameter = dynamic_cast<const ConfigOptionFloats*>(config.option("filament_diameter")); |     auto   *filament_diameter = dynamic_cast<const ConfigOptionFloats*>(config.option("filament_diameter")); | ||||||
|     size_t  num_extruders     = std::min(nozzle_diameter->values.size(), filament_diameter->values.size()); |     size_t  num_extruders     = std::min(nozzle_diameter->values.size(), filament_diameter->values.size()); | ||||||
|     if (num_extruders <= 1) { |     if (num_extruders <= 1) { | ||||||
|         this->filaments.load_preset(path, name, config).is_external = true; |         Preset &preset = this->filaments.load_preset( | ||||||
|  | 			is_external ? name_or_path : this->filaments.path_from_name(name), name, config); | ||||||
|  |         if (is_external) | ||||||
|  |             preset.is_external = true; | ||||||
|  |         else | ||||||
|  |             preset.save(); | ||||||
|         this->filament_presets.clear(); |         this->filament_presets.clear(); | ||||||
|         this->filament_presets.emplace_back(name); |         this->filament_presets.emplace_back(name); | ||||||
|     } else { |     } else { | ||||||
|  | @ -374,11 +386,20 @@ void PresetBundle::load_config_file_config(const std::string &path, DynamicPrint | ||||||
|                 suffix[0] = 0; |                 suffix[0] = 0; | ||||||
|             else |             else | ||||||
|                 sprintf(suffix, " (%d)", i); |                 sprintf(suffix, " (%d)", i); | ||||||
|  |             std::string new_name = name + suffix; | ||||||
|             // Load all filament presets, but only select the first one in the preset dialog.
 |             // Load all filament presets, but only select the first one in the preset dialog.
 | ||||||
|             this->filaments.load_preset(path, name + suffix, std::move(configs[i]), i == 0).is_external = true; |             Preset &preset = this->filaments.load_preset( | ||||||
|             this->filament_presets.emplace_back(name + suffix); | 				is_external ? name_or_path : this->filaments.path_from_name(new_name), | ||||||
|  |                 new_name, std::move(configs[i]), i == 0); | ||||||
|  |             if (is_external) | ||||||
|  |                 preset.is_external = true; | ||||||
|  |             else | ||||||
|  |                 preset.save(); | ||||||
|  |             this->filament_presets.emplace_back(new_name); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     this->update_compatible_with_printer(false); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // Load the active configuration of a config bundle from a boost property_tree. This is a private method called from load_config_file.
 | // Load the active configuration of a config bundle from a boost property_tree. This is a private method called from load_config_file.
 | ||||||
|  | @ -437,6 +458,8 @@ void PresetBundle::load_config_file_config_bundle(const std::string &path, const | ||||||
|     this->update_multi_material_filament_presets(); |     this->update_multi_material_filament_presets(); | ||||||
|     for (size_t i = 1; i < std::min(tmp_bundle.filament_presets.size(), this->filament_presets.size()); ++ i) |     for (size_t i = 1; i < std::min(tmp_bundle.filament_presets.size(), this->filament_presets.size()); ++ i) | ||||||
|         this->filament_presets[i] = load_one(this->filaments, tmp_bundle.filaments, tmp_bundle.filament_presets[i], false); |         this->filament_presets[i] = load_one(this->filaments, tmp_bundle.filaments, tmp_bundle.filament_presets[i], false); | ||||||
|  | 
 | ||||||
|  |     this->update_compatible_with_printer(false); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // Load a config bundle file, into presets and store the loaded presets into separate files
 | // Load a config bundle file, into presets and store the loaded presets into separate files
 | ||||||
|  | @ -537,6 +560,8 @@ size_t PresetBundle::load_configbundle(const std::string &path, unsigned int fla | ||||||
|     this->update_multi_material_filament_presets(); |     this->update_multi_material_filament_presets(); | ||||||
|     for (size_t i = 0; i < std::min(this->filament_presets.size(), active_filaments.size()); ++ i) |     for (size_t i = 0; i < std::min(this->filament_presets.size(), active_filaments.size()); ++ i) | ||||||
|         this->filament_presets[i] = filaments.find_preset(active_filaments[i], true)->name; |         this->filament_presets[i] = filaments.find_preset(active_filaments[i], true)->name; | ||||||
|  | 
 | ||||||
|  |     this->update_compatible_with_printer(false); | ||||||
|     return presets_loaded; |     return presets_loaded; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -44,6 +44,11 @@ public: | ||||||
| 
 | 
 | ||||||
|     DynamicPrintConfig          full_config() const; |     DynamicPrintConfig          full_config() const; | ||||||
| 
 | 
 | ||||||
|  |     // Load user configuration and store it into the user profiles.
 | ||||||
|  |     // This method is called by the configuration wizard.
 | ||||||
|  |     void                        load_config(const std::string &name, DynamicPrintConfig config) | ||||||
|  |         { this->load_config_file_config(name, false, std::move(config)); } | ||||||
|  | 
 | ||||||
|     // Load an external config file containing the print, filament and printer presets.
 |     // Load an external config file containing the print, filament and printer presets.
 | ||||||
|     // Instead of a config file, a G-code may be loaded containing the full set of parameters.
 |     // Instead of a config file, a G-code may be loaded containing the full set of parameters.
 | ||||||
|     // In the future the configuration will likely be read from an AMF file as well.
 |     // In the future the configuration will likely be read from an AMF file as well.
 | ||||||
|  | @ -89,7 +94,10 @@ public: | ||||||
|     void                        update_compatible_with_printer(bool select_other_if_incompatible); |     void                        update_compatible_with_printer(bool select_other_if_incompatible); | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|     void                        load_config_file_config(const std::string &path, DynamicPrintConfig &&config); |     // Load print, filament & printer presets from a config. If it is an external config, then the name is extracted from the external path.
 | ||||||
|  |     // and the external config is just referenced, not stored into user profile directory.
 | ||||||
|  |     // If it is not an external config, then the config will be stored into the user profile directory.
 | ||||||
|  |     void                        load_config_file_config(const std::string &name_or_path, bool is_external, DynamicPrintConfig &&config); | ||||||
|     void                        load_config_file_config_bundle(const std::string &path, const boost::property_tree::ptree &tree); |     void                        load_config_file_config_bundle(const std::string &path, const boost::property_tree::ptree &tree); | ||||||
|     bool                        load_compatible_bitmaps(); |     bool                        load_compatible_bitmaps(); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -119,6 +119,14 @@ PresetCollection::arrayref() | ||||||
|                     Slic3r::data_dir().c_str(), e.what()); |                     Slic3r::data_dir().c_str(), e.what()); | ||||||
|             } |             } | ||||||
|         %}; |         %}; | ||||||
|  |     void                        load_config(const char *name, DynamicPrintConfig *config) | ||||||
|  |         %code%{ | ||||||
|  |             try { | ||||||
|  |                 THIS->load_config(name, *config); | ||||||
|  |             } catch (std::exception& e) { | ||||||
|  |                 croak("Loading a configuration %s failed:\n%s\n", name, e.what()); | ||||||
|  |             } | ||||||
|  |         %}; | ||||||
|     void                        load_config_file(const char *path) |     void                        load_config_file(const char *path) | ||||||
|         %code%{ |         %code%{ | ||||||
|             try { |             try { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bubnikv
						bubnikv