mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-22 08:11:11 -06:00 
			
		
		
		
	Merge remote-tracking branch 'remotes/origin/gui_translate_to_cpp'
This commit is contained in:
		
						commit
						69fc99edbb
					
				
					 26 changed files with 11863 additions and 6374 deletions
				
			
		|  | @ -36,43 +36,43 @@ void BedShapePanel::build_panel(ConfigOptionPoints* default_pt) | |||
| { | ||||
| //	on_change(nullptr);
 | ||||
| 
 | ||||
| 	auto box = new wxStaticBox(this, wxID_ANY, _L("Shape")); | ||||
| 	auto box = new wxStaticBox(this, wxID_ANY, _(L("Shape"))); | ||||
| 	auto sbsizer = new wxStaticBoxSizer(box, wxVERTICAL); | ||||
| 
 | ||||
| 	// shape options
 | ||||
| 	m_shape_options_book = new wxChoicebook(this, wxID_ANY, wxDefaultPosition, wxSize(300, -1), wxCHB_TOP); | ||||
| 	sbsizer->Add(m_shape_options_book); | ||||
| 
 | ||||
| 	auto optgroup = init_shape_options_page(_L("Rectangular")); | ||||
| 	auto optgroup = init_shape_options_page(_(L("Rectangular"))); | ||||
| 		ConfigOptionDef def; | ||||
| 		def.type = coPoints; | ||||
| 		def.default_value = new ConfigOptionPoints{ Pointf(200, 200) }; | ||||
| 		def.label = _LU8("Size"); | ||||
| 		def.tooltip = _LU8("Size in X and Y of the rectangular plate."); | ||||
| 		def.label = L("Size"); | ||||
| 		def.tooltip = L("Size in X and Y of the rectangular plate."); | ||||
| 		Option option(def, "rect_size"); | ||||
| 		optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 		def.type = coPoints; | ||||
| 		def.default_value = new ConfigOptionPoints{ Pointf(0, 0) }; | ||||
| 		def.label = _LU8("Origin"); | ||||
| 		def.tooltip = _LU8("Distance of the 0,0 G-code coordinate from the front left corner of the rectangle."); | ||||
| 		def.label = L("Origin"); | ||||
| 		def.tooltip = L("Distance of the 0,0 G-code coordinate from the front left corner of the rectangle."); | ||||
| 		option = Option(def, "rect_origin"); | ||||
| 		optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 		optgroup = init_shape_options_page(_L("Circular")); | ||||
| 		optgroup = init_shape_options_page(_(L("Circular"))); | ||||
| 		def.type = coFloat; | ||||
| 		def.default_value = new ConfigOptionFloat(200); | ||||
| 		def.sidetext = _LU8("mm"); | ||||
| 		def.label = _LU8("Diameter"); | ||||
| 		def.tooltip = _LU8("Diameter of the print bed. It is assumed that origin (0,0) is located in the center."); | ||||
| 		def.sidetext = L("mm"); | ||||
| 		def.label = L("Diameter"); | ||||
| 		def.tooltip = L("Diameter of the print bed. It is assumed that origin (0,0) is located in the center."); | ||||
| 		option = Option(def, "diameter"); | ||||
| 		optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 		optgroup = init_shape_options_page(_L("Custom")); | ||||
| 		optgroup = init_shape_options_page(_(L("Custom"))); | ||||
| 		Line line{ "", "" }; | ||||
| 		line.full_width = 1; | ||||
| 		line.widget = [this](wxWindow* parent) { | ||||
| 			auto btn = new wxButton(parent, wxID_ANY, _L("Load shape from STL..."), wxDefaultPosition, wxDefaultSize); | ||||
| 			auto btn = new wxButton(parent, wxID_ANY, _(L("Load shape from STL...")), wxDefaultPosition, wxDefaultSize); | ||||
| 			 | ||||
| 			auto sizer = new wxBoxSizer(wxHORIZONTAL); | ||||
| 			sizer->Add(btn); | ||||
|  | @ -117,7 +117,7 @@ ConfigOptionsGroupShp BedShapePanel::init_shape_options_page(wxString title){ | |||
| 
 | ||||
| 	auto panel = new wxPanel(m_shape_options_book); | ||||
| 	ConfigOptionsGroupShp optgroup; | ||||
| 	optgroup = std::make_shared<ConfigOptionsGroup>(panel, _L("Settings")); | ||||
| 	optgroup = std::make_shared<ConfigOptionsGroup>(panel, _(L("Settings"))); | ||||
| 
 | ||||
| 	optgroup->label_width = 100; | ||||
| 	optgroup->m_on_change = [this](t_config_option_key opt_key, boost::any value){ | ||||
|  | @ -295,8 +295,8 @@ void BedShapePanel::load_stl() | |||
| 	for (auto file_type: file_types) | ||||
| 		MODEL_WILDCARD += vec_FILE_WILDCARDS.at(file_type) + "|"; | ||||
| 
 | ||||
|     auto dialog = new wxFileDialog(this, _L("Choose a file to import bed shape from (STL/OBJ/AMF/3MF/PRUSA):"), "", "", | ||||
|         MODEL_WILDCARD, wxFD_OPEN | wxFD_FILE_MUST_EXIST); | ||||
| 	auto dialog = new wxFileDialog(this, _(L("Choose a file to import bed shape from (STL/OBJ/AMF/3MF/PRUSA):")), "", "", | ||||
| 		MODEL_WILDCARD, wxFD_OPEN | wxFD_FILE_MUST_EXIST); | ||||
| 	if (dialog->ShowModal() != wxID_OK) { | ||||
| 		dialog->Destroy(); | ||||
| 		return; | ||||
|  | @ -312,7 +312,7 @@ void BedShapePanel::load_stl() | |||
| 		model = Model::read_from_file(file_name); | ||||
| 	} | ||||
| 	catch (std::exception &e) { | ||||
| 		auto msg = _L("Error! ") + file_name + " : " + e.what() + "."; | ||||
| 		auto msg = _(L("Error! ")) + file_name + " : " + e.what() + "."; | ||||
| 		show_error(this, msg); | ||||
| 		exit(1); | ||||
| 	} | ||||
|  | @ -321,11 +321,11 @@ void BedShapePanel::load_stl() | |||
| 	auto expolygons = mesh.horizontal_projection(); | ||||
| 
 | ||||
| 	if (expolygons.size() == 0) { | ||||
| 		show_error(this, _L("The selected file contains no geometry.")); | ||||
| 		show_error(this, _(L("The selected file contains no geometry."))); | ||||
| 		return; | ||||
| 	} | ||||
| 	if (expolygons.size() > 1) { | ||||
| 		show_error(this, _L("The selected file contains several disjoint areas. This is not supported.")); | ||||
| 		show_error(this, _(L("The selected file contains several disjoint areas. This is not supported."))); | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
|  |  | |||
|  | @ -39,7 +39,7 @@ class BedShapeDialog : public wxDialog | |||
| { | ||||
| 	BedShapePanel*	m_panel; | ||||
| public: | ||||
| 	BedShapeDialog(wxWindow* parent) : wxDialog(parent, wxID_ANY, _L("Bed Shape"), | ||||
| 	BedShapeDialog(wxWindow* parent) : wxDialog(parent, wxID_ANY, _(L("Bed Shape")), | ||||
| 		wxDefaultPosition, wxSize(350, 700), wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER){} | ||||
| 	~BedShapeDialog(){  } | ||||
| 
 | ||||
|  |  | |||
|  | @ -10,6 +10,14 @@ | |||
| 
 | ||||
| namespace Slic3r { namespace GUI { | ||||
| 
 | ||||
| 	wxString double_to_string(double const value) | ||||
| 	{ | ||||
| 		int precision = 10 * value - int(10 * value) == 0 ? 1 : 2; | ||||
| 		return value - int(value) == 0 ? | ||||
| 			wxString::Format(_T("%i"), int(value)) : | ||||
| 			wxNumberFormatter::ToString(value, precision, wxNumberFormatter::Style_None); | ||||
| 	} | ||||
| 
 | ||||
| 	void Field::on_kill_focus(wxEvent& event) { | ||||
|         // Without this, there will be nasty focus bugs on Windows.
 | ||||
|         // Also, docs for wxEvent::Skip() say "In general, it is recommended to skip all 
 | ||||
|  | @ -30,9 +38,9 @@ namespace Slic3r { namespace GUI { | |||
| 	wxString Field::get_tooltip_text(const wxString& default_string) | ||||
| 	{ | ||||
| 		wxString tooltip_text(""); | ||||
| 		wxString tooltip = wxString::FromUTF8(m_opt.tooltip.c_str()); | ||||
| 		wxString tooltip = L_str(m_opt.tooltip); | ||||
| 		if (tooltip.length() > 0) | ||||
| 			tooltip_text = tooltip + "(" + _L("default") + ": " + | ||||
| 			tooltip_text = tooltip + "(" + _(L("default")) + ": " + | ||||
| 							(boost::iends_with(m_opt_id, "_gcode") ? "\n" : "") +  | ||||
| 							default_string + ")"; | ||||
| 
 | ||||
|  | @ -45,7 +53,7 @@ namespace Slic3r { namespace GUI { | |||
| 		return std::regex_match(string, regex_pattern); | ||||
| 	} | ||||
| 
 | ||||
| 	boost::any Field::get_value_by_opt_type(wxString str, ConfigOptionType type) | ||||
| 	boost::any Field::get_value_by_opt_type(wxString str) | ||||
| 	{ | ||||
| 		boost::any ret_val; | ||||
| 		switch (m_opt.type){ | ||||
|  | @ -56,23 +64,17 @@ namespace Slic3r { namespace GUI { | |||
| 		case coPercents: | ||||
| 		case coFloats: | ||||
| 		case coFloat:{ | ||||
| 			if (m_opt.type == coPercent) str.RemoveLast(); | ||||
| 			if (m_opt.type == coPercent && str.Last() == '%')  | ||||
| 				str.RemoveLast(); | ||||
| 			double val; | ||||
| 			str.ToCDouble(&val); | ||||
| 			ret_val = val; | ||||
| 			break; } | ||||
| 		case coString: | ||||
| 		case coStrings: | ||||
| 		case coFloatOrPercent: | ||||
| 			ret_val = str.ToStdString(); | ||||
| 			break; | ||||
| 		case coFloatOrPercent:{ | ||||
| 			if (str.Last() == '%') | ||||
| 				str.RemoveLast(); | ||||
| 			double val; | ||||
| 			str.ToCDouble(&val); | ||||
| 			ret_val = val; | ||||
| 			break; | ||||
| 		} | ||||
| 		default: | ||||
| 			break; | ||||
| 		} | ||||
|  | @ -90,13 +92,9 @@ namespace Slic3r { namespace GUI { | |||
| 		switch (m_opt.type) { | ||||
| 		case coFloatOrPercent: | ||||
| 		{ | ||||
| 			if (static_cast<const ConfigOptionFloatOrPercent*>(m_opt.default_value)->percent) | ||||
| 			{ | ||||
| 				text_value = wxString::Format(_T("%i"), int(m_opt.default_value->getFloat())); | ||||
| 				text_value += "%"; | ||||
| 			} | ||||
| 			else | ||||
| 				text_value = wxNumberFormatter::ToString(m_opt.default_value->getFloat(), 2); | ||||
| 			text_value = double_to_string(m_opt.default_value->getFloat()); | ||||
|  			if (static_cast<const ConfigOptionFloatOrPercent*>(m_opt.default_value)->percent) | ||||
|  				text_value += "%"; | ||||
| 			break; | ||||
| 		} | ||||
| 		case coPercent: | ||||
|  | @ -106,29 +104,15 @@ namespace Slic3r { namespace GUI { | |||
| 			break; | ||||
| 		}	 | ||||
| 		case coPercents: | ||||
| 		{ | ||||
| 			const ConfigOptionPercents *vec = static_cast<const ConfigOptionPercents*>(m_opt.default_value); | ||||
| 			if (vec == nullptr || vec->empty()) break; | ||||
| 			if (vec->size() > 1) | ||||
| 				break; | ||||
| 			double val = vec->get_at(0); | ||||
| 			text_value = val - int(val) == 0 ? wxString::Format(_T("%i"), int(val)) : wxNumberFormatter::ToString(val, 2, wxNumberFormatter::Style_None); | ||||
| 			break; | ||||
| 		}			 | ||||
| 		case coFloats: | ||||
| 		case coFloat: | ||||
| 		{ | ||||
| 			double val = m_opt.default_value->getFloat(); | ||||
| 			text_value = (val - int(val)) == 0 ? wxString::Format(_T("%i"), int(val)) : wxNumberFormatter::ToString(val, 2, wxNumberFormatter::Style_None); | ||||
| 			break; | ||||
| 		}			 | ||||
| 		case coFloats: | ||||
| 		{ | ||||
| 			const ConfigOptionFloats *vec = static_cast<const ConfigOptionFloats*>(m_opt.default_value); | ||||
| 			if (vec == nullptr || vec->empty()) break; | ||||
| 			if (vec->size() > 1) | ||||
| 				break; | ||||
| 			double val = vec->get_at(0); | ||||
| 			text_value = val - int(val) == 0 ? wxString::Format(_T("%i"), int(val)) : wxNumberFormatter::ToString(val, 2, wxNumberFormatter::Style_None); | ||||
| 			double val = m_opt.type == coFloats ? | ||||
| 				static_cast<const ConfigOptionFloats*>(m_opt.default_value)->get_at(0) : | ||||
| 				m_opt.type == coFloat ?  | ||||
| 					m_opt.default_value->getFloat() : | ||||
| 					static_cast<const ConfigOptionPercents*>(m_opt.default_value)->get_at(0); | ||||
| 			text_value = double_to_string(val); | ||||
| 			break; | ||||
| 		} | ||||
| 		case coString:			 | ||||
|  | @ -174,7 +158,7 @@ namespace Slic3r { namespace GUI { | |||
| 	boost::any TextCtrl::get_value() | ||||
| 	{ | ||||
| 		wxString ret_str = static_cast<wxTextCtrl*>(window)->GetValue(); | ||||
| 		boost::any ret_val = get_value_by_opt_type(ret_str, m_opt.type); | ||||
| 		boost::any ret_val = get_value_by_opt_type(ret_str); | ||||
| 
 | ||||
| 		return ret_val; | ||||
| 	} | ||||
|  | @ -303,7 +287,7 @@ void Choice::set_selection() | |||
| 				break; | ||||
| 			++idx; | ||||
| 		} | ||||
| 		if (m_opt.type == coPercent) text_value += "%"; | ||||
| //		if (m_opt.type == coPercent) text_value += "%";
 | ||||
| 		idx == m_opt.enum_values.size() ? | ||||
| 			dynamic_cast<wxComboBox*>(window)->SetValue(text_value) : | ||||
| 			dynamic_cast<wxComboBox*>(window)->SetSelection(idx); | ||||
|  | @ -387,7 +371,7 @@ void Choice::set_value(boost::any value) | |||
| 				break; | ||||
| 			++idx; | ||||
| 		} | ||||
| 		if (m_opt.type == coPercent) text_value += "%"; | ||||
| //		if (m_opt.type == coPercent) text_value += "%";
 | ||||
| 		idx == m_opt.enum_values.size() ? | ||||
| 			dynamic_cast<wxComboBox*>(window)->SetValue(text_value) : | ||||
| 			dynamic_cast<wxComboBox*>(window)->SetSelection(idx); | ||||
|  | @ -429,7 +413,7 @@ boost::any Choice::get_value() | |||
| 	wxString ret_str = static_cast<wxComboBox*>(window)->GetValue();	 | ||||
| 
 | ||||
| 	if (m_opt.type != coEnum) | ||||
| 		ret_val = get_value_by_opt_type(ret_str, m_opt.type); | ||||
| 		ret_val = get_value_by_opt_type(ret_str); | ||||
| 	else | ||||
| 	{ | ||||
| 		int ret_enum = static_cast<wxComboBox*>(window)->GetSelection();  | ||||
|  | @ -535,21 +519,29 @@ void PointCtrl::set_value(const Pointf value) | |||
| void PointCtrl::set_value(boost::any value) | ||||
| { | ||||
| 	Pointf pt; | ||||
| 	try | ||||
| 	Pointf *ptf = boost::any_cast<Pointf>(&value); | ||||
| 	if (!ptf) | ||||
| 	{ | ||||
| 		pt = boost::any_cast<ConfigOptionPoints*>(value)->values.at(0); | ||||
| 		ConfigOptionPoints* pts = boost::any_cast<ConfigOptionPoints*>(value); | ||||
| 		pt = pts->values.at(0); | ||||
| 	} | ||||
| 	catch (const std::exception &e) | ||||
| 	{ | ||||
| 		try{ | ||||
| 			pt = boost::any_cast<Pointf>(value); | ||||
| 		} | ||||
| 		catch (const std::exception &e) | ||||
| 		{ | ||||
| 			std::cerr << "Error! Can't cast PointCtrl value" << m_opt_id << "\n"; | ||||
| 			return; | ||||
| 		}		 | ||||
| 	}	 | ||||
| 	else | ||||
| 		pt = *ptf; | ||||
| // 	try
 | ||||
| // 	{
 | ||||
| // 		pt = boost::any_cast<ConfigOptionPoints*>(value)->values.at(0);
 | ||||
| // 	}
 | ||||
| // 	catch (const std::exception &e)
 | ||||
| // 	{
 | ||||
| // 		try{
 | ||||
| // 			pt = boost::any_cast<Pointf>(value);
 | ||||
| // 		}
 | ||||
| // 		catch (const std::exception &e)
 | ||||
| // 		{
 | ||||
| // 			std::cerr << "Error! Can't cast PointCtrl value" << m_opt_id << "\n";
 | ||||
| // 			return;
 | ||||
| // 		}		
 | ||||
| // 	}	
 | ||||
| 	set_value(pt); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -26,6 +26,8 @@ using t_field = std::unique_ptr<Field>; | |||
| using t_kill_focus = std::function<void()>; | ||||
| using t_change = std::function<void(t_config_option_key, boost::any)>; | ||||
| 
 | ||||
| wxString double_to_string(double const value); | ||||
| 
 | ||||
| class Field { | ||||
| protected: | ||||
|     // factory function to defer and enforce creation of derived type. 
 | ||||
|  | @ -83,7 +85,7 @@ public: | |||
|     virtual wxWindow*	getWindow() { return nullptr; } | ||||
| 
 | ||||
| 	bool		is_matched(std::string string, std::string pattern); | ||||
| 	boost::any	get_value_by_opt_type(wxString str, ConfigOptionType type); | ||||
| 	boost::any get_value_by_opt_type(wxString str); | ||||
| 
 | ||||
|     /// Factory method for generating new derived classes.
 | ||||
|     template<class T> | ||||
|  |  | |||
|  | @ -28,7 +28,6 @@ | |||
| 
 | ||||
| #include <wx/app.h> | ||||
| #include <wx/button.h> | ||||
| #include <wx/config.h> | ||||
| #include <wx/dir.h> | ||||
| #include <wx/filename.h> | ||||
| #include <wx/frame.h> | ||||
|  | @ -45,6 +44,7 @@ | |||
| #include "TabIface.hpp" | ||||
| #include "AppConfig.hpp" | ||||
| #include "Utils.hpp" | ||||
| #include "Preferences.hpp" | ||||
| 
 | ||||
| namespace Slic3r { namespace GUI { | ||||
| 
 | ||||
|  | @ -171,6 +171,7 @@ void break_to_debugger() | |||
| wxApp       *g_wxApp        = nullptr; | ||||
| wxFrame     *g_wxMainFrame  = nullptr; | ||||
| wxNotebook  *g_wxTabPanel   = nullptr; | ||||
| AppConfig	*g_AppConfig	= nullptr; | ||||
| 
 | ||||
| std::vector<Tab *> g_tabs_list; | ||||
| 
 | ||||
|  | @ -191,6 +192,11 @@ void set_tab_panel(wxNotebook *tab_panel) | |||
|     g_wxTabPanel = tab_panel; | ||||
| } | ||||
| 
 | ||||
| void set_app_config(AppConfig *app_config) | ||||
| { | ||||
| 	g_AppConfig = app_config; | ||||
| } | ||||
| 
 | ||||
| std::vector<Tab *>& get_tabs_list() | ||||
| { | ||||
| 	return g_tabs_list; | ||||
|  | @ -215,7 +221,7 @@ bool select_language(wxArrayString & names, | |||
| 	wxArrayLong & identifiers) | ||||
| { | ||||
| 	wxCHECK_MSG(names.Count() == identifiers.Count(), false, | ||||
| 		_L("Array of language names and identifiers should have the same size.")); | ||||
| 		_(L("Array of language names and identifiers should have the same size."))); | ||||
| 	int init_selection = 0; | ||||
| 	long current_language = g_wxLocale ? g_wxLocale->GetLanguage() : wxLANGUAGE_UNKNOWN; | ||||
| 	for (auto lang : identifiers){ | ||||
|  | @ -226,7 +232,7 @@ bool select_language(wxArrayString & names, | |||
| 	} | ||||
| 	if (init_selection == identifiers.size()) | ||||
| 		init_selection = 0; | ||||
| 	long index = wxGetSingleChoiceIndex(_L("Select the language"), _L("Language"),  | ||||
| 	long index = wxGetSingleChoiceIndex(_(L("Select the language")), _(L("Language")),  | ||||
| 										names, init_selection); | ||||
| 	if (index != -1) | ||||
| 	{ | ||||
|  | @ -241,13 +247,14 @@ bool select_language(wxArrayString & names, | |||
| 
 | ||||
| bool load_language() | ||||
| { | ||||
| 	wxConfig config(g_wxApp->GetAppName()); | ||||
| 	long language; | ||||
| 	if (!config.Read(wxT("wxTranslation_Language"), | ||||
| 		&language, wxLANGUAGE_UNKNOWN)) | ||||
| 	{ | ||||
| 	if (!g_AppConfig->has("translation_language")) | ||||
| 		language = wxLANGUAGE_UNKNOWN; | ||||
| 	else { | ||||
| 		auto str_language = g_AppConfig->get("translation_language"); | ||||
| 		language = str_language != "" ? stol(str_language) : wxLANGUAGE_UNKNOWN; | ||||
| 	} | ||||
| 
 | ||||
| 	if (language == wxLANGUAGE_UNKNOWN)  | ||||
| 		return false; | ||||
| 	wxArrayString	names; | ||||
|  | @ -269,13 +276,13 @@ bool load_language() | |||
| 
 | ||||
| void save_language() | ||||
| { | ||||
| 	wxConfig config(g_wxApp->GetAppName()); | ||||
| 	long language = wxLANGUAGE_UNKNOWN; | ||||
| 	if (g_wxLocale)	{ | ||||
| 		language = g_wxLocale->GetLanguage(); | ||||
| 	} | ||||
| 	config.Write(wxT("wxTranslation_Language"), language); | ||||
| 	config.Flush(); | ||||
| 	std::string str_language = std::to_string(language); | ||||
| 	g_AppConfig->set("translation_language", str_language); | ||||
| 	g_AppConfig->save(); | ||||
| } | ||||
| 
 | ||||
| void get_installed_languages(wxArrayString & names, | ||||
|  | @ -290,15 +297,12 @@ void get_installed_languages(wxArrayString & names, | |||
| 	wxString name = wxLocale::GetLanguageName(wxLANGUAGE_DEFAULT); | ||||
| 	if (!name.IsEmpty()) | ||||
| 	{ | ||||
| 		names.Add(_L("Default")); | ||||
| 		names.Add(_(L("Default"))); | ||||
| 		identifiers.Add(wxLANGUAGE_DEFAULT); | ||||
| 	} | ||||
| 	for (bool cont = dir.GetFirst(&filename, wxEmptyString, wxDIR_DIRS); | ||||
| 		cont; cont = dir.GetNext(&filename)) | ||||
| 	{ | ||||
| 		wxLogTrace(wxTraceMask(), | ||||
| 			"L10n: Directory found = \"%s\"", | ||||
| 			filename.GetData()); | ||||
| 		langinfo = wxLocale::FindLanguageInfo(filename); | ||||
| 		if (langinfo != NULL) | ||||
| 		{ | ||||
|  | @ -318,14 +322,14 @@ void add_debug_menu(wxMenuBar *menu, int event_language_change) | |||
| { | ||||
| //#if 0
 | ||||
|     auto local_menu = new wxMenu(); | ||||
| 	local_menu->Append(wxWindow::NewControlId(1), _L("Change Application Language")); | ||||
| 	local_menu->Append(wxWindow::NewControlId(1), _(L("Change Application Language"))); | ||||
| 	local_menu->Bind(wxEVT_MENU, [event_language_change](wxEvent&){ | ||||
| 		wxArrayString names; | ||||
| 		wxArrayLong identifiers; | ||||
| 		get_installed_languages(names, identifiers); | ||||
| 		if (select_language(names, identifiers)){ | ||||
| 			save_language(); | ||||
| 			show_info(g_wxTabPanel, "Application will be restarted", "Attention!"); | ||||
| 			show_info(g_wxTabPanel, _(L("Application will be restarted")), _(L("Attention!"))); | ||||
| 			if (event_language_change > 0) { | ||||
| 				wxCommandEvent event(event_language_change); | ||||
| 				g_wxApp->ProcessEvent(event); | ||||
|  | @ -336,15 +340,21 @@ void add_debug_menu(wxMenuBar *menu, int event_language_change) | |||
| //#endif
 | ||||
| } | ||||
| 
 | ||||
| void create_preset_tabs(PresetBundle *preset_bundle, AppConfig *app_config, | ||||
| void open_preferences_dialog(int event_preferences) | ||||
| { | ||||
| 	auto dlg = new PreferencesDialog(g_wxMainFrame, event_preferences); | ||||
| 	dlg->ShowModal(); | ||||
| } | ||||
| 
 | ||||
| void create_preset_tabs(PresetBundle *preset_bundle, | ||||
| 						bool no_controller, bool is_disabled_button_browse, bool is_user_agent, | ||||
| 						int event_value_change, int event_presets_changed, | ||||
| 						int event_button_browse, int event_button_test) | ||||
| {	 | ||||
| 	add_created_tab(new TabPrint	(g_wxTabPanel, no_controller), preset_bundle, app_config); | ||||
| 	add_created_tab(new TabFilament	(g_wxTabPanel, no_controller), preset_bundle, app_config); | ||||
| 	add_created_tab(new TabPrint	(g_wxTabPanel, no_controller), preset_bundle); | ||||
| 	add_created_tab(new TabFilament	(g_wxTabPanel, no_controller), preset_bundle); | ||||
| 	add_created_tab(new TabPrinter	(g_wxTabPanel, no_controller, is_disabled_button_browse, is_user_agent),  | ||||
| 					preset_bundle, app_config); | ||||
| 					preset_bundle); | ||||
| 	for (size_t i = 0; i < g_wxTabPanel->GetPageCount(); ++ i) { | ||||
| 		Tab *tab = dynamic_cast<Tab*>(g_wxTabPanel->GetPage(i)); | ||||
| 		if (! tab) | ||||
|  | @ -378,8 +388,14 @@ void change_opt_value(DynamicPrintConfig& config, t_config_option_key opt_key, b | |||
| 	try{ | ||||
| 		switch (config.def()->get(opt_key)->type){ | ||||
| 		case coFloatOrPercent:{ | ||||
| 			const auto &val = *config.option<ConfigOptionFloatOrPercent>(opt_key); | ||||
| 			config.set_key_value(opt_key, new ConfigOptionFloatOrPercent(boost::any_cast<double>(value), val.percent)); | ||||
| 			std::string str = boost::any_cast<std::string>(value); | ||||
| 			bool percent = false; | ||||
| 			if (str.back() == '%'){ | ||||
| 				str.pop_back(); | ||||
| 				percent = true; | ||||
| 			} | ||||
| 			double val = stod(str); | ||||
| 			config.set_key_value(opt_key, new ConfigOptionFloatOrPercent(val, percent)); | ||||
| 			break;} | ||||
| 		case coPercent: | ||||
| 			config.set_key_value(opt_key, new ConfigOptionPercent(boost::any_cast<double>(value))); | ||||
|  | @ -455,9 +471,9 @@ void change_opt_value(DynamicPrintConfig& config, t_config_option_key opt_key, b | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| void add_created_tab(Tab* panel, PresetBundle *preset_bundle, AppConfig *app_config) | ||||
| void add_created_tab(Tab* panel, PresetBundle *preset_bundle) | ||||
| { | ||||
| 	panel->m_show_btn_incompatible_presets = app_config->get("show_incompatible_presets").empty(); | ||||
| 	panel->m_show_btn_incompatible_presets = g_AppConfig->get("show_incompatible_presets").empty(); | ||||
| 	panel->create_preset_tab(preset_bundle); | ||||
| 
 | ||||
| 	// Load the currently selected preset into the GUI, update the preset selection box.
 | ||||
|  | @ -466,15 +482,22 @@ void add_created_tab(Tab* panel, PresetBundle *preset_bundle, AppConfig *app_con | |||
| } | ||||
| 
 | ||||
| void show_error(wxWindow* parent, wxString message){ | ||||
| 	auto msg_wingow = new wxMessageDialog(parent, message, _L("Error"), wxOK | wxICON_ERROR); | ||||
| 	auto msg_wingow = new wxMessageDialog(parent, message, _(L("Error")), wxOK | wxICON_ERROR); | ||||
| 	msg_wingow->ShowModal(); | ||||
| } | ||||
| 
 | ||||
| void show_info(wxWindow* parent, wxString message, wxString title){ | ||||
| 	auto msg_wingow = new wxMessageDialog(parent, message, title.empty() ? _L("Notice") : title, wxOK | wxICON_INFORMATION); | ||||
| 	auto msg_wingow = new wxMessageDialog(parent, message, title.empty() ? _(L("Notice")) : title, wxOK | wxICON_INFORMATION); | ||||
| 	msg_wingow->ShowModal(); | ||||
| } | ||||
| 
 | ||||
| void warning_catcher(wxWindow* parent, wxString message){ | ||||
| 	if (message == _(L("GLUquadricObjPtr | Attempt to free unreferenced scalar")) ) | ||||
| 		return; | ||||
| 	auto msg = new wxMessageDialog(parent, message, _(L("Warning")), wxOK | wxICON_WARNING); | ||||
| 	msg->ShowModal();	 | ||||
| } | ||||
| 
 | ||||
| wxApp* get_app(){ | ||||
| 	return g_wxApp; | ||||
| } | ||||
|  | @ -531,4 +554,20 @@ int combochecklist_get_flags(wxComboCtrl* comboCtrl) | |||
|     return flags; | ||||
| } | ||||
| 
 | ||||
| AppConfig* get_app_config() | ||||
| { | ||||
| 	return g_AppConfig; | ||||
| } | ||||
| 
 | ||||
| wxString L_str(std::string str) | ||||
| { | ||||
| 	//! Explicitly specify that the source string is already in UTF-8 encoding
 | ||||
| 	return wxGetTranslation(wxString(str.c_str(), wxConvUTF8)); | ||||
| } | ||||
| 
 | ||||
| wxString from_u8(std::string str) | ||||
| { | ||||
| 	return wxString::FromUTF8(str.c_str()); | ||||
| } | ||||
| 
 | ||||
| } } | ||||
|  |  | |||
|  | @ -23,10 +23,16 @@ class AppConfig; | |||
| class DynamicPrintConfig; | ||||
| class TabIface; | ||||
| 
 | ||||
| //! macro used to localization, return wxString
 | ||||
| #define _L(s) wxGetTranslation(s) | ||||
| //! macro used to localization, return const CharType *
 | ||||
| #define _LU8(s) wxGetTranslation(s).ToUTF8().data() | ||||
| // !!! If you needed to translate some wxString,
 | ||||
| // !!! please use _(L(string))
 | ||||
| // !!! _() - is a standard wxWidgets macro to translate
 | ||||
| // !!! L() is used only for marking localizable string 
 | ||||
| // !!! It will be used in "xgettext" to create a Locating Message Catalog.
 | ||||
| #define L(s) s | ||||
| 
 | ||||
| //! macro used to localization, return wxScopedCharBuffer
 | ||||
| //! With wxConvUTF8 explicitly specify that the source string is already in UTF-8 encoding
 | ||||
| #define _CHB(s) wxGetTranslation(wxString(s, wxConvUTF8)).utf8_str() | ||||
| 
 | ||||
| namespace GUI { | ||||
| 
 | ||||
|  | @ -59,22 +65,31 @@ void break_to_debugger(); | |||
| void set_wxapp(wxApp *app); | ||||
| void set_main_frame(wxFrame *main_frame); | ||||
| void set_tab_panel(wxNotebook *tab_panel); | ||||
| void set_app_config(AppConfig *app_config); | ||||
| 
 | ||||
| AppConfig*	get_app_config(); | ||||
| wxApp*		get_app(); | ||||
| 
 | ||||
| void add_debug_menu(wxMenuBar *menu, int event_language_change); | ||||
| 
 | ||||
| // Create "Preferences" dialog after selecting menu "Preferences" in Perl part
 | ||||
| void open_preferences_dialog(int event_preferences); | ||||
| 
 | ||||
| // Create a new preset tab (print, filament and printer),
 | ||||
| void create_preset_tabs(PresetBundle *preset_bundle, AppConfig *app_config,  | ||||
| void create_preset_tabs(PresetBundle *preset_bundle,  | ||||
| 						bool no_controller, bool is_disabled_button_browse,	bool is_user_agent, | ||||
| 						int event_value_change, int event_presets_changed, | ||||
| 						int event_button_browse, int event_button_test); | ||||
| TabIface* get_preset_tab_iface(char *name); | ||||
| 
 | ||||
| // add it at the end of the tab panel.
 | ||||
| void add_created_tab(Tab* panel, PresetBundle *preset_bundle, AppConfig *app_config); | ||||
| void add_created_tab(Tab* panel, PresetBundle *preset_bundle); | ||||
| // Change option value in config
 | ||||
| void change_opt_value(DynamicPrintConfig& config, t_config_option_key opt_key, boost::any value, int opt_index = 0); | ||||
| 
 | ||||
| void show_error(wxWindow* parent, wxString message); | ||||
| void show_info(wxWindow* parent, wxString message, wxString title); | ||||
| void warning_catcher(wxWindow* parent, wxString message); | ||||
| 
 | ||||
| // load language saved at application config 
 | ||||
| bool load_language(); | ||||
|  | @ -98,6 +113,11 @@ void create_combochecklist(wxComboCtrl* comboCtrl, std::string text, std::string | |||
| // encoded inside an int.
 | ||||
| int combochecklist_get_flags(wxComboCtrl* comboCtrl); | ||||
| 
 | ||||
| // Return translated std::string as a wxString
 | ||||
| wxString	L_str(std::string str); | ||||
| // Return wxString from std::string in UTF8
 | ||||
| wxString	from_u8(std::string str); | ||||
| 
 | ||||
| } | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -2,7 +2,6 @@ | |||
| #include "ConfigExceptions.hpp" | ||||
| 
 | ||||
| #include <utility> | ||||
| #include <wx/tooltip.h> | ||||
| #include <wx/numformatter.h> | ||||
| 
 | ||||
| namespace Slic3r { namespace GUI { | ||||
|  | @ -122,13 +121,13 @@ void OptionsGroup::append_line(const Line& line) { | |||
|     } | ||||
| 
 | ||||
|     // If there's a widget, build it and add the result to the sizer.
 | ||||
|     if (line.widget != nullptr) { | ||||
|         auto wgt = line.widget(parent()); | ||||
| 	if (line.widget != nullptr) { | ||||
| 		auto wgt = line.widget(parent()); | ||||
| 		grid_sizer->Add(wgt, 0, wxEXPAND | wxBOTTOM | wxTOP, wxOSX ? 0 : 5); | ||||
|         return; | ||||
|     } | ||||
|      | ||||
|     // if we have a single option with no sidetext just add it directly to the grid sizer
 | ||||
| 		return; | ||||
| 	} | ||||
| 	 | ||||
| 	// if we have a single option with no sidetext just add it directly to the grid sizer
 | ||||
|     if (option_set.size() == 1 && option_set.front().opt.sidetext.size() == 0 && | ||||
|         option_set.front().side_widget == nullptr && line.get_extra_widgets().size() == 0) { | ||||
|         const auto& option = option_set.front(); | ||||
|  | @ -152,7 +151,7 @@ void OptionsGroup::append_line(const Line& line) { | |||
| 		ConfigOptionDef option = opt.opt; | ||||
| 		// add label if any
 | ||||
| 		if (option.label != "") { | ||||
| 			auto field_label = new wxStaticText(parent(), wxID_ANY, wxString::FromUTF8(option.label.c_str()) + ":", wxDefaultPosition, wxDefaultSize); | ||||
| 			auto field_label = new wxStaticText(parent(), wxID_ANY, L_str(option.label) + ":", wxDefaultPosition, wxDefaultSize); | ||||
| 			field_label->SetFont(label_font); | ||||
| 			sizer->Add(field_label, 0, wxALIGN_CENTER_VERTICAL, 0); | ||||
| 		} | ||||
|  | @ -166,7 +165,7 @@ void OptionsGroup::append_line(const Line& line) { | |||
| 		 | ||||
| 		// add sidetext if any
 | ||||
| 		if (option.sidetext != "") { | ||||
| 			auto sidetext = new wxStaticText(parent(), wxID_ANY, wxString::FromUTF8(option.sidetext.c_str()), wxDefaultPosition, wxDefaultSize); | ||||
| 			auto sidetext = new wxStaticText(parent(), wxID_ANY, L_str(option.sidetext), wxDefaultPosition, wxDefaultSize); | ||||
| 			sidetext->SetFont(sidetext_font); | ||||
| 			sizer->Add(sidetext, 0, wxLEFT | wxALIGN_CENTER_VERTICAL, 4); | ||||
| 		} | ||||
|  | @ -188,7 +187,7 @@ void OptionsGroup::append_line(const Line& line) { | |||
| } | ||||
| 
 | ||||
| Line OptionsGroup::create_single_option_line(const Option& option) const { | ||||
| 	Line retval{ wxString::FromUTF8(option.opt.label.c_str()), wxString::FromUTF8(option.opt.tooltip.c_str()) }; | ||||
| 	Line retval{ L_str(option.opt.label), L_str(option.opt.tooltip) }; | ||||
|     Option tmp(option); | ||||
|     tmp.opt.label = std::string(""); | ||||
|     retval.append_option(tmp); | ||||
|  | @ -203,7 +202,7 @@ void OptionsGroup::on_change_OG(t_config_option_key id, /*config_value*/boost::a | |||
| Option ConfigOptionsGroup::get_option(const std::string opt_key, int opt_index /*= -1*/) | ||||
| { | ||||
| 	if (!m_config->has(opt_key)) { | ||||
| 		//! exception  ("No $opt_key in ConfigOptionsGroup config");
 | ||||
| 		std::cerr << "No " << opt_key << " in ConfigOptionsGroup config."; | ||||
| 	} | ||||
| 
 | ||||
| 	std::string opt_id = opt_index == -1 ? opt_key : opt_key + "#" + std::to_string(opt_index); | ||||
|  | @ -287,14 +286,6 @@ boost::any ConfigOptionsGroup::config_value(std::string opt_key, int opt_index, | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| wxString double_to_string(double const value) | ||||
| { | ||||
| 	int precision = 10 * value - int(10 * value) == 0 ? 1 : 2;  | ||||
| 	return value - int(value) == 0 ? | ||||
| 		wxString::Format(_T("%i"), int(value)) : | ||||
| 		wxNumberFormatter::ToString(value, precision, wxNumberFormatter::Style_None); | ||||
| } | ||||
| 
 | ||||
| boost::any ConfigOptionsGroup::get_config_value(DynamicPrintConfig& config, std::string opt_key, int opt_index/* = -1*/) | ||||
| { | ||||
| 	size_t idx = opt_index == -1 ? 0 : opt_index; | ||||
|  | @ -325,9 +316,9 @@ boost::any ConfigOptionsGroup::get_config_value(DynamicPrintConfig& config, std: | |||
| 	case coFloats: | ||||
| 	case coFloat:{ | ||||
| 		double val = opt->type == coFloats ? | ||||
| 					config.opt_float(opt_key, idx/*0opt_index*/) : | ||||
| 					config.opt_float(opt_key, idx) : | ||||
| 						opt->type == coFloat ? config.opt_float(opt_key) : | ||||
| 						config.option<ConfigOptionPercents>(opt_key)->values.at(idx/*0*/); | ||||
| 						config.option<ConfigOptionPercents>(opt_key)->values.at(idx); | ||||
| 		ret = double_to_string(val); | ||||
| 		} | ||||
| 		break; | ||||
|  | @ -338,19 +329,19 @@ boost::any ConfigOptionsGroup::get_config_value(DynamicPrintConfig& config, std: | |||
| 		if (config.option<ConfigOptionStrings>(opt_key)->values.empty()) | ||||
| 			ret = text_value; | ||||
| 		else | ||||
| 			ret = static_cast<wxString>(config.opt_string(opt_key, static_cast<unsigned int>(idx/*0*/)/*opt_index*/)); | ||||
| 			ret = static_cast<wxString>(config.opt_string(opt_key, static_cast<unsigned int>(idx))); | ||||
| 		break; | ||||
| 	case coBool: | ||||
| 		ret = config.opt_bool(opt_key); | ||||
| 		break; | ||||
| 	case coBools: | ||||
| 		ret = config.opt_bool(opt_key, idx/*0opt_index*/); | ||||
| 		ret = config.opt_bool(opt_key, idx); | ||||
| 		break; | ||||
| 	case coInt: | ||||
| 		ret = config.opt_int(opt_key); | ||||
| 		break; | ||||
| 	case coInts: | ||||
| 		ret = config.opt_int(opt_key, idx/*0/*opt_index*/); | ||||
| 		ret = config.opt_int(opt_key, idx); | ||||
| 		break; | ||||
| 	case coEnum:{ | ||||
| 		if (opt_key.compare("external_fill_pattern") == 0 || | ||||
|  | @ -369,7 +360,7 @@ boost::any ConfigOptionsGroup::get_config_value(DynamicPrintConfig& config, std: | |||
| 		break; | ||||
| 	case coPoints:{ | ||||
| 		const auto &value = *config.option<ConfigOptionPoints>(opt_key); | ||||
| 		ret = value.values.at(idx/*0*/); | ||||
| 		ret = value.values.at(idx); | ||||
| 		} | ||||
| 		break; | ||||
| 	case coNone: | ||||
|  | @ -397,14 +388,5 @@ void ogStaticText::SetText(wxString value) | |||
| 	GetParent()->Layout(); | ||||
| } | ||||
| 
 | ||||
| void Option::translate() | ||||
| { | ||||
| 	opt.label = _LU8(opt.label); | ||||
| 	opt.tooltip = _LU8(opt.tooltip); | ||||
| 	opt.sidetext = _LU8(opt.sidetext); | ||||
| 	opt.full_label = _LU8(opt.full_label); | ||||
| 	opt.category = _LU8(opt.category); | ||||
| } | ||||
| 
 | ||||
| } // GUI
 | ||||
| } // Slic3r
 | ||||
|  |  | |||
|  | @ -35,8 +35,7 @@ struct Option { | |||
|     bool					readonly {false}; | ||||
| 
 | ||||
| 	Option(const ConfigOptionDef& _opt, t_config_option_key id) : | ||||
| 		opt(_opt), opt_id(id) { translate(); } | ||||
| 	void		translate(); | ||||
| 		opt(_opt), opt_id(id) {} | ||||
| }; | ||||
| using t_option = std::unique_ptr<Option>;	//!
 | ||||
| 
 | ||||
|  | @ -90,9 +89,22 @@ public: | |||
|     void		append_single_option_line(const Option& option) { append_line(create_single_option_line(option)); } | ||||
| 
 | ||||
|     // return a non-owning pointer reference 
 | ||||
|     inline /*const*/ Field*	get_field(t_config_option_key id) const { try { return m_fields.at(id).get(); } catch (std::out_of_range e) { return nullptr; } } | ||||
| 	bool			set_value(t_config_option_key id, boost::any value) { try { m_fields.at(id)->set_value(value); return true; } catch (std::out_of_range e) { return false; } } | ||||
| 	boost::any		get_value(t_config_option_key id) { boost::any out; try { out = m_fields.at(id)->get_value(); } catch (std::out_of_range e) { ; } return out; } | ||||
|     inline Field*	get_field(t_config_option_key id) const{ | ||||
| 							if (m_fields.find(id) == m_fields.end()) return nullptr; | ||||
| 							return m_fields.at(id).get(); | ||||
|     } | ||||
| 	bool			set_value(t_config_option_key id, boost::any value) { | ||||
| 							if (m_fields.find(id) == m_fields.end()) return false; | ||||
| 							m_fields.at(id)->set_value(value); | ||||
| 							return true; | ||||
|     } | ||||
| 	boost::any		get_value(t_config_option_key id) { | ||||
| 							boost::any out;  | ||||
|     						if (m_fields.find(id) == m_fields.end()) ; | ||||
| 							else  | ||||
| 								out = m_fields.at(id)->get_value(); | ||||
| 							return out; | ||||
|     } | ||||
| 
 | ||||
| 	inline void		enable() { for (auto& field : m_fields) field.second->enable(); } | ||||
|     inline void		disable() { for (auto& field : m_fields) field.second->disable(); } | ||||
|  |  | |||
							
								
								
									
										120
									
								
								xs/src/slic3r/GUI/Preferences.cpp
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										120
									
								
								xs/src/slic3r/GUI/Preferences.cpp
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,120 @@ | |||
| #include "Preferences.hpp" | ||||
| #include "AppConfig.hpp" | ||||
| #include "OptionsGroup.hpp" | ||||
| 
 | ||||
| namespace Slic3r { | ||||
| namespace GUI { | ||||
| 
 | ||||
| void PreferencesDialog::build() | ||||
| { | ||||
| 	auto app_config = get_app_config(); | ||||
| 	m_optgroup = std::make_shared<ConfigOptionsGroup>(this, _(L("General"))); | ||||
| 	m_optgroup->label_width = 200; | ||||
| 	m_optgroup->m_on_change = [this](t_config_option_key opt_key, boost::any value){ | ||||
| 		m_values[opt_key] = boost::any_cast<bool>(value) ? "1" : "0"; | ||||
| 	}; | ||||
| 
 | ||||
| //    $optgroup->append_single_option_line(Slic3r::GUI::OptionsGroup::Option->new(
 | ||||
| //        opt_id = > 'version_check',
 | ||||
| //        type = > 'bool',
 | ||||
| //        label = > 'Check for updates',
 | ||||
| //        tooltip = > 'If this is enabled, Slic3r will check for updates daily and display a reminder if a newer version is available.',
 | ||||
| //        default = > $app_config->get("version_check") // 1,
 | ||||
| //        readonly = > !wxTheApp->have_version_check,
 | ||||
| //    ));
 | ||||
| 
 | ||||
| 	ConfigOptionDef def; | ||||
| 	def.label = L("Remember output directory"); | ||||
| 	def.type = coBool; | ||||
| 	def.tooltip = L("If this is enabled, Slic3r will prompt the last output directory " | ||||
| 					  "instead of the one containing the input files."); | ||||
| 	def.default_value = new ConfigOptionBool{ app_config->get("remember_output_path")[0] == '1' }; // 1;
 | ||||
| 	Option option(def, "remember_output_path"); | ||||
| 	m_optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 	def.label = L("Auto-center parts"); | ||||
| 	def.type = coBool; | ||||
| 	def.tooltip = L("If this is enabled, Slic3r will auto-center objects " | ||||
| 					  "around the print bed center."); | ||||
| 	def.default_value = new ConfigOptionBool{ app_config->get("autocenter")[0] == '1' }; // 1;
 | ||||
| 	option = Option (def,"autocenter"); | ||||
| 	m_optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 	def.label = L("Background processing"); | ||||
| 	def.type = coBool; | ||||
| 	def.tooltip = L("If this is enabled, Slic3r will pre-process objects as soon " | ||||
| 					  "as they\'re loaded in order to save time when exporting G-code."); | ||||
| 	def.default_value = new ConfigOptionBool{ app_config->get("background_processing")[0] == '1' }; // 1;
 | ||||
| 	option = Option (def,"background_processing"); | ||||
| 	m_optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 	def.label = L("Disable USB/serial connection"); | ||||
| 	def.type = coBool; | ||||
| 	def.tooltip = L("Disable communication with the printer over a serial / USB cable. " | ||||
| 					  "This simplifies the user interface in case the printer is never attached to the computer."); | ||||
| 	def.default_value = new ConfigOptionBool{ app_config->get("no_controller")[0] == '1' }; // 1;
 | ||||
| 	option = Option (def,"no_controller"); | ||||
| 	m_optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 	def.label = L("Suppress \" - default - \" presets"); | ||||
| 	def.type = coBool; | ||||
| 	def.tooltip = L("Suppress \" - default - \" presets in the Print / Filament / Printer " | ||||
| 					  "selections once there are any other valid presets available."); | ||||
| 	def.default_value = new ConfigOptionBool{ app_config->get("no_defaults")[0] == '1' }; // 1;
 | ||||
| 	option = Option (def,"no_defaults"); | ||||
| 	m_optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 	def.label = L("Show incompatible print and filament presets"); | ||||
| 	def.type = coBool; | ||||
| 	def.tooltip = L("When checked, the print and filament presets are shown in the preset editor " | ||||
| 					  "even if they are marked as incompatible with the active printer"); | ||||
| 	def.default_value = new ConfigOptionBool{ app_config->get("show_incompatible_presets")[0] == '1' }; // 1;
 | ||||
| 	option = Option (def,"show_incompatible_presets"); | ||||
| 	m_optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 	def.label = L("Use legacy OpenGL 1.1 rendering"); | ||||
| 	def.type = coBool; | ||||
| 	def.tooltip = L("If you have rendering issues caused by a buggy OpenGL 2.0 driver, " | ||||
| 					  "you may try to check this checkbox. This will disable the layer height " | ||||
| 					  "editing and anti aliasing, so it is likely better to upgrade your graphics driver."); | ||||
| 	def.default_value = new ConfigOptionBool{ app_config->get("use_legacy_opengl")[0] == '1' }; // 1;
 | ||||
| 	option = Option (def,"use_legacy_opengl"); | ||||
| 	m_optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 	auto sizer = new wxBoxSizer(wxVERTICAL); | ||||
| 	sizer->Add(m_optgroup->sizer, 0, wxEXPAND | wxBOTTOM | wxLEFT | wxRIGHT, 10); | ||||
| 
 | ||||
| 	auto buttons = CreateStdDialogButtonSizer(wxOK | wxCANCEL); | ||||
| 	wxButton* btn = static_cast<wxButton*>(FindWindowById(wxID_OK, this)); | ||||
| 	btn->Bind(wxEVT_BUTTON, [this](wxCommandEvent&) { accept(); }); | ||||
| 	sizer->Add(buttons, 0, wxALIGN_CENTER_HORIZONTAL | wxBOTTOM, 10); | ||||
| 
 | ||||
| 	SetSizer(sizer); | ||||
| 	sizer->SetSizeHints(this); | ||||
| } | ||||
| 
 | ||||
| void PreferencesDialog::accept() | ||||
| { | ||||
| 	if (m_values.find("no_controller")    != m_values.end()|| | ||||
| 		m_values.find("no_defaults")      != m_values.end()|| | ||||
| 		m_values.find("use_legacy_opengl")!= m_values.end()) { | ||||
| 		warning_catcher(this, _(L("You need to restart Slic3r to make the changes effective."))); | ||||
| 	} | ||||
| 
 | ||||
| 	auto app_config = get_app_config(); | ||||
| 	for (std::map<std::string, std::string>::iterator it = m_values.begin(); it != m_values.end(); ++it) { | ||||
| 		app_config->set(it->first, it->second); | ||||
| 	} | ||||
| 
 | ||||
| 	EndModal(wxID_OK); | ||||
| 	Close();  // needed on Linux
 | ||||
| 
 | ||||
| 	// Nothify the UI to update itself from the ini file.
 | ||||
| 	if (m_event_preferences > 0) { | ||||
| 		wxCommandEvent event(m_event_preferences); | ||||
| 		get_app()->ProcessEvent(event); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| } // GUI
 | ||||
| } // Slic3r
 | ||||
							
								
								
									
										27
									
								
								xs/src/slic3r/GUI/Preferences.hpp
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								xs/src/slic3r/GUI/Preferences.hpp
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,27 @@ | |||
| #include "GUI.hpp" | ||||
| 
 | ||||
| #include <wx/dialog.h> | ||||
| #include <map> | ||||
| 
 | ||||
| namespace Slic3r { | ||||
| namespace GUI { | ||||
| 
 | ||||
| class ConfigOptionsGroup; | ||||
| 
 | ||||
| class PreferencesDialog : public wxDialog | ||||
| { | ||||
| 	std::map<std::string, std::string>	m_values; | ||||
| 	std::shared_ptr<ConfigOptionsGroup>	m_optgroup; | ||||
| 	int		m_event_preferences; | ||||
| public: | ||||
| 	PreferencesDialog(wxWindow* parent, int event_preferences) : wxDialog(parent, wxID_ANY, _(L("Preferences")), | ||||
| 		wxDefaultPosition, wxDefaultSize), m_event_preferences(event_preferences) {	build(); } | ||||
| 	~PreferencesDialog(){ } | ||||
| 
 | ||||
| 	void	build(); | ||||
| 	void	accept(); | ||||
| }; | ||||
| 
 | ||||
| } // GUI
 | ||||
| } // Slic3r
 | ||||
| 
 | ||||
|  | @ -6,8 +6,10 @@ | |||
| #include "Flow.hpp" | ||||
| 
 | ||||
| #include <boost/algorithm/string/predicate.hpp> | ||||
| #include <wx/intl.h>  | ||||
| 
 | ||||
| #include "../../libslic3r/libslic3r.h" | ||||
| #include "GUI.hpp" | ||||
| 
 | ||||
| namespace Slic3r { | ||||
| 
 | ||||
|  | @ -21,31 +23,31 @@ std::string PresetHints::cooling_description(const Preset &preset) | |||
| 		int 	max_fan_speed 				= preset.config.opt_int("max_fan_speed", 0); | ||||
| 		int 	min_print_speed				= int(preset.config.opt_float("min_print_speed", 0) + 0.5); | ||||
| 		int 	fan_below_layer_time		= preset.config.opt_int("fan_below_layer_time", 0); | ||||
| 		sprintf(buf, "If estimated layer time is below ~%ds, fan will run at %d%% and print speed will be reduced so that no less than %ds are spent on that layer (however, speed will never be reduced below %dmm/s).", | ||||
| 		sprintf(buf, _CHB(L("If estimated layer time is below ~%ds, fan will run at %d%% and print speed will be reduced so that no less than %ds are spent on that layer (however, speed will never be reduced below %dmm/s).")), | ||||
|             slowdown_below_layer_time, max_fan_speed, slowdown_below_layer_time, min_print_speed); | ||||
| 		out += buf; | ||||
|         if (fan_below_layer_time > slowdown_below_layer_time) { | ||||
|             sprintf(buf, "\nIf estimated layer time is greater, but still below ~%ds, fan will run at a proportionally decreasing speed between %d%% and %d%%.", | ||||
| 			sprintf(buf, _CHB(L("\nIf estimated layer time is greater, but still below ~%ds, fan will run at a proportionally decreasing speed between %d%% and %d%%.")), | ||||
|                 fan_below_layer_time, max_fan_speed, min_fan_speed); | ||||
|             out += buf; | ||||
|         } | ||||
|         out += "\nDuring the other layers, fan "; | ||||
| 		out += _CHB(L("\nDuring the other layers, fan ")); | ||||
|     } else { | ||||
|         out = "Fan "; | ||||
|         out = _CHB(L("Fan ")); | ||||
|     } | ||||
| 	if (preset.config.opt_bool("fan_always_on", 0)) { | ||||
| 		int 	disable_fan_first_layers 	= preset.config.opt_int("disable_fan_first_layers", 0); | ||||
| 		int 	min_fan_speed 				= preset.config.opt_int("min_fan_speed", 0); | ||||
|         sprintf(buf, "will always run at %d%% ", min_fan_speed); | ||||
|         sprintf(buf, _CHB(L("will always run at %d%% ")), min_fan_speed); | ||||
|         out += buf; | ||||
|         if (disable_fan_first_layers > 1) { | ||||
|         	sprintf(buf, "except for the first %d layers", disable_fan_first_layers); | ||||
|         	sprintf(buf, _CHB(L("except for the first %d layers")), disable_fan_first_layers); | ||||
| 	        out += buf; | ||||
|         } | ||||
|         else if (disable_fan_first_layers == 1) | ||||
|         	out += "except for the first layer"; | ||||
|         	out += _CHB(L("except for the first layer")); | ||||
|     } else | ||||
|     	out += "will be turned off."; | ||||
|     	out += _CHB(L("will be turned off.")); | ||||
| 
 | ||||
|     return out; | ||||
| } | ||||
|  | @ -146,7 +148,7 @@ std::string PresetHints::maximum_volumetric_flow_description(const PresetBundle | |||
|                     limit_by_first_layer_speed(std::max(external_perimeter_speed, small_perimeter_speed), max_print_speed)); | ||||
|             if (max_flow < external_perimeter_rate) { | ||||
|                 max_flow = external_perimeter_rate; | ||||
|                 max_flow_extrusion_type = "external perimeters"; | ||||
|                 max_flow_extrusion_type = _CHB(L("external perimeters")); | ||||
|             } | ||||
|             double perimeter_rate = Flow::new_from_config_width(frPerimeter,  | ||||
|                 first_positive(first_layer_extrusion_width_ptr, perimeter_extrusion_width, extrusion_width),  | ||||
|  | @ -155,7 +157,7 @@ std::string PresetHints::maximum_volumetric_flow_description(const PresetBundle | |||
|                     limit_by_first_layer_speed(std::max(perimeter_speed, small_perimeter_speed), max_print_speed)); | ||||
|             if (max_flow < perimeter_rate) { | ||||
|                 max_flow = perimeter_rate; | ||||
|                 max_flow_extrusion_type = "perimeters"; | ||||
|                 max_flow_extrusion_type = _CHB(L("perimeters")); | ||||
|             } | ||||
|         } | ||||
|         if (! bridging && infill_extruder_active) { | ||||
|  | @ -164,7 +166,7 @@ std::string PresetHints::maximum_volumetric_flow_description(const PresetBundle | |||
|                 nozzle_diameter, lh, bfr).mm3_per_mm() * limit_by_first_layer_speed(infill_speed, max_print_speed); | ||||
|             if (max_flow < infill_rate) { | ||||
|                 max_flow = infill_rate; | ||||
|                 max_flow_extrusion_type = "infill"; | ||||
|                 max_flow_extrusion_type = _CHB(L("infill")); | ||||
|             } | ||||
|         } | ||||
|         if (solid_infill_extruder_active) { | ||||
|  | @ -174,7 +176,7 @@ std::string PresetHints::maximum_volumetric_flow_description(const PresetBundle | |||
|                 (bridging ? bridge_speed : limit_by_first_layer_speed(solid_infill_speed, max_print_speed)); | ||||
|             if (max_flow < solid_infill_rate) { | ||||
|                 max_flow = solid_infill_rate; | ||||
|                 max_flow_extrusion_type = "solid infill"; | ||||
|                 max_flow_extrusion_type = _CHB(L("solid infill")); | ||||
|             } | ||||
|             if (! bridging) { | ||||
|                 double top_solid_infill_rate = Flow::new_from_config_width(frInfill,  | ||||
|  | @ -182,7 +184,7 @@ std::string PresetHints::maximum_volumetric_flow_description(const PresetBundle | |||
|                     nozzle_diameter, lh, bfr).mm3_per_mm() * limit_by_first_layer_speed(top_solid_infill_speed, max_print_speed); | ||||
|                 if (max_flow < top_solid_infill_rate) { | ||||
|                     max_flow = top_solid_infill_rate; | ||||
|                     max_flow_extrusion_type = "top solid infill"; | ||||
|                     max_flow_extrusion_type = _CHB(L("top solid infill")); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | @ -193,7 +195,7 @@ std::string PresetHints::maximum_volumetric_flow_description(const PresetBundle | |||
|                 (bridging ? bridge_speed : limit_by_first_layer_speed(support_material_speed, max_print_speed)); | ||||
|             if (max_flow < support_material_rate) { | ||||
|                 max_flow = support_material_rate; | ||||
|                 max_flow_extrusion_type = "support"; | ||||
|                 max_flow_extrusion_type = _CHB(L("support")); | ||||
|             } | ||||
|         } | ||||
|         if (support_material_interface_extruder_active) { | ||||
|  | @ -203,25 +205,25 @@ std::string PresetHints::maximum_volumetric_flow_description(const PresetBundle | |||
|                 (bridging ? bridge_speed : limit_by_first_layer_speed(support_material_interface_speed, max_print_speed)); | ||||
|             if (max_flow < support_material_interface_rate) { | ||||
|                 max_flow = support_material_interface_rate; | ||||
|                 max_flow_extrusion_type = "support interface"; | ||||
|                 max_flow_extrusion_type = _CHB(L("support interface")); | ||||
|             } | ||||
|         } | ||||
|         //FIXME handle gap_fill_speed
 | ||||
|         if (! out.empty()) | ||||
|             out += "\n"; | ||||
|         out += (first_layer ? "First layer volumetric" : (bridging ? "Bridging volumetric" : "Volumetric")); | ||||
|         out += " flow rate is maximized "; | ||||
|         out += (first_layer ? _CHB(L("First layer volumetric")) : (bridging ? _CHB(L("Bridging volumetric")) : _CHB(L("Volumetric")))); | ||||
|         out += _CHB(L(" flow rate is maximized ")); | ||||
|         bool limited_by_max_volumetric_speed = max_volumetric_speed > 0 && max_volumetric_speed < max_flow; | ||||
|         out += (limited_by_max_volumetric_speed ?  | ||||
|             "by the print profile maximum" :  | ||||
|             ("when printing " + max_flow_extrusion_type)) | ||||
|             + " with a volumetric rate "; | ||||
|             _CHB(L("by the print profile maximum")) :  | ||||
|             (_CHB(L("when printing ")) + max_flow_extrusion_type)) | ||||
|             + _CHB(L(" with a volumetric rate ")); | ||||
|         if (limited_by_max_volumetric_speed) | ||||
|             max_flow = max_volumetric_speed; | ||||
|         char buf[2048]; | ||||
|         sprintf(buf, "%3.2f mm³/s", max_flow); | ||||
|         sprintf(buf, _CHB(L("%3.2f mm³/s")), max_flow); | ||||
|         out += buf; | ||||
|         sprintf(buf, " at filament speed %3.2f mm/s.", max_flow / filament_crossection); | ||||
|         sprintf(buf, _CHB(L(" at filament speed %3.2f mm/s.")), max_flow / filament_crossection); | ||||
|         out += buf; | ||||
|     } | ||||
| 
 | ||||
|  | @ -238,8 +240,11 @@ std::string PresetHints::recommended_thin_wall_thickness(const PresetBundle &pre | |||
|     bool    thin_walls                          = print_config.opt_bool("thin_walls"); | ||||
|     float   nozzle_diameter                     = float(printer_config.opt_float("nozzle_diameter", 0)); | ||||
|      | ||||
|     if (layer_height <= 0.f) | ||||
|         return "Recommended object thin wall thickness: Not available due to invalid layer height."; | ||||
|     std::string out; | ||||
| 	if (layer_height <= 0.f){ | ||||
| 		out += _CHB(L("Recommended object thin wall thickness: Not available due to invalid layer height.")); | ||||
| 		return out; | ||||
| 	} | ||||
| 
 | ||||
|     Flow    external_perimeter_flow             = Flow::new_from_config_width( | ||||
|         frExternalPerimeter,  | ||||
|  | @ -250,18 +255,18 @@ std::string PresetHints::recommended_thin_wall_thickness(const PresetBundle &pre | |||
|         *print_config.opt<ConfigOptionFloatOrPercent>("perimeter_extrusion_width"),  | ||||
|         nozzle_diameter, layer_height, false); | ||||
| 
 | ||||
|     std::string out; | ||||
|      | ||||
|     if (num_perimeters > 0) { | ||||
|         int num_lines = std::min(num_perimeters * 2, 10); | ||||
|         char buf[256]; | ||||
|         sprintf(buf, "Recommended object thin wall thickness for layer height %.2f and ", layer_height); | ||||
|         sprintf(buf, _CHB(L("Recommended object thin wall thickness for layer height %.2f and ")), layer_height); | ||||
|         out += buf; | ||||
|         // Start with the width of two closely spaced 
 | ||||
|         double width = external_perimeter_flow.width + external_perimeter_flow.spacing(); | ||||
|         for (int i = 2; i <= num_lines; thin_walls ? ++ i : i += 2) { | ||||
|             if (i > 2) | ||||
|                 out += ", "; | ||||
|             sprintf(buf, "%d lines: %.2lf mm", i, width); | ||||
|             sprintf(buf, _CHB(L("%d lines: %.2lf mm")), i, width); | ||||
|             out += buf; | ||||
|             width += perimeter_flow.spacing() * (thin_walls ? 1.f : 2.f); | ||||
|         } | ||||
|  |  | |||
|  | @ -33,22 +33,22 @@ void Tab::create_preset_tab(PresetBundle *preset_bundle) | |||
| 
 | ||||
| 	// preset chooser
 | ||||
| 	m_presets_choice = new wxBitmapComboBox(panel, wxID_ANY, "", wxDefaultPosition, wxSize(270, -1), 0, 0,wxCB_READONLY); | ||||
| 	const wxBitmap* bmp = new wxBitmap(wxString::FromUTF8(Slic3r::var("flag-green-icon.png").c_str()), wxBITMAP_TYPE_PNG); | ||||
| 	const wxBitmap* bmp = new wxBitmap(from_u8(Slic3r::var("flag-green-icon.png")), wxBITMAP_TYPE_PNG); | ||||
| 
 | ||||
| 	//buttons
 | ||||
| 	wxBitmap bmpMenu; | ||||
| 	bmpMenu = wxBitmap(wxString::FromUTF8(Slic3r::var("disk.png").c_str()), wxBITMAP_TYPE_PNG); | ||||
| 	bmpMenu = wxBitmap(from_u8(Slic3r::var("disk.png")), wxBITMAP_TYPE_PNG); | ||||
| 	m_btn_save_preset = new wxBitmapButton(panel, wxID_ANY, bmpMenu, wxDefaultPosition, wxDefaultSize, wxBORDER_NONE); | ||||
| 	bmpMenu = wxBitmap(wxString::FromUTF8(Slic3r::var("delete.png").c_str()), wxBITMAP_TYPE_PNG); | ||||
| 	bmpMenu = wxBitmap(from_u8(Slic3r::var("delete.png")), wxBITMAP_TYPE_PNG); | ||||
| 	m_btn_delete_preset = new wxBitmapButton(panel, wxID_ANY, bmpMenu, wxDefaultPosition, wxDefaultSize, wxBORDER_NONE); | ||||
| 
 | ||||
| 	m_show_incompatible_presets = false; | ||||
| 	m_bmp_show_incompatible_presets = new wxBitmap(wxString::FromUTF8(Slic3r::var("flag-red-icon.png").c_str()), wxBITMAP_TYPE_PNG); | ||||
| 	m_bmp_hide_incompatible_presets = new wxBitmap(wxString::FromUTF8(Slic3r::var("flag-green-icon.png").c_str()), wxBITMAP_TYPE_PNG); | ||||
| 	m_bmp_show_incompatible_presets = new wxBitmap(from_u8(Slic3r::var("flag-red-icon.png")), wxBITMAP_TYPE_PNG); | ||||
| 	m_bmp_hide_incompatible_presets = new wxBitmap(from_u8(Slic3r::var("flag-green-icon.png")), wxBITMAP_TYPE_PNG); | ||||
| 	m_btn_hide_incompatible_presets = new wxBitmapButton(panel, wxID_ANY, *m_bmp_hide_incompatible_presets, wxDefaultPosition, wxDefaultSize, wxBORDER_NONE); | ||||
| 
 | ||||
| 	m_btn_save_preset->SetToolTip(_L("Save current ") + m_title); | ||||
| 	m_btn_delete_preset->SetToolTip(_L("Delete this preset")); | ||||
| 	m_btn_save_preset->SetToolTip(_(L("Save current ")) + m_title); | ||||
| 	m_btn_delete_preset->SetToolTip(_(L("Delete this preset"))); | ||||
| 	m_btn_delete_preset->Disable(); | ||||
| 
 | ||||
| 	m_hsizer = new wxBoxSizer(wxHORIZONTAL); | ||||
|  | @ -113,11 +113,11 @@ PageShp Tab::add_options_page(wxString title, std::string icon, bool is_extruder | |||
| 	// Index of icon in an icon list $self->{icons}.
 | ||||
| 	auto icon_idx = 0; | ||||
| 	if (!icon.empty()) { | ||||
| 		try { icon_idx = m_icon_index.at(icon);} | ||||
| 		catch (std::out_of_range e) { icon_idx = -1; } | ||||
| 		if (m_icon_index.find(icon) == m_icon_index.end()) | ||||
| 			icon_idx = -1; | ||||
| 		if (icon_idx == -1) { | ||||
| 			// Add a new icon to the icon list.
 | ||||
| 			const auto img_icon = new wxIcon(wxString::FromUTF8(Slic3r::var(icon).c_str()), wxBITMAP_TYPE_PNG); | ||||
| 			const auto img_icon = new wxIcon(from_u8(Slic3r::var(icon)), wxBITMAP_TYPE_PNG); | ||||
| 			m_icons->Add(*img_icon); | ||||
| 			icon_idx = ++m_icon_count; | ||||
| 			m_icon_index[icon] = icon_idx; | ||||
|  | @ -311,12 +311,12 @@ void TabPrint::build() | |||
| 	m_presets = &m_preset_bundle->prints; | ||||
| 	m_config = &m_presets->get_edited_preset().config; | ||||
| 
 | ||||
| 	auto page = add_options_page(_L("Layers and perimeters"), "layers.png"); | ||||
| 		auto optgroup = page->new_optgroup(_L("Layer height")); | ||||
| 	auto page = add_options_page(_(L("Layers and perimeters")), "layers.png"); | ||||
| 		auto optgroup = page->new_optgroup(_(L("Layer height"))); | ||||
| 		optgroup->append_single_option_line("layer_height"); | ||||
| 		optgroup->append_single_option_line("first_layer_height"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Vertical shells")); | ||||
| 		optgroup = page->new_optgroup(_(L("Vertical shells"))); | ||||
| 		optgroup->append_single_option_line("perimeters"); | ||||
| 		optgroup->append_single_option_line("spiral_vase"); | ||||
| 
 | ||||
|  | @ -327,34 +327,34 @@ void TabPrint::build() | |||
| 		}; | ||||
| 		optgroup->append_line(line); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Horizontal shells")); | ||||
| 		line = { _L("Solid layers"), "" }; | ||||
| 		optgroup = page->new_optgroup(_(L("Horizontal shells"))); | ||||
| 		line = { _(L("Solid layers")), "" }; | ||||
| 		line.append_option(optgroup->get_option("top_solid_layers")); | ||||
| 		line.append_option(optgroup->get_option("bottom_solid_layers")); | ||||
| 		optgroup->append_line(line); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Quality (slower slicing)")); | ||||
| 		optgroup = page->new_optgroup(_(L("Quality (slower slicing)"))); | ||||
| 		optgroup->append_single_option_line("extra_perimeters"); | ||||
| 		optgroup->append_single_option_line("ensure_vertical_shell_thickness"); | ||||
| 		optgroup->append_single_option_line("avoid_crossing_perimeters"); | ||||
| 		optgroup->append_single_option_line("thin_walls"); | ||||
| 		optgroup->append_single_option_line("overhangs"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Advanced")); | ||||
| 		optgroup = page->new_optgroup(_(L("Advanced"))); | ||||
| 		optgroup->append_single_option_line("seam_position"); | ||||
| 		optgroup->append_single_option_line("external_perimeters_first"); | ||||
| 
 | ||||
| 	page = add_options_page(_L("Infill"), "infill.png"); | ||||
| 		optgroup = page->new_optgroup(_L("Infill")); | ||||
| 	page = add_options_page(_(L("Infill")), "infill.png"); | ||||
| 		optgroup = page->new_optgroup(_(L("Infill"))); | ||||
| 		optgroup->append_single_option_line("fill_density"); | ||||
| 		optgroup->append_single_option_line("fill_pattern"); | ||||
| 		optgroup->append_single_option_line("external_fill_pattern"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Reducing printing time")); | ||||
| 		optgroup = page->new_optgroup(_(L("Reducing printing time"))); | ||||
| 		optgroup->append_single_option_line("infill_every_layers"); | ||||
| 		optgroup->append_single_option_line("infill_only_where_needed"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Advanced")); | ||||
| 		optgroup = page->new_optgroup(_(L("Advanced"))); | ||||
| 		optgroup->append_single_option_line("solid_infill_every_layers"); | ||||
| 		optgroup->append_single_option_line("fill_angle"); | ||||
| 		optgroup->append_single_option_line("solid_infill_below_area"); | ||||
|  | @ -362,27 +362,27 @@ void TabPrint::build() | |||
| 		optgroup->append_single_option_line("only_retract_when_crossing_perimeters"); | ||||
| 		optgroup->append_single_option_line("infill_first"); | ||||
| 
 | ||||
| 	page = add_options_page(_L("Skirt and brim"), "box.png"); | ||||
| 		optgroup = page->new_optgroup(_L("Skirt")); | ||||
| 	page = add_options_page(_(L("Skirt and brim")), "box.png"); | ||||
| 		optgroup = page->new_optgroup(_(L("Skirt"))); | ||||
| 		optgroup->append_single_option_line("skirts"); | ||||
| 		optgroup->append_single_option_line("skirt_distance"); | ||||
| 		optgroup->append_single_option_line("skirt_height"); | ||||
| 		optgroup->append_single_option_line("min_skirt_length"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Brim")); | ||||
| 		optgroup = page->new_optgroup(_(L("Brim"))); | ||||
| 		optgroup->append_single_option_line("brim_width"); | ||||
| 
 | ||||
| 	page = add_options_page(_L("Support material"), "building.png"); | ||||
| 		optgroup = page->new_optgroup(_L("Support material")); | ||||
| 	page = add_options_page(_(L("Support material")), "building.png"); | ||||
| 		optgroup = page->new_optgroup(_(L("Support material"))); | ||||
| 		optgroup->append_single_option_line("support_material"); | ||||
| 		optgroup->append_single_option_line("support_material_threshold"); | ||||
| 		optgroup->append_single_option_line("support_material_enforce_layers"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Raft")); | ||||
| 		optgroup = page->new_optgroup(_(L("Raft"))); | ||||
| 		optgroup->append_single_option_line("raft_layers"); | ||||
| //		# optgroup->append_single_option_line(get_option_("raft_contact_distance");
 | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Options for support material and raft")); | ||||
| 		optgroup = page->new_optgroup(_(L("Options for support material and raft"))); | ||||
| 		optgroup->append_single_option_line("support_material_contact_distance"); | ||||
| 		optgroup->append_single_option_line("support_material_pattern"); | ||||
| 		optgroup->append_single_option_line("support_material_with_sheath"); | ||||
|  | @ -396,8 +396,8 @@ void TabPrint::build() | |||
| 		optgroup->append_single_option_line("dont_support_bridges"); | ||||
| 		optgroup->append_single_option_line("support_material_synchronize_layers"); | ||||
| 
 | ||||
| 	page = add_options_page(_L("Speed"), "time.png"); | ||||
| 		optgroup = page->new_optgroup(_L("Speed for print moves")); | ||||
| 	page = add_options_page(_(L("Speed")), "time.png"); | ||||
| 		optgroup = page->new_optgroup(_(L("Speed for print moves"))); | ||||
| 		optgroup->append_single_option_line("perimeter_speed"); | ||||
| 		optgroup->append_single_option_line("small_perimeter_speed"); | ||||
| 		optgroup->append_single_option_line("external_perimeter_speed"); | ||||
|  | @ -409,49 +409,49 @@ void TabPrint::build() | |||
| 		optgroup->append_single_option_line("bridge_speed"); | ||||
| 		optgroup->append_single_option_line("gap_fill_speed"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Speed for non-print moves")); | ||||
| 		optgroup = page->new_optgroup(_(L("Speed for non-print moves"))); | ||||
| 		optgroup->append_single_option_line("travel_speed"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Modifiers")); | ||||
| 		optgroup = page->new_optgroup(_(L("Modifiers"))); | ||||
| 		optgroup->append_single_option_line("first_layer_speed"); | ||||
| 
 | ||||
| 		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("infill_acceleration"); | ||||
| 		optgroup->append_single_option_line("bridge_acceleration"); | ||||
| 		optgroup->append_single_option_line("first_layer_acceleration"); | ||||
| 		optgroup->append_single_option_line("default_acceleration"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Autospeed (advanced)")); | ||||
| 		optgroup = page->new_optgroup(_(L("Autospeed (advanced)"))); | ||||
| 		optgroup->append_single_option_line("max_print_speed"); | ||||
| 		optgroup->append_single_option_line("max_volumetric_speed"); | ||||
| 		optgroup->append_single_option_line("max_volumetric_extrusion_rate_slope_positive"); | ||||
| 		optgroup->append_single_option_line("max_volumetric_extrusion_rate_slope_negative"); | ||||
| 
 | ||||
| 	page = add_options_page(_L("Multiple Extruders"), "funnel.png"); | ||||
| 		optgroup = page->new_optgroup(_L("Extruders")); | ||||
| 	page = add_options_page(_(L("Multiple Extruders")), "funnel.png"); | ||||
| 		optgroup = page->new_optgroup(_(L("Extruders"))); | ||||
| 		optgroup->append_single_option_line("perimeter_extruder"); | ||||
| 		optgroup->append_single_option_line("infill_extruder"); | ||||
| 		optgroup->append_single_option_line("solid_infill_extruder"); | ||||
| 		optgroup->append_single_option_line("support_material_extruder"); | ||||
| 		optgroup->append_single_option_line("support_material_interface_extruder"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Ooze prevention")); | ||||
| 		optgroup = page->new_optgroup(_(L("Ooze prevention"))); | ||||
| 		optgroup->append_single_option_line("ooze_prevention"); | ||||
| 		optgroup->append_single_option_line("standby_temperature_delta"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Wipe tower")); | ||||
| 		optgroup = page->new_optgroup(_(L("Wipe tower"))); | ||||
| 		optgroup->append_single_option_line("wipe_tower"); | ||||
| 		optgroup->append_single_option_line("wipe_tower_x"); | ||||
| 		optgroup->append_single_option_line("wipe_tower_y"); | ||||
| 		optgroup->append_single_option_line("wipe_tower_width"); | ||||
| 		optgroup->append_single_option_line("wipe_tower_per_color_wipe"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Advanced")); | ||||
| 		optgroup = page->new_optgroup(_(L("Advanced"))); | ||||
| 		optgroup->append_single_option_line("interface_shells"); | ||||
| 
 | ||||
| 	page = add_options_page(_L("Advanced"), "wrench.png"); | ||||
| 		optgroup = page->new_optgroup(_L("Extrusion width"), 180); | ||||
| 	page = add_options_page(_(L("Advanced")), "wrench.png"); | ||||
| 		optgroup = page->new_optgroup(_(L("Extrusion width")), 180); | ||||
| 		optgroup->append_single_option_line("extrusion_width"); | ||||
| 		optgroup->append_single_option_line("first_layer_extrusion_width"); | ||||
| 		optgroup->append_single_option_line("perimeter_extrusion_width"); | ||||
|  | @ -461,23 +461,23 @@ void TabPrint::build() | |||
| 		optgroup->append_single_option_line("top_infill_extrusion_width"); | ||||
| 		optgroup->append_single_option_line("support_material_extrusion_width"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Overlap")); | ||||
| 		optgroup = page->new_optgroup(_(L("Overlap"))); | ||||
| 		optgroup->append_single_option_line("infill_overlap"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Flow")); | ||||
| 		optgroup = page->new_optgroup(_(L("Flow"))); | ||||
| 		optgroup->append_single_option_line("bridge_flow_ratio"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Other")); | ||||
| 		optgroup = page->new_optgroup(_(L("Other"))); | ||||
| 		optgroup->append_single_option_line("clip_multipart_objects"); | ||||
| 		optgroup->append_single_option_line("elefant_foot_compensation"); | ||||
| 		optgroup->append_single_option_line("xy_size_compensation"); | ||||
| //		#            optgroup->append_single_option_line("threads");
 | ||||
| 		optgroup->append_single_option_line("resolution"); | ||||
| 
 | ||||
| 	page = add_options_page(_L("Output options"), "page_white_go.png"); | ||||
| 		optgroup = page->new_optgroup(_L("Sequential printing")); | ||||
| 	page = add_options_page(_(L("Output options")), "page_white_go.png"); | ||||
| 		optgroup = page->new_optgroup(_(L("Sequential printing"))); | ||||
| 		optgroup->append_single_option_line("complete_objects"); | ||||
| 		line = { _L("Extruder clearance (mm)"), "" }; | ||||
| 		line = { _(L("Extruder clearance (mm)")), "" }; | ||||
| 		Option option = optgroup->get_option("extruder_clearance_radius"); | ||||
| 		option.opt.width = 60; | ||||
| 		line.append_option(option); | ||||
|  | @ -486,28 +486,28 @@ void TabPrint::build() | |||
| 		line.append_option(option); | ||||
| 		optgroup->append_line(line); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Output file")); | ||||
| 		optgroup = page->new_optgroup(_(L("Output file"))); | ||||
| 		optgroup->append_single_option_line("gcode_comments"); | ||||
| 		option = optgroup->get_option("output_filename_format"); | ||||
| 		option.opt.full_width = true; | ||||
| 		optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Post-processing scripts"), 0);	 | ||||
| 		optgroup = page->new_optgroup(_(L("Post-processing scripts")), 0);	 | ||||
| 		option = optgroup->get_option("post_process"); | ||||
| 		option.opt.full_width = true; | ||||
| 		option.opt.height = 50; | ||||
| 		optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 	page = add_options_page(_L("Notes"), "note.png"); | ||||
| 		optgroup = page->new_optgroup(_L("Notes"), 0);						 | ||||
| 	page = add_options_page(_(L("Notes")), "note.png"); | ||||
| 		optgroup = page->new_optgroup(_(L("Notes")), 0);						 | ||||
| 		option = optgroup->get_option("notes"); | ||||
| 		option.opt.full_width = true; | ||||
| 		option.opt.height = 250; | ||||
| 		optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 	page = add_options_page(_L("Dependencies"), "wrench.png"); | ||||
| 		optgroup = page->new_optgroup(_L("Profile dependencies")); | ||||
| 		line = { _L("Compatible printers"), "" }; | ||||
| 	page = add_options_page(_(L("Dependencies")), "wrench.png"); | ||||
| 		optgroup = page->new_optgroup(_(L("Profile dependencies"))); | ||||
| 		line = { _(L("Compatible printers")), "" }; | ||||
| 		line.widget = [this](wxWindow* parent){ | ||||
| 			return compatible_printers_widget(parent, &m_compatible_printers_checkbox, &m_compatible_printers_btn); | ||||
| 		}; | ||||
|  | @ -528,78 +528,79 @@ void TabPrint::update() | |||
| { | ||||
| 	Freeze(); | ||||
| 
 | ||||
| 	if ( m_config->opt_bool("spiral_vase") &&  | ||||
| 	if (m_config->opt_bool("spiral_vase") && | ||||
| 		!(m_config->opt_int("perimeters") == 1 && m_config->opt_int("top_solid_layers") == 0 && | ||||
| 			m_config->option<ConfigOptionPercent>("fill_density")->value == 0)) { | ||||
| 		wxString msg_text = _L("The Spiral Vase mode requires:\n" | ||||
| 		m_config->option<ConfigOptionPercent>("fill_density")->value == 0)) { | ||||
| 		wxString msg_text = _(L("The Spiral Vase mode requires:\n" | ||||
| 			"- one perimeter\n" | ||||
|  			"- no top solid layers\n" | ||||
|  			"- 0% fill density\n" | ||||
|  			"- no support material\n" | ||||
|  			"- no ensure_vertical_shell_thickness\n" | ||||
|   			"\nShall I adjust those settings in order to enable Spiral Vase?"); | ||||
| 		auto dialog = new wxMessageDialog(parent(), msg_text, _L("Spiral Vase"), wxICON_WARNING | wxYES | wxNO); | ||||
| 			"- no top solid layers\n" | ||||
| 			"- 0% fill density\n" | ||||
| 			"- no support material\n" | ||||
| 			"- no ensure_vertical_shell_thickness\n" | ||||
| 			"\nShall I adjust those settings in order to enable Spiral Vase?")); | ||||
| 		auto dialog = new wxMessageDialog(parent(), msg_text, _(L("Spiral Vase")), wxICON_WARNING | wxYES | wxNO); | ||||
| 		DynamicPrintConfig new_conf = *m_config; | ||||
|  		if (dialog->ShowModal() == wxID_YES) { | ||||
| 		if (dialog->ShowModal() == wxID_YES) { | ||||
| 			new_conf.set_key_value("perimeters", new ConfigOptionInt(1)); | ||||
| 			new_conf.set_key_value("top_solid_layers", new ConfigOptionInt(0)); | ||||
| 			new_conf.set_key_value("fill_density", new ConfigOptionPercent(0)); | ||||
| 			new_conf.set_key_value("support_material", new ConfigOptionBool(false)); | ||||
| 			new_conf.set_key_value("support_material_enforce_layers", new ConfigOptionInt(0)); | ||||
| 			new_conf.set_key_value("ensure_vertical_shell_thickness", new ConfigOptionBool(false)); | ||||
| 		} | ||||
| 		else { | ||||
| 			new_conf.set_key_value("spiral_vase", new ConfigOptionBool(false)); | ||||
| 		} | ||||
|  		load_config(new_conf); | ||||
| 		load_config(new_conf); | ||||
| 	} | ||||
| 
 | ||||
| 	auto first_layer_height = m_config->option<ConfigOptionFloatOrPercent>("first_layer_height")->value; | ||||
| 	auto layer_height = m_config->opt_float("layer_height"); | ||||
| 	if (m_config->opt_bool("wipe_tower") && | ||||
| 		( first_layer_height != 0.2 || layer_height < 0.15 || layer_height > 0.35)) { | ||||
| 		wxString msg_text = _L("The Wipe Tower currently supports only:\n" | ||||
| 		(first_layer_height != 0.2 || layer_height < 0.15 || layer_height > 0.35)) { | ||||
| 		wxString msg_text = _(L("The Wipe Tower currently supports only:\n" | ||||
| 			"- first layer height 0.2mm\n" | ||||
| 			"- layer height from 0.15mm to 0.35mm\n" | ||||
| 			"\nShall I adjust those settings in order to enable the Wipe Tower?"); | ||||
| 		auto dialog = new wxMessageDialog(parent(), msg_text, _L("Wipe Tower"), wxICON_WARNING | wxYES | wxNO); | ||||
| 			"\nShall I adjust those settings in order to enable the Wipe Tower?")); | ||||
| 		auto dialog = new wxMessageDialog(parent(), msg_text, _(L("Wipe Tower")), wxICON_WARNING | wxYES | wxNO); | ||||
| 		DynamicPrintConfig new_conf = *m_config; | ||||
| 		if (dialog->ShowModal() == wxID_YES) { | ||||
| 			const auto &val = *m_config->option<ConfigOptionFloatOrPercent>("first_layer_height"); | ||||
| 			new_conf.set_key_value("first_layer_height", new ConfigOptionFloatOrPercent(0.2, val.percent)); | ||||
| 
 | ||||
| 			if (m_config->opt_float("layer_height") < 0.15) new_conf.set_key_value("layer_height", new ConfigOptionFloat(0.15)) ; | ||||
| 			if (m_config->opt_float("layer_height") < 0.15) new_conf.set_key_value("layer_height", new ConfigOptionFloat(0.15)); | ||||
| 			if (m_config->opt_float("layer_height") > 0.35) new_conf.set_key_value("layer_height", new ConfigOptionFloat(0.35)); | ||||
| 		} | ||||
| 		else  | ||||
| 		else | ||||
| 			new_conf.set_key_value("wipe_tower", new ConfigOptionBool(false)); | ||||
| 		load_config(new_conf); | ||||
| 	} | ||||
| 
 | ||||
| 	if (m_config->opt_bool("wipe_tower") && m_config->opt_bool("support_material") &&  | ||||
| 	if (m_config->opt_bool("wipe_tower") && m_config->opt_bool("support_material") && | ||||
| 		m_config->opt_float("support_material_contact_distance") > 0. && | ||||
| 		(m_config->opt_int("support_material_extruder") != 0 || m_config->opt_int("support_material_interface_extruder") != 0)) { | ||||
| 		wxString msg_text = _L("The Wipe Tower currently supports the non-soluble supports only\n" | ||||
| 		wxString msg_text = _(L("The Wipe Tower currently supports the non-soluble supports only\n" | ||||
| 			"if they are printed with the current extruder without triggering a tool change.\n" | ||||
| 			"(both support_material_extruder and support_material_interface_extruder need to be set to 0).\n" | ||||
| 			"\nShall I adjust those settings in order to enable the Wipe Tower?"); | ||||
| 		auto dialog = new wxMessageDialog(parent(), msg_text, _L("Wipe Tower"), wxICON_WARNING | wxYES | wxNO); | ||||
| 			"\nShall I adjust those settings in order to enable the Wipe Tower?")); | ||||
| 		auto dialog = new wxMessageDialog(parent(), msg_text, _(L("Wipe Tower")), wxICON_WARNING | wxYES | wxNO); | ||||
| 		DynamicPrintConfig new_conf = *m_config; | ||||
| 		if (dialog->ShowModal() == wxID_YES) { | ||||
| 			new_conf.set_key_value("support_material_extruder", new ConfigOptionInt(0)); | ||||
| 			new_conf.set_key_value("support_material_interface_extruder", new ConfigOptionInt(0)); | ||||
| 		} | ||||
| 		else  | ||||
| 		else | ||||
| 			new_conf.set_key_value("wipe_tower", new ConfigOptionBool(false)); | ||||
| 		load_config(new_conf); | ||||
| 	} | ||||
| 
 | ||||
| 	if (m_config->opt_bool("wipe_tower") && m_config->opt_bool("support_material") &&  | ||||
| 	if (m_config->opt_bool("wipe_tower") && m_config->opt_bool("support_material") && | ||||
| 		m_config->opt_float("support_material_contact_distance") == 0 && | ||||
| 		!m_config->opt_bool("support_material_synchronize_layers")) { | ||||
| 		wxString msg_text = _L("For the Wipe Tower to work with the soluble supports, the support layers\n" | ||||
| 		wxString msg_text = _(L("For the Wipe Tower to work with the soluble supports, the support layers\n" | ||||
| 			"need to be synchronized with the object layers.\n" | ||||
| 			"\nShall I synchronize support layers in order to enable the Wipe Tower?"); | ||||
| 		auto dialog = new wxMessageDialog(parent(), msg_text, _L("Wipe Tower"), wxICON_WARNING | wxYES | wxNO); | ||||
| 			"\nShall I synchronize support layers in order to enable the Wipe Tower?")); | ||||
| 		auto dialog = new wxMessageDialog(parent(), msg_text, _(L("Wipe Tower")), wxICON_WARNING | wxYES | wxNO); | ||||
| 		DynamicPrintConfig new_conf = *m_config; | ||||
| 		if (dialog->ShowModal() == wxID_YES) { | ||||
| 			new_conf.set_key_value("support_material_synchronize_layers", new ConfigOptionBool(true)); | ||||
|  | @ -614,18 +615,18 @@ void TabPrint::update() | |||
| 		if (!m_support_material_overhangs_queried) { | ||||
| 			m_support_material_overhangs_queried = true; | ||||
| 			if (!m_config->opt_bool("overhangs")/* != 1*/) { | ||||
| 				wxString msg_text = _L("Supports work better, if the following feature is enabled:\n" | ||||
| 				wxString msg_text = _(L("Supports work better, if the following feature is enabled:\n" | ||||
| 					"- Detect bridging perimeters\n" | ||||
| 					"\nShall I adjust those settings for supports?"); | ||||
| 				auto dialog = new wxMessageDialog(parent(), msg_text, _L("Support Generator"), wxICON_WARNING | wxYES | wxNO | wxCANCEL); | ||||
| 					"\nShall I adjust those settings for supports?")); | ||||
| 				auto dialog = new wxMessageDialog(parent(), msg_text, _(L("Support Generator")), wxICON_WARNING | wxYES | wxNO | wxCANCEL); | ||||
| 				DynamicPrintConfig new_conf = *m_config; | ||||
| 				auto answer = dialog->ShowModal(); | ||||
| 				if (answer == wxID_YES) { | ||||
| 					// Enable "detect bridging perimeters".
 | ||||
| 					new_conf.set_key_value("overhangs", new ConfigOptionBool(true)); | ||||
| 				} else if(answer == wxID_NO) { | ||||
| 				} else if (answer == wxID_NO) { | ||||
| 					// Do nothing, leave supports on and "detect bridging perimeters" off.
 | ||||
| 				} else if(answer == wxID_CANCEL) { | ||||
| 				} else if (answer == wxID_CANCEL) { | ||||
| 					// Disable supports.
 | ||||
| 					new_conf.set_key_value("support_material", new ConfigOptionBool(false)); | ||||
| 					m_support_material_overhangs_queried = false; | ||||
|  | @ -642,7 +643,7 @@ void TabPrint::update() | |||
| 		auto fill_pattern = m_config->option<ConfigOptionEnum<InfillPattern>>("fill_pattern")->value; | ||||
| 		std::string str_fill_pattern = ""; | ||||
| 		t_config_enum_values map_names = m_config->option<ConfigOptionEnum<InfillPattern>>("fill_pattern")->get_enum_values(); | ||||
| 		for (auto it:map_names) { | ||||
| 		for (auto it : map_names) { | ||||
| 			if (fill_pattern == it.second) { | ||||
| 				str_fill_pattern = it.first; | ||||
| 				break; | ||||
|  | @ -659,9 +660,9 @@ void TabPrint::update() | |||
| 			// get fill_pattern name from enum_labels for using this one at dialog_msg
 | ||||
| 			str_fill_pattern = m_config->def()->get("fill_pattern")->enum_labels[fill_pattern]; | ||||
| 			if (!correct_100p_fill){ | ||||
| 				wxString msg_text = _L("The ") + str_fill_pattern + _L(" infill pattern is not supposed to work at 100% density.\n" | ||||
| 					"\nShall I switch to rectilinear fill pattern?"); | ||||
| 				auto dialog = new wxMessageDialog(parent(), msg_text, _L("Infill"), wxICON_WARNING | wxYES | wxNO); | ||||
| 				wxString msg_text = _(L("The ")) + str_fill_pattern + _(L(" infill pattern is not supposed to work at 100% density.\n" | ||||
| 					"\nShall I switch to rectilinear fill pattern?")); | ||||
| 				auto dialog = new wxMessageDialog(parent(), msg_text, _(L("Infill")), wxICON_WARNING | wxYES | wxNO); | ||||
| 				DynamicPrintConfig new_conf = *m_config; | ||||
| 				if (dialog->ShowModal() == wxID_YES) { | ||||
| 					new_conf.set_key_value("fill_pattern", new ConfigOptionEnum<InfillPattern>(ipRectilinear)); | ||||
|  | @ -675,7 +676,7 @@ void TabPrint::update() | |||
| 	} | ||||
| 
 | ||||
| 	bool have_perimeters = m_config->opt_int("perimeters") > 0; | ||||
| 	std::vector<std::string> vec_enable = { "extra_perimeters", "ensure_vertical_shell_thickness", "thin_walls", "overhangs", | ||||
| 	std::vector<std::string> vec_enable = {	"extra_perimeters", "ensure_vertical_shell_thickness", "thin_walls", "overhangs", | ||||
| 											"seam_position", "external_perimeters_first", "external_perimeter_extrusion_width", | ||||
| 											"perimeter_speed", "small_perimeter_speed", "external_perimeter_speed" }; | ||||
| 	for (auto el : vec_enable) | ||||
|  | @ -683,22 +684,22 @@ void TabPrint::update() | |||
| 
 | ||||
| 	bool have_infill = m_config->option<ConfigOptionPercent>("fill_density")->value > 0; | ||||
| 	vec_enable.resize(0); | ||||
| 	vec_enable = {	"fill_pattern", "infill_every_layers", "infill_only_where_needed",  | ||||
| 					"solid_infill_every_layers", "solid_infill_below_area", "infill_extruder"}; | ||||
| 	vec_enable = {	"fill_pattern", "infill_every_layers", "infill_only_where_needed", | ||||
| 					"solid_infill_every_layers", "solid_infill_below_area", "infill_extruder" }; | ||||
| 	// infill_extruder uses the same logic as in Print::extruders()
 | ||||
| 	for (auto el : vec_enable) | ||||
| 		get_field(el)->toggle(have_infill); | ||||
| 
 | ||||
| 	bool have_solid_infill = m_config->opt_int("top_solid_layers") > 0 || m_config->opt_int("bottom_solid_layers") > 0; | ||||
| 	vec_enable.resize(0); | ||||
| 	vec_enable = { "external_fill_pattern", "infill_first", "solid_infill_extruder", | ||||
| 		"solid_infill_extrusion_width", "solid_infill_speed" }; | ||||
| 	vec_enable = {	"external_fill_pattern", "infill_first", "solid_infill_extruder", | ||||
| 					"solid_infill_extrusion_width", "solid_infill_speed" }; | ||||
| 	// solid_infill_extruder uses the same logic as in Print::extruders()
 | ||||
| 	for (auto el : vec_enable) | ||||
| 		get_field(el)->toggle(have_solid_infill); | ||||
| 
 | ||||
| 	vec_enable.resize(0); | ||||
| 	vec_enable = { "fill_angle", "bridge_angle", "infill_extrusion_width",  | ||||
| 	vec_enable = {	"fill_angle", "bridge_angle", "infill_extrusion_width", | ||||
| 					"infill_speed", "bridge_speed" }; | ||||
| 	for (auto el : vec_enable) | ||||
| 		get_field(el)->toggle(have_infill || have_solid_infill); | ||||
|  | @ -713,14 +714,14 @@ void TabPrint::update() | |||
| 
 | ||||
| 	bool have_default_acceleration = m_config->opt_float("default_acceleration") > 0; | ||||
| 	vec_enable.resize(0); | ||||
| 	vec_enable = {	"perimeter_acceleration", "infill_acceleration",  | ||||
| 					"bridge_acceleration", "first_layer_acceleration"}; | ||||
| 	vec_enable = {	"perimeter_acceleration", "infill_acceleration", | ||||
| 					"bridge_acceleration", "first_layer_acceleration" }; | ||||
| 	for (auto el : vec_enable) | ||||
| 		get_field(el)->toggle(have_default_acceleration); | ||||
| 
 | ||||
| 	bool have_skirt = m_config->opt_int("skirts") > 0 || m_config->opt_float("min_skirt_length") > 0; | ||||
| 	vec_enable.resize(0); | ||||
| 	vec_enable = {	"skirt_distance", "skirt_height"}; | ||||
| 	vec_enable = { "skirt_distance", "skirt_height" }; | ||||
| 	for (auto el : vec_enable) | ||||
| 		get_field(el)->toggle(have_skirt); | ||||
| 
 | ||||
|  | @ -734,15 +735,15 @@ void TabPrint::update() | |||
| 	bool have_support_soluble = have_support_material && m_config->opt_float("support_material_contact_distance") == 0; | ||||
| 	vec_enable.resize(0); | ||||
| 	vec_enable = {	"support_material_threshold", "support_material_pattern", "support_material_with_sheath", | ||||
| 					"support_material_spacing", "support_material_angle", "support_material_interface_layers",  | ||||
| 					"dont_support_bridges", "support_material_extrusion_width", "support_material_contact_distance",  | ||||
| 					"support_material_xy_spacing"}; | ||||
| 					"support_material_spacing", "support_material_angle", "support_material_interface_layers", | ||||
| 					"dont_support_bridges", "support_material_extrusion_width", "support_material_contact_distance", | ||||
| 					"support_material_xy_spacing" }; | ||||
| 	for (auto el : vec_enable) | ||||
| 		get_field(el)->toggle(have_support_material); | ||||
| 
 | ||||
| 	vec_enable.resize(0); | ||||
| 	vec_enable = {	"support_material_interface_spacing", "support_material_interface_extruder",  | ||||
| 					"support_material_interface_speed", "support_material_interface_contact_loops"}; | ||||
| 	vec_enable = {	"support_material_interface_spacing", "support_material_interface_extruder", | ||||
| 					"support_material_interface_speed", "support_material_interface_contact_loops" }; | ||||
| 	for (auto el : vec_enable) | ||||
| 		get_field(el)->toggle(have_support_material && have_support_interface); | ||||
| 	get_field("support_material_synchronize_layers")->toggle(have_support_soluble); | ||||
|  | @ -753,7 +754,7 @@ void TabPrint::update() | |||
| 
 | ||||
| 	bool have_sequential_printing = m_config->opt_bool("complete_objects"); | ||||
| 	vec_enable.resize(0); | ||||
| 	vec_enable = {	"extruder_clearance_radius", "extruder_clearance_height"}; | ||||
| 	vec_enable = { "extruder_clearance_radius", "extruder_clearance_height" }; | ||||
| 	for (auto el : vec_enable) | ||||
| 		get_field(el)->toggle(have_sequential_printing); | ||||
| 
 | ||||
|  | @ -762,7 +763,7 @@ void TabPrint::update() | |||
| 
 | ||||
| 	bool have_wipe_tower = m_config->opt_bool("wipe_tower"); | ||||
| 	vec_enable.resize(0); | ||||
| 	vec_enable = {	"wipe_tower_x", "wipe_tower_y", "wipe_tower_width", "wipe_tower_per_color_wipe"}; | ||||
| 	vec_enable = { "wipe_tower_x", "wipe_tower_y", "wipe_tower_width", "wipe_tower_per_color_wipe" }; | ||||
| 	for (auto el : vec_enable) | ||||
| 		get_field(el)->toggle(have_wipe_tower); | ||||
| 
 | ||||
|  | @ -782,39 +783,39 @@ void TabFilament::build() | |||
| 	m_presets = &m_preset_bundle->filaments; | ||||
| 	m_config = &m_preset_bundle->filaments.get_edited_preset().config; | ||||
| 
 | ||||
| 	auto page = add_options_page(_L("Filament"), "spool.png"); | ||||
| 		auto optgroup = page->new_optgroup(_L("Filament")); | ||||
| 	auto page = add_options_page(_(L("Filament")), "spool.png"); | ||||
| 		auto optgroup = page->new_optgroup(_(L("Filament"))); | ||||
| 		optgroup->append_single_option_line("filament_colour"); | ||||
| 		optgroup->append_single_option_line("filament_diameter"); | ||||
| 		optgroup->append_single_option_line("extrusion_multiplier"); | ||||
| 		optgroup->append_single_option_line("filament_density"); | ||||
| 		optgroup->append_single_option_line("filament_cost"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Temperature") +" (\u00B0C)"); // degree sign
 | ||||
| 		Line line = { _L("Extruder"), "" }; | ||||
| 		optgroup = page->new_optgroup(_(L("Temperature ")) +" (\u00B0C)"); // degree sign
 | ||||
| 		Line line = { _(L("Extruder")), "" }; | ||||
| 		line.append_option(optgroup->get_option("first_layer_temperature")); | ||||
| 		line.append_option(optgroup->get_option("temperature")); | ||||
| 		optgroup->append_line(line); | ||||
| 
 | ||||
| 		line = { _L("Bed"), "" }; | ||||
| 		line = { _(L("Bed")), "" }; | ||||
| 		line.append_option(optgroup->get_option("first_layer_bed_temperature")); | ||||
| 		line.append_option(optgroup->get_option("bed_temperature")); | ||||
| 		optgroup->append_line(line); | ||||
| 
 | ||||
| 	page = add_options_page(_L("Cooling"), "hourglass.png"); | ||||
| 		optgroup = page->new_optgroup(_L("Enable")); | ||||
| 	page = add_options_page(_(L("Cooling")), "hourglass.png"); | ||||
| 		optgroup = page->new_optgroup(_(L("Enable"))); | ||||
| 		optgroup->append_single_option_line("fan_always_on"); | ||||
| 		optgroup->append_single_option_line("cooling"); | ||||
| 
 | ||||
| 		line = { "", "" };  | ||||
| 		line = { "", "" }; | ||||
| 		line.full_width = 1; | ||||
| 		line.widget = [this](wxWindow* parent) { | ||||
| 			return description_line_widget(parent, &m_cooling_description_line); | ||||
| 		}; | ||||
| 		optgroup->append_line(line); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Fan settings")); | ||||
| 		line = {_L("Fan speed"),""}; | ||||
| 		optgroup = page->new_optgroup(_(L("Fan settings"))); | ||||
| 		line = { _(L("Fan speed")), "" }; | ||||
| 		line.append_option(optgroup->get_option("min_fan_speed")); | ||||
| 		line.append_option(optgroup->get_option("max_fan_speed")); | ||||
| 		optgroup->append_line(line); | ||||
|  | @ -822,50 +823,50 @@ void TabFilament::build() | |||
| 		optgroup->append_single_option_line("bridge_fan_speed"); | ||||
| 		optgroup->append_single_option_line("disable_fan_first_layers"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Cooling thresholds"), 250); | ||||
| 		optgroup = page->new_optgroup(_(L("Cooling thresholds")), 250); | ||||
| 		optgroup->append_single_option_line("fan_below_layer_time"); | ||||
| 		optgroup->append_single_option_line("slowdown_below_layer_time"); | ||||
| 		optgroup->append_single_option_line("min_print_speed"); | ||||
| 
 | ||||
| 	page = add_options_page(_L("Advanced"), "wrench.png"); | ||||
| 		optgroup = page->new_optgroup(_L("Filament properties")); | ||||
| 	page = add_options_page(_(L("Advanced")), "wrench.png"); | ||||
| 		optgroup = page->new_optgroup(_(L("Filament properties"))); | ||||
| 		optgroup->append_single_option_line("filament_type"); | ||||
| 		optgroup->append_single_option_line("filament_soluble"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Print speed override")); | ||||
| 		optgroup = page->new_optgroup(_(L("Print speed override"))); | ||||
| 		optgroup->append_single_option_line("filament_max_volumetric_speed"); | ||||
| 
 | ||||
| 		line = {"",""}; | ||||
| 		line = { "", "" }; | ||||
| 		line.full_width = 1; | ||||
| 		line.widget = [this](wxWindow* parent) { | ||||
| 			return description_line_widget(parent, &m_volumetric_speed_description_line); | ||||
| 		}; | ||||
| 		optgroup->append_line(line); | ||||
| 
 | ||||
| 	page = add_options_page(_L("Custom G-code"), "cog.png"); | ||||
| 		optgroup = page->new_optgroup(_L("Start G-code"), 0); | ||||
| 	page = add_options_page(_(L("Custom G-code")), "cog.png"); | ||||
| 		optgroup = page->new_optgroup(_(L("Start G-code")), 0); | ||||
| 		Option option = optgroup->get_option("start_filament_gcode"); | ||||
| 		option.opt.full_width = true; | ||||
| 		option.opt.height = 150; | ||||
| 		optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("End G-code"), 0); | ||||
| 		optgroup = page->new_optgroup(_(L("End G-code")), 0); | ||||
| 		option = optgroup->get_option("end_filament_gcode"); | ||||
| 		option.opt.full_width = true; | ||||
| 		option.opt.height = 150; | ||||
| 		optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 	page = add_options_page(_L("Notes"), "note.png"); | ||||
| 		optgroup = page->new_optgroup(_L("Notes"), 0); | ||||
| 	page = add_options_page(_(L("Notes")), "note.png"); | ||||
| 		optgroup = page->new_optgroup(_(L("Notes")), 0); | ||||
| 		optgroup->label_width = 0; | ||||
| 		option = optgroup->get_option("filament_notes"); | ||||
| 		option.opt.full_width = true; | ||||
| 		option.opt.height = 250; | ||||
| 		optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 	page = add_options_page(_L("Dependencies"), "wrench.png"); | ||||
| 		optgroup = page->new_optgroup(_L("Profile dependencies")); | ||||
| 		line = {_L("Compatible printers"), ""}; | ||||
| 	page = add_options_page(_(L("Dependencies")), "wrench.png"); | ||||
| 		optgroup = page->new_optgroup(_(L("Profile dependencies"))); | ||||
| 		line = { _(L("Compatible printers")), "" }; | ||||
| 		line.widget = [this](wxWindow* parent){ | ||||
| 			return compatible_printers_widget(parent, &m_compatible_printers_checkbox, &m_compatible_printers_btn); | ||||
| 		}; | ||||
|  | @ -884,9 +885,9 @@ void TabFilament::reload_config(){ | |||
| 
 | ||||
| void TabFilament::update() | ||||
| { | ||||
| 	wxString text = wxString::FromUTF8(PresetHints::cooling_description(m_presets->get_edited_preset()).c_str()); | ||||
| 	wxString text = from_u8(PresetHints::cooling_description(m_presets->get_edited_preset())); | ||||
| 	m_cooling_description_line->SetText(text); | ||||
| 	text = wxString::FromUTF8(PresetHints::maximum_volumetric_flow_description(*m_preset_bundle).c_str()); | ||||
| 	text = from_u8(PresetHints::maximum_volumetric_flow_description(*m_preset_bundle)); | ||||
| 	m_volumetric_speed_description_line->SetText(text); | ||||
| 
 | ||||
| 	bool cooling = m_config->opt_bool("cooling", 0); | ||||
|  | @ -904,7 +905,7 @@ void TabFilament::update() | |||
| 
 | ||||
| void TabFilament::OnActivate() | ||||
| { | ||||
| 	m_volumetric_speed_description_line->SetText(PresetHints::maximum_volumetric_flow_description(*m_preset_bundle)); | ||||
| 	m_volumetric_speed_description_line->SetText(from_u8(PresetHints::maximum_volumetric_flow_description(*m_preset_bundle))); | ||||
| } | ||||
| 
 | ||||
| wxSizer* Tab::description_line_widget(wxWindow* parent, ogStaticText* *StaticText) | ||||
|  | @ -933,14 +934,14 @@ void TabPrinter::build() | |||
| 	auto   *nozzle_diameter = dynamic_cast<const ConfigOptionFloats*>(m_config->option("nozzle_diameter")); | ||||
| 	m_extruders_count = nozzle_diameter->values.size(); | ||||
| 
 | ||||
| 	auto page = add_options_page(_L("General"), "printer_empty.png"); | ||||
| 		auto optgroup = page->new_optgroup(_L("Size and coordinates")); | ||||
| 	auto page = add_options_page(_(L("General")), "printer_empty.png"); | ||||
| 		auto optgroup = page->new_optgroup(_(L("Size and coordinates"))); | ||||
| 
 | ||||
| 		Line line{ _L("Bed shape"), "" }; | ||||
| 		Line line{ _(L("Bed shape")), "" }; | ||||
| 		line.widget = [this](wxWindow* parent){ | ||||
| 			auto btn = new wxButton(parent, wxID_ANY, _L("Set")+"\u2026", wxDefaultPosition, wxDefaultSize, wxBU_LEFT | wxBU_EXACTFIT); | ||||
| //			btn->SetFont(Slic3r::GUI::small_font);
 | ||||
| 			btn->SetBitmap(wxBitmap(wxString::FromUTF8(Slic3r::var("printer_empty.png").c_str()), wxBITMAP_TYPE_PNG)); | ||||
| 	auto btn = new wxButton(parent, wxID_ANY, _(L(" Set "))+"\u2026", wxDefaultPosition, wxDefaultSize, wxBU_LEFT | wxBU_EXACTFIT); | ||||
| 			//			btn->SetFont(Slic3r::GUI::small_font);
 | ||||
| 			btn->SetBitmap(wxBitmap(from_u8(Slic3r::var("printer_empty.png")), wxBITMAP_TYPE_PNG)); | ||||
| 
 | ||||
| 			auto sizer = new wxBoxSizer(wxHORIZONTAL); | ||||
| 			sizer->Add(btn); | ||||
|  | @ -958,12 +959,12 @@ void TabPrinter::build() | |||
| 		optgroup->append_line(line); | ||||
| 		optgroup->append_single_option_line("z_offset"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Capabilities")); | ||||
| 		optgroup = page->new_optgroup(_(L("Capabilities"))); | ||||
| 		ConfigOptionDef def; | ||||
| 			def.type =  coInt, | ||||
| 			def.default_value = new ConfigOptionInt(1);  | ||||
| 			def.label = _LU8("Extruders"); | ||||
| 			def.tooltip = _LU8("Number of extruders of the printer."); | ||||
| 			def.label = L("Extruders"); | ||||
| 			def.tooltip = L("Number of extruders of the printer."); | ||||
| 			def.min = 1; | ||||
| 		Option option(def, "extruders_count"); | ||||
| 		optgroup->append_single_option_line(option); | ||||
|  | @ -985,13 +986,13 @@ void TabPrinter::build() | |||
| 
 | ||||
| 		if (!m_no_controller) | ||||
| 		{ | ||||
| 		optgroup = page->new_optgroup(_L("USB/Serial connection")); | ||||
| 			line = {_L("Serial port"), ""}; | ||||
| 		optgroup = page->new_optgroup(_(L("USB/Serial connection"))); | ||||
| 			line = {_(L("Serial port")), ""}; | ||||
| 			Option serial_port = optgroup->get_option("serial_port"); | ||||
| 			serial_port.side_widget = ([this](wxWindow* parent){ | ||||
| 				auto btn = new wxBitmapButton(parent, wxID_ANY, wxBitmap(wxString::FromUTF8(Slic3r::var("arrow_rotate_clockwise.png").c_str()), wxBITMAP_TYPE_PNG), | ||||
| 				auto btn = new wxBitmapButton(parent, wxID_ANY, wxBitmap(from_u8(Slic3r::var("arrow_rotate_clockwise.png")), wxBITMAP_TYPE_PNG), | ||||
| 					wxDefaultPosition, wxDefaultSize, wxBORDER_NONE); | ||||
| 				btn->SetToolTip(_L("Rescan serial ports")); | ||||
| 				btn->SetToolTip(_(L("Rescan serial ports"))); | ||||
| 				auto sizer = new wxBoxSizer(wxHORIZONTAL); | ||||
| 				sizer->Add(btn); | ||||
| 
 | ||||
|  | @ -1000,9 +1001,9 @@ void TabPrinter::build() | |||
| 			}); | ||||
| 			auto serial_test = [this](wxWindow* parent){ | ||||
| 				auto btn = m_serial_test_btn = new wxButton(parent, wxID_ANY, | ||||
| 					_L("Test"), wxDefaultPosition, wxDefaultSize, wxBU_LEFT | wxBU_EXACTFIT); | ||||
| 					_(L("Test")), wxDefaultPosition, wxDefaultSize, wxBU_LEFT | wxBU_EXACTFIT); | ||||
| //				btn->SetFont($Slic3r::GUI::small_font);
 | ||||
| 				btn->SetBitmap(wxBitmap(wxString::FromUTF8(Slic3r::var("wrench.png").c_str()), wxBITMAP_TYPE_PNG)); | ||||
| 				btn->SetBitmap(wxBitmap(from_u8(Slic3r::var("wrench.png")), wxBITMAP_TYPE_PNG)); | ||||
| 				auto sizer = new wxBoxSizer(wxHORIZONTAL); | ||||
| 				sizer->Add(btn); | ||||
| 
 | ||||
|  | @ -1013,10 +1014,10 @@ void TabPrinter::build() | |||
| 						m_config->opt_int("serial_speed") | ||||
| 						); | ||||
| 					if (res && sender->wait_connected()) { | ||||
| 						show_info(parent, _L("Connection to printer works correctly."), _L("Success!")); | ||||
| 						show_info(parent, _(L("Connection to printer works correctly.")), _(L("Success!"))); | ||||
| 					} | ||||
| 					else { | ||||
| 						show_error(parent, _L("Connection failed.")); | ||||
| 						show_error(parent, _(L("Connection failed."))); | ||||
| 					} | ||||
| 				}); | ||||
| 				return sizer; | ||||
|  | @ -1028,12 +1029,12 @@ void TabPrinter::build() | |||
| 			optgroup->append_line(line); | ||||
| 		} | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("OctoPrint upload")); | ||||
| 		optgroup = page->new_optgroup(_(L("OctoPrint upload"))); | ||||
| 		// # append two buttons to the Host line
 | ||||
| 		auto octoprint_host_browse = [this] (wxWindow* parent) { | ||||
| 			auto btn = new wxButton(parent, wxID_ANY, _L("Browse")+"\u2026", wxDefaultPosition, wxDefaultSize, wxBU_LEFT); | ||||
| 			auto btn = new wxButton(parent, wxID_ANY, _(L(" Browse "))+"\u2026", wxDefaultPosition, wxDefaultSize, wxBU_LEFT); | ||||
| //			btn->SetFont($Slic3r::GUI::small_font);
 | ||||
| 			btn->SetBitmap(wxBitmap(wxString::FromUTF8(Slic3r::var("zoom.png").c_str()), wxBITMAP_TYPE_PNG)); | ||||
| 			btn->SetBitmap(wxBitmap(from_u8(Slic3r::var("zoom.png")), wxBITMAP_TYPE_PNG)); | ||||
| 			auto sizer = new wxBoxSizer(wxHORIZONTAL); | ||||
| 			sizer->Add(btn); | ||||
| 
 | ||||
|  | @ -1043,7 +1044,7 @@ void TabPrinter::build() | |||
| 			btn->Bind(wxEVT_BUTTON, [this, parent](wxCommandEvent e){ | ||||
| 				if (m_event_button_browse > 0){ | ||||
| 					wxCommandEvent event(m_event_button_browse); | ||||
| 					event.SetString(_L("Button BROWSE was clicked!")); | ||||
| 					event.SetString(_(L("Button BROWSE was clicked!"))); | ||||
| 					g_wxMainFrame->ProcessWindowEvent(event); | ||||
| 				} | ||||
| // 				// # look for devices
 | ||||
|  | @ -1068,17 +1069,17 @@ void TabPrinter::build() | |||
| 		}; | ||||
| 
 | ||||
| 		auto octoprint_host_test = [this](wxWindow* parent) { | ||||
| 			auto btn = m_octoprint_host_test_btn = new wxButton(parent, wxID_ANY, _L("Test"),  | ||||
| 			auto btn = m_octoprint_host_test_btn = new wxButton(parent, wxID_ANY, _(L("Test")),  | ||||
| 				wxDefaultPosition, wxDefaultSize, wxBU_LEFT | wxBU_EXACTFIT); | ||||
| //			btn->SetFont($Slic3r::GUI::small_font);
 | ||||
| 			btn->SetBitmap(wxBitmap(wxString::FromUTF8(Slic3r::var("wrench.png").c_str()), wxBITMAP_TYPE_PNG)); | ||||
| 			btn->SetBitmap(wxBitmap(from_u8(Slic3r::var("wrench.png")), wxBITMAP_TYPE_PNG)); | ||||
| 			auto sizer = new wxBoxSizer(wxHORIZONTAL); | ||||
| 			sizer->Add(btn); | ||||
| 
 | ||||
| 			btn->Bind(wxEVT_BUTTON, [this, parent](wxCommandEvent e) { | ||||
| 				if (m_event_button_test > 0){ | ||||
| 					wxCommandEvent event(m_event_button_test); | ||||
| 					event.SetString(_L("Button TEST was clicked!")); | ||||
| 					event.SetString(_(L("Button TEST was clicked!"))); | ||||
| 					g_wxMainFrame->ProcessWindowEvent(event); | ||||
| 				} | ||||
| // 				my $ua = LWP::UserAgent->new;
 | ||||
|  | @ -1106,54 +1107,54 @@ void TabPrinter::build() | |||
| 		optgroup->append_line(host_line); | ||||
| 		optgroup->append_single_option_line("octoprint_apikey"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Firmware")); | ||||
| 		optgroup = page->new_optgroup(_(L("Firmware"))); | ||||
| 		optgroup->append_single_option_line("gcode_flavor"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Advanced")); | ||||
| 		optgroup = page->new_optgroup(_(L("Advanced"))); | ||||
| 		optgroup->append_single_option_line("use_relative_e_distances"); | ||||
| 		optgroup->append_single_option_line("use_firmware_retraction"); | ||||
| 		optgroup->append_single_option_line("use_volumetric_e"); | ||||
| 		optgroup->append_single_option_line("variable_layer_height"); | ||||
| 
 | ||||
| 	page = add_options_page(_L("Custom G-code"), "cog.png"); | ||||
| 		optgroup = page->new_optgroup(_L("Start G-code"), 0); | ||||
| 	page = add_options_page(_(L("Custom G-code")), "cog.png"); | ||||
| 		optgroup = page->new_optgroup(_(L("Start G-code")), 0); | ||||
| 		option = optgroup->get_option("start_gcode"); | ||||
| 		option.opt.full_width = true; | ||||
| 		option.opt.height = 150; | ||||
| 		optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("End G-code"), 0); | ||||
| 		optgroup = page->new_optgroup(_(L("End G-code")), 0); | ||||
| 		option = optgroup->get_option("end_gcode"); | ||||
| 		option.opt.full_width = true; | ||||
| 		option.opt.height = 150; | ||||
| 		optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Before layer change G-code"), 0); | ||||
| 		optgroup = page->new_optgroup(_(L("Before layer change G-code")), 0); | ||||
| 		option = optgroup->get_option("before_layer_gcode"); | ||||
| 		option.opt.full_width = true; | ||||
| 		option.opt.height = 150; | ||||
| 		optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("After layer change G-code"), 0); | ||||
| 		optgroup = page->new_optgroup(_(L("After layer change G-code")), 0); | ||||
| 		option = optgroup->get_option("layer_gcode"); | ||||
| 		option.opt.full_width = true; | ||||
| 		option.opt.height = 150; | ||||
| 		optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Tool change G-code"), 0); | ||||
| 		optgroup = page->new_optgroup(_(L("Tool change G-code")), 0); | ||||
| 		option = optgroup->get_option("toolchange_gcode"); | ||||
| 		option.opt.full_width = true; | ||||
| 		option.opt.height = 150; | ||||
| 		optgroup->append_single_option_line(option); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_L("Between objects G-code (for sequential printing)"), 0); | ||||
| 		optgroup = page->new_optgroup(_(L("Between objects G-code (for sequential printing)")), 0); | ||||
| 		option = optgroup->get_option("between_objects_gcode"); | ||||
| 		option.opt.full_width = true; | ||||
| 		option.opt.height = 150; | ||||
| 		optgroup->append_single_option_line(option); | ||||
| 	 | ||||
| 	page = add_options_page(_L("Notes"), "note.png"); | ||||
| 		optgroup = page->new_optgroup(_L("Notes"), 0); | ||||
| 	page = add_options_page(_(L("Notes")), "note.png"); | ||||
| 		optgroup = page->new_optgroup(_(L("Notes")), 0); | ||||
| 		option = optgroup->get_option("printer_notes"); | ||||
| 		option.opt.full_width = true; | ||||
| 		option.opt.height = 250; | ||||
|  | @ -1182,24 +1183,24 @@ void TabPrinter::extruders_count_changed(size_t extruders_count){ | |||
| void TabPrinter::build_extruder_pages(){ | ||||
| 	for (auto extruder_idx = m_extruder_pages.size(); extruder_idx < m_extruders_count; ++extruder_idx){ | ||||
| 		//# build page
 | ||||
| 		auto page = add_options_page(_L("Extruder ") + wxString::Format(_T("%i"), extruder_idx + 1), "funnel.png", true); | ||||
| 		auto page = add_options_page(_(L("Extruder ")) + wxString::Format(_T("%i"), extruder_idx + 1), "funnel.png", true); | ||||
| 		m_extruder_pages.push_back(page); | ||||
| 			 | ||||
| 			auto optgroup = page->new_optgroup(_L("Size")); | ||||
| 			auto optgroup = page->new_optgroup(_(L("Size"))); | ||||
| 			optgroup->append_single_option_line("nozzle_diameter", extruder_idx); | ||||
| 		 | ||||
| 			optgroup = page->new_optgroup(_L("Layer height limits")); | ||||
| 			optgroup = page->new_optgroup(_(L("Layer height limits"))); | ||||
| 			optgroup->append_single_option_line("min_layer_height", extruder_idx); | ||||
| 			optgroup->append_single_option_line("max_layer_height", extruder_idx); | ||||
| 				 | ||||
| 		 | ||||
| 			optgroup = page->new_optgroup(_L("Position (for multi-extruder printers)")); | ||||
| 			optgroup = page->new_optgroup(_(L("Position (for multi-extruder printers)"))); | ||||
| 			optgroup->append_single_option_line("extruder_offset", extruder_idx); | ||||
| 		 | ||||
| 			optgroup = page->new_optgroup(_L("Retraction")); | ||||
| 			optgroup = page->new_optgroup(_(L("Retraction"))); | ||||
| 			optgroup->append_single_option_line("retract_length", extruder_idx); | ||||
| 			optgroup->append_single_option_line("retract_lift", extruder_idx); | ||||
| 				Line line = { _L("Only lift Z"), "" }; | ||||
| 				Line line = { _(L("Only lift Z")), "" }; | ||||
| 				line.append_option(optgroup->get_option("retract_lift_above", extruder_idx)); | ||||
| 				line.append_option(optgroup->get_option("retract_lift_below", extruder_idx)); | ||||
| 				optgroup->append_line(line); | ||||
|  | @ -1212,11 +1213,11 @@ void TabPrinter::build_extruder_pages(){ | |||
| 			optgroup->append_single_option_line("wipe", extruder_idx); | ||||
| 			optgroup->append_single_option_line("retract_before_wipe", extruder_idx); | ||||
| 	 | ||||
| 			optgroup = page->new_optgroup(_L("Retraction when tool is disabled (advanced settings for multi-extruder setups)")); | ||||
| 			optgroup = page->new_optgroup(_(L("Retraction when tool is disabled (advanced settings for multi-extruder setups)"))); | ||||
| 			optgroup->append_single_option_line("retract_length_toolchange", extruder_idx); | ||||
| 			optgroup->append_single_option_line("retract_restart_extra_toolchange", extruder_idx); | ||||
| 
 | ||||
| 			optgroup = page->new_optgroup(_L("Preview")); | ||||
| 			optgroup = page->new_optgroup(_(L("Preview"))); | ||||
| 			optgroup->append_single_option_line("extruder_colour", extruder_idx); | ||||
| 	} | ||||
|   | ||||
|  | @ -1228,7 +1229,7 @@ void TabPrinter::build_extruder_pages(){ | |||
| 	// # rebuild page list
 | ||||
| 	PageShp page_note = m_pages.back(); | ||||
| 	m_pages.pop_back(); | ||||
| 	while (m_pages.back()->title().find(_L("Extruder")) != std::string::npos) | ||||
| 	while (m_pages.back()->title().find(_(L("Extruder"))) != std::string::npos) | ||||
| 		m_pages.pop_back(); | ||||
| 	for (auto page_extruder : m_extruder_pages) | ||||
| 		m_pages.push_back(page_extruder); | ||||
|  | @ -1306,9 +1307,9 @@ void TabPrinter::update(){ | |||
| 
 | ||||
| 		if (use_firmware_retraction && wipe) { | ||||
| 			auto dialog = new wxMessageDialog(parent(), | ||||
| 				_L("The Wipe option is not available when using the Firmware Retraction mode.\n" | ||||
| 				"\nShall I disable it in order to enable Firmware Retraction?"), | ||||
| 				_L("Firmware Retraction"), wxICON_WARNING | wxYES | wxNO); | ||||
| 				_(L("The Wipe option is not available when using the Firmware Retraction mode.\n" | ||||
| 				"\nShall I disable it in order to enable Firmware Retraction?")), | ||||
| 				_(L("Firmware Retraction")), wxICON_WARNING | wxYES | wxNO); | ||||
| 
 | ||||
| 			DynamicPrintConfig new_conf = *m_config; | ||||
| 			if (dialog->ShowModal() == wxID_YES) { | ||||
|  | @ -1463,8 +1464,8 @@ bool Tab::may_discard_current_dirty_preset(PresetCollection* presets /*= nullptr | |||
| 	auto type_name = presets->name(); | ||||
| 	auto tab = "          "; | ||||
| 	auto name = old_preset.is_default ? | ||||
| 		_L("Default ") + type_name + _L(" preset") : | ||||
| 		(type_name + _L(" preset\n") + tab + old_preset.name); | ||||
| 		_(L("Default ")) + type_name + _(L(" preset")) : | ||||
| 		(type_name + _(L(" preset\n")) + tab + old_preset.name); | ||||
| 	// Collect descriptions of the dirty options.
 | ||||
| 	std::vector<std::string> option_names; | ||||
| 	for(auto opt_key: presets->current_dirty_options()) { | ||||
|  | @ -1482,11 +1483,11 @@ bool Tab::may_discard_current_dirty_preset(PresetCollection* presets /*= nullptr | |||
| 	for (auto changed_name : option_names) | ||||
| 		changes += tab + changed_name + "\n"; | ||||
| 	auto message = (!new_printer_name.empty()) ? | ||||
| 		name + _L("\n\nis not compatible with printer\n") +tab + new_printer_name+ _L("\n\nand it has the following unsaved changes:") : | ||||
| 		name + _L("\n\nhas the following unsaved changes:"); | ||||
| 		name + _(L("\n\nis not compatible with printer\n")) +tab + new_printer_name+ _(L("\n\nand it has the following unsaved changes:")) : | ||||
| 		name + _(L("\n\nhas the following unsaved changes:")); | ||||
| 	auto confirm = new wxMessageDialog(parent(), | ||||
| 		message + "\n" +changes +_L("\n\nDiscard changes and continue anyway?"), | ||||
| 		_L("Unsaved Changes"), wxYES_NO | wxNO_DEFAULT | wxICON_QUESTION); | ||||
| 		message + "\n" +changes +_(L("\n\nDiscard changes and continue anyway?")), | ||||
| 		_(L("Unsaved Changes")), wxYES_NO | wxNO_DEFAULT | wxICON_QUESTION); | ||||
| 	return confirm->ShowModal() == wxID_YES; | ||||
| } | ||||
| 
 | ||||
|  | @ -1554,21 +1555,13 @@ void Tab::save_preset(std::string name /*= ""*/) | |||
| 			return; | ||||
| 		name = dlg->get_name(); | ||||
| 		if (name == ""){ | ||||
| 			show_error(this, _L("The supplied name is empty. It can't be saved.")); | ||||
| 			show_error(this, _(L("The supplied name is empty. It can't be saved."))); | ||||
| 			return; | ||||
| 		} | ||||
| 	} | ||||
| 	try | ||||
| 	{ | ||||
| 		// Save the preset into Slic3r::data_dir / presets / section_name / preset_name.ini
 | ||||
| 		m_presets->save_current_preset(name); | ||||
| 	} | ||||
| 	catch (const std::exception &e) | ||||
| 	{ | ||||
| 		show_error(this, _L("Something is wrong. It can't be saved.")); | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
| 	// Save the preset into Slic3r::data_dir / presets / section_name / preset_name.ini
 | ||||
| 	m_presets->save_current_preset(name); | ||||
| 	// Mark the print & filament enabled if they are compatible with the currently selected preset.
 | ||||
| 	m_preset_bundle->update_compatible_with_printer(false); | ||||
| 	// Add the new item into the UI component, remove dirty flags and activate the saved item.
 | ||||
|  | @ -1582,10 +1575,10 @@ void Tab::delete_preset() | |||
| { | ||||
| 	auto current_preset = m_presets->get_selected_preset(); | ||||
| 	// Don't let the user delete the ' - default - ' configuration.
 | ||||
| 	wxString action = current_preset.is_external ? _L("remove") : _L("delete"); | ||||
| 	wxString msg = _L("Are you sure you want to ") + action + _L(" the selected preset?"); | ||||
| 	action = current_preset.is_external ? _L("Remove") : _L("Delete"); | ||||
| 	wxString title = action + _L(" Preset"); | ||||
| 	wxString action = current_preset.is_external ? _(L("remove")) : _(L("delete")); | ||||
| 	wxString msg = _(L("Are you sure you want to ")) + action + _(L(" the selected preset?")); | ||||
| 	action = current_preset.is_external ? _(L("Remove")) : _(L("Delete")); | ||||
| 	wxString title = action + _(L(" Preset")); | ||||
| 	if (current_preset.is_default || | ||||
| 		wxID_YES != wxMessageDialog(parent(), msg, title, wxYES_NO | wxNO_DEFAULT | wxICON_QUESTION).ShowModal()) | ||||
| 		return; | ||||
|  | @ -1637,10 +1630,10 @@ void Tab::update_ui_from_settings() | |||
| // Return a callback to create a Tab widget to mark the preferences as compatible / incompatible to the current printer.
 | ||||
| wxSizer* Tab::compatible_printers_widget(wxWindow* parent, wxCheckBox** checkbox, wxButton** btn) | ||||
| { | ||||
| 	*checkbox = new wxCheckBox(parent, wxID_ANY, _L("All")); | ||||
| 	*btn = new wxButton(parent, wxID_ANY, _L("Set")+"\u2026", wxDefaultPosition, wxDefaultSize, wxBU_LEFT | wxBU_EXACTFIT); | ||||
| 	*checkbox = new wxCheckBox(parent, wxID_ANY, _(L("All"))); | ||||
| 	*btn = new wxButton(parent, wxID_ANY, _(L(" Set "))+"\u2026", wxDefaultPosition, wxDefaultSize, wxBU_LEFT | wxBU_EXACTFIT); | ||||
| 
 | ||||
| 	(*btn)->SetBitmap(wxBitmap(wxString::FromUTF8(Slic3r::var("printer_empty.png").c_str()), wxBITMAP_TYPE_PNG)); | ||||
| 	(*btn)->SetBitmap(wxBitmap(from_u8(Slic3r::var("printer_empty.png")), wxBITMAP_TYPE_PNG)); | ||||
| 
 | ||||
| 	auto sizer = new wxBoxSizer(wxHORIZONTAL); | ||||
| 	sizer->Add((*checkbox), 0, wxALIGN_CENTER_VERTICAL); | ||||
|  | @ -1668,8 +1661,8 @@ wxSizer* Tab::compatible_printers_widget(wxWindow* parent, wxCheckBox** checkbox | |||
| 		} | ||||
| 
 | ||||
| 		auto dlg = new wxMultiChoiceDialog(parent, | ||||
| 		_L("Select the printers this profile is compatible with."), | ||||
| 		_L("Compatible printers"),  presets); | ||||
| 		_(L("Select the printers this profile is compatible with.")), | ||||
| 		_(L("Compatible printers")),  presets); | ||||
| 		// # Collect and set indices of printers marked as compatible.
 | ||||
| 		wxArrayInt selections; | ||||
| 		auto *compatible_printers = dynamic_cast<const ConfigOptionStrings*>(m_config->option("compatible_printers")); | ||||
|  | @ -1752,12 +1745,12 @@ ConfigOptionsGroupShp Page::new_optgroup(wxString title, int noncommon_label_wid | |||
| 
 | ||||
| void SavePresetWindow::build(wxString title, std::string default_name, std::vector<std::string> &values) | ||||
| { | ||||
| 	auto text = new wxStaticText(this, wxID_ANY, _L("Save ") + title + _L(" as:"),  | ||||
| 	auto text = new wxStaticText(this, wxID_ANY, _(L("Save ")) + title + _(L(" as:")),  | ||||
| 									wxDefaultPosition, wxDefaultSize); | ||||
| 	m_combo = new wxComboBox(this, wxID_ANY, wxString::FromUTF8(default_name.c_str()),  | ||||
| 	m_combo = new wxComboBox(this, wxID_ANY, from_u8(default_name),  | ||||
| 							wxDefaultPosition, wxDefaultSize, 0, 0, wxTE_PROCESS_ENTER); | ||||
| 	for (auto value : values) | ||||
| 		m_combo->Append(wxString::FromUTF8(value.c_str())); | ||||
| 		m_combo->Append(from_u8(value)); | ||||
| 	auto buttons = CreateStdDialogButtonSizer(wxOK | wxCANCEL); | ||||
| 
 | ||||
| 	auto sizer = new wxBoxSizer(wxVERTICAL); | ||||
|  | @ -1786,10 +1779,10 @@ void SavePresetWindow::accept() | |||
| 			} | ||||
| 		} | ||||
| 		if (is_unusable_symbol) { | ||||
| 			show_error(this, _L("The supplied name is not valid; the following characters are not allowed:")+" <>:/\\|?*\""); | ||||
| 			show_error(this, _(L("The supplied name is not valid; the following characters are not allowed:"))+" <>:/\\|?*\""); | ||||
| 		} | ||||
| 		else if (m_chosen_name.compare("- default -") == 0) { | ||||
| 			show_error(this, _L("The supplied name is not available.")); | ||||
| 			show_error(this, _(L("The supplied name is not available."))); | ||||
| 		} | ||||
| 		else { | ||||
| 			EndModal(wxID_OK); | ||||
|  |  | |||
|  | @ -179,7 +179,7 @@ class TabPrint : public Tab | |||
| public: | ||||
| 	TabPrint() {} | ||||
| 	TabPrint(wxNotebook* parent, bool no_controller) :  | ||||
| 		Tab(parent, _L("Print Settings"), "print", no_controller) {} | ||||
| 		Tab(parent, _(L("Print Settings")), "print", no_controller) {} | ||||
| 	~TabPrint(){} | ||||
| 
 | ||||
| 	ogStaticText*	m_recommended_thin_wall_thickness_description_line; | ||||
|  | @ -199,7 +199,7 @@ class TabFilament : public Tab | |||
| public: | ||||
| 	TabFilament() {} | ||||
| 	TabFilament(wxNotebook* parent, bool no_controller) :  | ||||
| 		Tab(parent, _L("Filament Settings"), "filament", no_controller) {} | ||||
| 		Tab(parent, _(L("Filament Settings")), "filament", no_controller) {} | ||||
| 	~TabFilament(){} | ||||
| 
 | ||||
| 	void		build() override; | ||||
|  | @ -225,7 +225,7 @@ public: | |||
| 
 | ||||
| 	TabPrinter() {} | ||||
| 	TabPrinter(wxNotebook* parent, bool no_controller, bool is_disabled_btn_browse, bool is_user_agent) : | ||||
| 		Tab(parent, _L("Printer Settings"), "printer", no_controller), | ||||
| 		Tab(parent, _(L("Printer Settings")), "printer", no_controller), | ||||
| 		m_is_disabled_button_browse(is_disabled_btn_browse),  | ||||
| 		m_is_user_agent(is_user_agent) {} | ||||
| 	~TabPrinter(){} | ||||
|  | @ -245,7 +245,7 @@ public: | |||
| class SavePresetWindow :public wxDialog | ||||
| { | ||||
| public: | ||||
| 	SavePresetWindow(wxWindow* parent) :wxDialog(parent, wxID_ANY, _L("Save preset")){} | ||||
| 	SavePresetWindow(wxWindow* parent) :wxDialog(parent, wxID_ANY, _(L("Save preset"))){} | ||||
| 	~SavePresetWindow(){} | ||||
| 
 | ||||
| 	std::string		m_chosen_name; | ||||
|  |  | |||
|  | @ -11,7 +11,7 @@ void	TabIface::load_config(DynamicPrintConfig* config)	{ m_tab->load_config(*con | |||
| void	TabIface::load_key_value(char* opt_key, char* value){ m_tab->load_key_value(opt_key, static_cast<std::string>(value)); } | ||||
| bool	TabIface::current_preset_is_dirty()					{ return m_tab->current_preset_is_dirty();} | ||||
| void	TabIface::OnActivate()								{ return m_tab->OnActivate();} | ||||
| std::string					TabIface::title()				{ return m_tab->title().ToStdString();} | ||||
| std::string					TabIface::title()				{ return m_tab->title().ToUTF8().data(); } | ||||
| DynamicPrintConfig*			TabIface::get_config()			{ return m_tab->get_config(); } | ||||
| PresetCollection*			TabIface::get_presets()			{ return m_tab!=nullptr ? m_tab->get_presets() : nullptr; } | ||||
| std::vector<std::string>	TabIface::get_dependent_tabs()	{ return m_tab->get_dependent_tabs(); } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bubnikv
						bubnikv