mirror of
				https://git.mirrors.martin98.com/https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-21 04:41:06 +08:00 
			
		
		
		
	Merge branch 'master' of https://github.com/prusa3d/Slic3r into scene_manipulators
This commit is contained in:
		
						commit
						01b6bc1dc8
					
				| @ -410,6 +410,7 @@ sub new { | |||||||
|                 $presets->Add($text, 0, wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL | wxRIGHT, 4); |                 $presets->Add($text, 0, wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL | wxRIGHT, 4); | ||||||
|                 $presets->Add($choice, 1, wxALIGN_CENTER_VERTICAL | wxEXPAND | wxBOTTOM, 1); |                 $presets->Add($choice, 1, wxALIGN_CENTER_VERTICAL | wxEXPAND | wxBOTTOM, 1); | ||||||
|             } |             } | ||||||
|  |             $presets->Layout; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         my $frequently_changed_parameters_sizer = Wx::BoxSizer->new(wxHORIZONTAL); |         my $frequently_changed_parameters_sizer = Wx::BoxSizer->new(wxHORIZONTAL); | ||||||
| @ -1738,7 +1739,7 @@ sub on_extruders_change { | |||||||
|         my @presets = $choices->[0]->GetStrings; |         my @presets = $choices->[0]->GetStrings; | ||||||
|          |          | ||||||
|         # initialize new choice |         # initialize new choice | ||||||
|         my $choice = Wx::BitmapComboBox->new($self, -1, "", wxDefaultPosition, wxDefaultSize, [@presets], wxCB_READONLY); |         my $choice = Wx::BitmapComboBox->new($self->{right_panel}, -1, "", wxDefaultPosition, wxDefaultSize, [@presets], wxCB_READONLY); | ||||||
|         my $extruder_idx = scalar @$choices; |         my $extruder_idx = scalar @$choices; | ||||||
|         EVT_LEFT_DOWN($choice, sub { $self->filament_color_box_lmouse_down($extruder_idx, @_); } ); |         EVT_LEFT_DOWN($choice, sub { $self->filament_color_box_lmouse_down($extruder_idx, @_); } ); | ||||||
|         push @$choices, $choice; |         push @$choices, $choice; | ||||||
|  | |||||||
| @ -809,8 +809,8 @@ void add_frequently_changed_parameters(wxWindow* parent, wxBoxSizer* sizer, wxFl | |||||||
| { | { | ||||||
| 	DynamicPrintConfig*	config = &g_PresetBundle->prints.get_edited_preset().config; | 	DynamicPrintConfig*	config = &g_PresetBundle->prints.get_edited_preset().config; | ||||||
| 	m_optgroup = std::make_shared<ConfigOptionsGroup>(parent, "", config); | 	m_optgroup = std::make_shared<ConfigOptionsGroup>(parent, "", config); | ||||||
| //	const wxArrayInt& ar = preset_sizer->GetColWidths();
 | 	const wxArrayInt& ar = preset_sizer->GetColWidths(); | ||||||
| // 	m_optgroup->label_width = ar.IsEmpty() ? 100 : ar.front(); // doesn't work
 | 	m_optgroup->label_width = ar.IsEmpty() ? 100 : ar.front()-4; // doesn't work
 | ||||||
| 	m_optgroup->m_on_change = [config](t_config_option_key opt_key, boost::any value){ | 	m_optgroup->m_on_change = [config](t_config_option_key opt_key, boost::any value){ | ||||||
| 		TabPrint* tab_print = nullptr; | 		TabPrint* tab_print = nullptr; | ||||||
| 		for (size_t i = 0; i < g_wxTabPanel->GetPageCount(); ++i) { | 		for (size_t i = 0; i < g_wxTabPanel->GetPageCount(); ++i) { | ||||||
|  | |||||||
| @ -151,10 +151,10 @@ void OptionsGroup::append_line(const Line& line, wxStaticText**	colored_Label/* | |||||||
| 	wxStaticText* label=nullptr; | 	wxStaticText* label=nullptr; | ||||||
|     if (label_width != 0) { |     if (label_width != 0) { | ||||||
| 		label = new wxStaticText(parent(), wxID_ANY, line.label + (line.label.IsEmpty() ? "" : ":"),  | 		label = new wxStaticText(parent(), wxID_ANY, line.label + (line.label.IsEmpty() ? "" : ":"),  | ||||||
| 							wxDefaultPosition, staticbox ? wxSize(label_width, -1) : wxDefaultSize); | 							wxDefaultPosition, wxSize(label_width, -1), staticbox ? 0 : wxALIGN_RIGHT); | ||||||
|         label->SetFont(label_font); |         label->SetFont(label_font); | ||||||
|         label->Wrap(label_width); // avoid a Linux/GTK bug
 |         label->Wrap(label_width); // avoid a Linux/GTK bug
 | ||||||
| 		grid_sizer->Add(label, 0, (staticbox ? 0 : wxALIGN_RIGHT) | wxALIGN_CENTER_VERTICAL, 0); | 		grid_sizer->Add(label, 0, (staticbox ? 0 : wxALIGN_RIGHT | wxRIGHT) | wxALIGN_CENTER_VERTICAL, 5); | ||||||
| 		if (line.label_tooltip.compare("") != 0) | 		if (line.label_tooltip.compare("") != 0) | ||||||
| 			label->SetToolTip(line.label_tooltip); | 			label->SetToolTip(line.label_tooltip); | ||||||
|     } |     } | ||||||
| @ -170,7 +170,7 @@ void OptionsGroup::append_line(const Line& line, wxStaticText**	colored_Label/* | |||||||
| 	 | 	 | ||||||
| 	// if we have a single option with no sidetext just add it directly to the grid sizer
 | 	// if we have a single option with no sidetext just add it directly to the grid sizer
 | ||||||
| 	auto sizer = new wxBoxSizer(wxHORIZONTAL); | 	auto sizer = new wxBoxSizer(wxHORIZONTAL); | ||||||
| 	grid_sizer->Add(sizer, 0, wxEXPAND | wxALL, 0); | 	grid_sizer->Add(sizer, 0, wxEXPAND | (staticbox ? wxALL : wxBOTTOM|wxTOP|wxLEFT), staticbox ? 0 : 1); | ||||||
| 	if (option_set.size() == 1 && option_set.front().opt.sidetext.size() == 0 && | 	if (option_set.size() == 1 && option_set.front().opt.sidetext.size() == 0 && | ||||||
| 		option_set.front().side_widget == nullptr && line.get_extra_widgets().size() == 0) { | 		option_set.front().side_widget == nullptr && line.get_extra_widgets().size() == 0) { | ||||||
| 		const auto& option = option_set.front(); | 		const auto& option = option_set.front(); | ||||||
| @ -180,7 +180,7 @@ void OptionsGroup::append_line(const Line& line, wxStaticText**	colored_Label/* | |||||||
| 		sizer->Add(field->m_Undo_btn, 0, wxALIGN_CENTER_VERTICAL); | 		sizer->Add(field->m_Undo_btn, 0, wxALIGN_CENTER_VERTICAL); | ||||||
| 		if (is_window_field(field))  | 		if (is_window_field(field))  | ||||||
| 			sizer->Add(field->getWindow(), option.opt.full_width ? 1 : 0, (option.opt.full_width ? wxEXPAND : 0) | | 			sizer->Add(field->getWindow(), option.opt.full_width ? 1 : 0, (option.opt.full_width ? wxEXPAND : 0) | | ||||||
| 							wxBOTTOM | wxTOP | wxALIGN_CENTER_VERTICAL, wxOSX ? 0 : 2); | 							wxBOTTOM | wxTOP | wxALIGN_CENTER_VERTICAL, (wxOSX||!staticbox) ? 0 : 2); | ||||||
| 		if (is_sizer_field(field))  | 		if (is_sizer_field(field))  | ||||||
| 			sizer->Add(field->getSizer(), 0, (option.opt.full_width ? wxEXPAND : 0) | wxALIGN_CENTER_VERTICAL, 0); | 			sizer->Add(field->getSizer(), 0, (option.opt.full_width ? wxEXPAND : 0) | wxALIGN_CENTER_VERTICAL, 0); | ||||||
| 		return; | 		return; | ||||||
|  | |||||||
| @ -402,7 +402,11 @@ void PresetUpdater::priv::perform_updates(Updates &&updates, bool snapshot) cons | |||||||
| 			PresetBundle bundle; | 			PresetBundle bundle; | ||||||
| 			bundle.load_configbundle(update.target.string(), PresetBundle::LOAD_CFGBNDLE_SYSTEM); | 			bundle.load_configbundle(update.target.string(), PresetBundle::LOAD_CFGBNDLE_SYSTEM); | ||||||
| 
 | 
 | ||||||
|  | 			BOOST_LOG_TRIVIAL(info) << boost::format("Deleting %1% conflicting presets") | ||||||
|  | 				% (bundle.prints.size() + bundle.filaments.size() + bundle.printers.size()); | ||||||
|  | 
 | ||||||
| 			auto preset_remover = [](const Preset &preset) { | 			auto preset_remover = [](const Preset &preset) { | ||||||
|  | 				BOOST_LOG_TRIVIAL(info) << '\t' << preset.file; | ||||||
| 				fs::remove(preset.file); | 				fs::remove(preset.file); | ||||||
| 			}; | 			}; | ||||||
| 
 | 
 | ||||||
| @ -411,9 +415,14 @@ void PresetUpdater::priv::perform_updates(Updates &&updates, bool snapshot) cons | |||||||
| 			for (const auto &preset : bundle.printers)  { preset_remover(preset); } | 			for (const auto &preset : bundle.printers)  { preset_remover(preset); } | ||||||
| 
 | 
 | ||||||
| 			// Also apply the `obsolete_presets` property, removing obsolete ini files
 | 			// Also apply the `obsolete_presets` property, removing obsolete ini files
 | ||||||
|  | 
 | ||||||
|  | 			BOOST_LOG_TRIVIAL(info) << boost::format("Deleting %1% obsolete presets") | ||||||
|  | 				% (bundle.obsolete_presets.prints.size() + bundle.obsolete_presets.filaments.size() + bundle.obsolete_presets.printers.size()); | ||||||
|  | 
 | ||||||
| 			auto obsolete_remover = [](const char *subdir, const std::string &preset) { | 			auto obsolete_remover = [](const char *subdir, const std::string &preset) { | ||||||
| 				auto path = fs::path(Slic3r::data_dir()) / subdir / preset; | 				auto path = fs::path(Slic3r::data_dir()) / subdir / preset; | ||||||
| 				path += ".ini"; | 				path += ".ini"; | ||||||
|  | 				BOOST_LOG_TRIVIAL(info) << '\t' << path.string(); | ||||||
| 				fs::remove(path); | 				fs::remove(path); | ||||||
| 			}; | 			}; | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Enrico Turri
						Enrico Turri