mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-22 08:11:11 -06:00 
			
		
		
		
	Merge branch 'master' of https://github.com/prusa3d/Slic3r into opengl_to_cpp
This commit is contained in:
		
						commit
						f4a687703c
					
				
					 11 changed files with 96 additions and 53 deletions
				
			
		|  | @ -308,6 +308,8 @@ enum ConfigMenuIDs { | |||
| 	ConfigMenuCnt, | ||||
| }; | ||||
| 
 | ||||
| static wxString dots("…", wxConvUTF8); | ||||
| 
 | ||||
| void add_config_menu(wxMenuBar *menu, int event_preferences_changed, int event_language_change) | ||||
| { | ||||
|     auto local_menu = new wxMenu(); | ||||
|  | @ -315,12 +317,12 @@ void add_config_menu(wxMenuBar *menu, int event_preferences_changed, int event_l | |||
| 
 | ||||
|     const auto config_wizard_tooltip = wxString::Format(_(L("Run %s")), ConfigWizard::name()); | ||||
|     // Cmd+, is standard on OS X - what about other operating systems?
 | ||||
|    	local_menu->Append(config_id_base + ConfigMenuWizard, 		ConfigWizard::name() + "\u2026", 			config_wizard_tooltip); | ||||
|    	local_menu->Append(config_id_base + ConfigMenuSnapshots, 	_(L("Configuration Snapshots"))+"\u2026",	_(L("Inspect / activate configuration snapshots"))); | ||||
|    	local_menu->Append(config_id_base + ConfigMenuWizard, 		ConfigWizard::name() + dots, 			config_wizard_tooltip); | ||||
|    	local_menu->Append(config_id_base + ConfigMenuSnapshots, 	_(L("Configuration Snapshots"))+dots,	_(L("Inspect / activate configuration snapshots"))); | ||||
|    	local_menu->Append(config_id_base + ConfigMenuTakeSnapshot, _(L("Take Configuration Snapshot")), 		_(L("Capture a configuration snapshot"))); | ||||
| // 	local_menu->Append(config_id_base + ConfigMenuUpdate, 		_(L("Check for updates")), 					_(L("Check for configuration updates")));
 | ||||
|    	local_menu->AppendSeparator(); | ||||
|    	local_menu->Append(config_id_base + ConfigMenuPreferences, 	_(L("Preferences"))+"\u2026\tCtrl+,", 		_(L("Application preferences"))); | ||||
|    	local_menu->Append(config_id_base + ConfigMenuPreferences, 	_(L("Preferences"))+dots+"\tCtrl+,", 		_(L("Application preferences"))); | ||||
|    	local_menu->Append(config_id_base + ConfigMenuLanguage, 	_(L("Change Application Language"))); | ||||
|    	local_menu->AppendSeparator(); | ||||
| 	local_menu->Append(config_id_base + ConfigMenuFlashFirmware, _(L("Flash printer firmware")), _(L("Upload a firmware image into an Arduino based printer"))); | ||||
|  | @ -356,8 +358,7 @@ void add_config_menu(wxMenuBar *menu, int event_preferences_changed, int event_l | |||
| 		    			Config::SnapshotDB::singleton().restore_snapshot(dlg.snapshot_to_activate(), *g_AppConfig).id); | ||||
| 		    		g_PresetBundle->load_presets(*g_AppConfig); | ||||
| 		    		// Load the currently selected preset into the GUI, update the preset selection box.
 | ||||
| 					for (Tab *tab : g_tabs_list) | ||||
| 						tab->load_current_preset(); | ||||
| 					load_current_presets(); | ||||
| 		    	} | ||||
| 		    } | ||||
| 		    break; | ||||
|  | @ -451,9 +452,8 @@ void config_wizard(int reason) | |||
| 		show_error(nullptr, e.what()); | ||||
| 	} | ||||
| 
 | ||||
|     // Load the currently selected preset into the GUI, update the preset selection box.
 | ||||
| 	for (Tab *tab : g_tabs_list) | ||||
| 		tab->load_current_preset(); | ||||
| 	// Load the currently selected preset into the GUI, update the preset selection box.
 | ||||
| 	load_current_presets(); | ||||
| } | ||||
| 
 | ||||
| void open_preferences_dialog(int event_preferences) | ||||
|  | @ -605,6 +605,13 @@ void add_created_tab(Tab* panel) | |||
| 	g_wxTabPanel->AddPage(panel, panel->title()); | ||||
| } | ||||
| 
 | ||||
| void load_current_presets() | ||||
| { | ||||
| 	for (Tab *tab : g_tabs_list) { | ||||
| 		tab->load_current_preset(); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| void show_error(wxWindow* parent, const wxString& message) { | ||||
| 	ErrorDialog msg(parent, message); | ||||
| 	msg.ShowModal(); | ||||
|  | @ -841,7 +848,7 @@ void add_frequently_changed_parameters(wxWindow* parent, wxBoxSizer* sizer, wxFl | |||
| 
 | ||||
|     Line line = { "", "" }; | ||||
|         line.widget = [config](wxWindow* parent){ | ||||
| 			g_wiping_dialog_button = new wxButton(parent, wxID_ANY, _(L("Purging volumes")) + "\u2026", wxDefaultPosition, wxDefaultSize, wxBU_EXACTFIT); | ||||
| 			g_wiping_dialog_button = new wxButton(parent, wxID_ANY, _(L("Purging volumes")) + dots, wxDefaultPosition, wxDefaultSize, wxBU_EXACTFIT); | ||||
| 			auto sizer = new wxBoxSizer(wxHORIZONTAL); | ||||
| 			sizer->Add(g_wiping_dialog_button); | ||||
| 			g_wiping_dialog_button->Bind(wxEVT_BUTTON, ([parent](wxCommandEvent& e) | ||||
|  |  | |||
|  | @ -5,6 +5,9 @@ | |||
| #include <vector> | ||||
| #include "Config.hpp" | ||||
| 
 | ||||
| #include <wx/intl.h> | ||||
| #include <wx/string.h> | ||||
| 
 | ||||
| class wxApp; | ||||
| class wxWindow; | ||||
| class wxFrame; | ||||
|  | @ -30,6 +33,12 @@ class PresetUpdater; | |||
| class DynamicPrintConfig; | ||||
| class TabIface; | ||||
| 
 | ||||
| #define _(s)    Slic3r::translate((s)) | ||||
| inline wxString translate(const char *s)    	 { return wxGetTranslation(wxString(s, wxConvUTF8)); } | ||||
| inline wxString translate(const wchar_t *s) 	 { return wxGetTranslation(s); } | ||||
| inline wxString translate(const std::string &s)  { return wxGetTranslation(wxString(s.c_str(), wxConvUTF8)); } | ||||
| inline wxString translate(const std::wstring &s) { return wxGetTranslation(s.c_str()); } | ||||
| 
 | ||||
| // !!! If you needed to translate some wxString,
 | ||||
| // !!! please use _(L(string))
 | ||||
| // !!! _() - is a standard wxWidgets macro to translate
 | ||||
|  | @ -116,6 +125,9 @@ void add_created_tab(Tab* panel); | |||
| // Change option value in config
 | ||||
| void change_opt_value(DynamicPrintConfig& config, const t_config_option_key& opt_key, const boost::any& value, int opt_index = 0); | ||||
| 
 | ||||
| // Update UI / Tabs to reflect changes in the currently loaded presets
 | ||||
| void load_current_presets(); | ||||
| 
 | ||||
| void show_error(wxWindow* parent, const wxString& message); | ||||
| void show_error_id(int id, const std::string& message);   // For Perl
 | ||||
| void show_info(wxWindow* parent, const wxString& message, const wxString& title); | ||||
|  |  | |||
|  | @ -101,6 +101,7 @@ PresetBundle::~PresetBundle() | |||
| void PresetBundle::reset(bool delete_files) | ||||
| { | ||||
|     // Clear the existing presets, delete their respective files.
 | ||||
|     this->vendors.clear(); | ||||
|     this->prints   .reset(delete_files); | ||||
|     this->filaments.reset(delete_files); | ||||
|     this->printers .reset(delete_files); | ||||
|  |  | |||
|  | @ -2,12 +2,7 @@ | |||
| #include <wx/dcbuffer.h> | ||||
| 
 | ||||
| #include "RammingChart.hpp" | ||||
| 
 | ||||
| 
 | ||||
| //! macro used to mark string used at localization,
 | ||||
| //! return same string
 | ||||
| #define L(s) s | ||||
| 
 | ||||
| #include "GUI.hpp" | ||||
| 
 | ||||
| 
 | ||||
| wxDEFINE_EVENT(EVT_WIPE_TOWER_CHART_CHANGED, wxCommandEvent); | ||||
|  | @ -83,7 +78,7 @@ void Chart::draw() { | |||
|     int text_height = 0; | ||||
|     dc.GetTextExtent(label,&text_width,&text_height); | ||||
|     dc.DrawText(label,wxPoint(0.5*(m_rect.GetRight()+m_rect.GetLeft())-text_width/2.f, m_rect.GetBottom()+25)); | ||||
|     label = _(L("Volumetric speed")) + " (" + _(L("mm")) + "\u00B3/" + _(L("s")) + ")"; | ||||
|     label = _(L("Volumetric speed")) + " (" + _(L("mm")) + wxString("³/", wxConvUTF8) + _(L("s")) + ")"; | ||||
|     dc.GetTextExtent(label,&text_width,&text_height); | ||||
|     dc.DrawRotatedText(label,wxPoint(0,0.5*(m_rect.GetBottom()+m_rect.GetTop())+text_width/2.f),90); | ||||
| } | ||||
|  |  | |||
|  | @ -32,6 +32,8 @@ | |||
| namespace Slic3r { | ||||
| namespace GUI { | ||||
| 
 | ||||
| static wxString dots("…", wxConvUTF8); | ||||
| 
 | ||||
| // sub new
 | ||||
| void Tab::create_preset_tab(PresetBundle *preset_bundle) | ||||
| { | ||||
|  | @ -1261,7 +1263,7 @@ void TabFilament::build() | |||
| 		optgroup->append_single_option_line("filament_density"); | ||||
| 		optgroup->append_single_option_line("filament_cost"); | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_(L("Temperature ")) +" (\u00B0C)"); // degree sign
 | ||||
| 		optgroup = page->new_optgroup(_(L("Temperature ")) + wxString("°C", wxConvUTF8)); | ||||
| 		Line line = { _(L("Extruder")), "" }; | ||||
| 		line.append_option(optgroup->get_option("first_layer_temperature")); | ||||
| 		line.append_option(optgroup->get_option("temperature")); | ||||
|  | @ -1319,7 +1321,7 @@ void TabFilament::build() | |||
|         optgroup->append_single_option_line("filament_toolchange_delay"); | ||||
|         line = { _(L("Ramming")), "" }; | ||||
|         line.widget = [this](wxWindow* parent){ | ||||
| 			auto ramming_dialog_btn = new wxButton(parent, wxID_ANY, _(L("Ramming settings"))+"\u2026", wxDefaultPosition, wxDefaultSize, wxBU_EXACTFIT); | ||||
| 			auto ramming_dialog_btn = new wxButton(parent, wxID_ANY, _(L("Ramming settings"))+dots, wxDefaultPosition, wxDefaultSize, wxBU_EXACTFIT); | ||||
|             auto sizer = new wxBoxSizer(wxHORIZONTAL); | ||||
| 			sizer->Add(ramming_dialog_btn); | ||||
|              | ||||
|  | @ -1441,7 +1443,7 @@ void TabPrinter::build() | |||
| 
 | ||||
| 		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); | ||||
| 			auto btn = new wxButton(parent, wxID_ANY, _(L(" Set "))+dots, 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)); | ||||
| 
 | ||||
|  | @ -1540,7 +1542,7 @@ void TabPrinter::build() | |||
| 		optgroup = page->new_optgroup(_(L("OctoPrint upload"))); | ||||
| 
 | ||||
| 		auto octoprint_host_browse = [this, optgroup] (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 "))+dots, wxDefaultPosition, wxDefaultSize, wxBU_LEFT); | ||||
| 			btn->SetBitmap(wxBitmap(from_u8(Slic3r::var("zoom.png")), wxBITMAP_TYPE_PNG)); | ||||
| 			auto sizer = new wxBoxSizer(wxHORIZONTAL); | ||||
| 			sizer->Add(btn); | ||||
|  | @ -1589,7 +1591,7 @@ void TabPrinter::build() | |||
| 			Line cafile_line = optgroup->create_single_option_line("octoprint_cafile"); | ||||
| 
 | ||||
| 			auto octoprint_cafile_browse = [this, optgroup] (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 "))+dots, wxDefaultPosition, wxDefaultSize, wxBU_LEFT); | ||||
| 				btn->SetBitmap(wxBitmap(from_u8(Slic3r::var("zoom.png")), wxBITMAP_TYPE_PNG)); | ||||
| 				auto sizer = new wxBoxSizer(wxHORIZONTAL); | ||||
| 				sizer->Add(btn); | ||||
|  | @ -2211,7 +2213,7 @@ void Tab::update_ui_from_settings() | |||
| 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); | ||||
| 	*btn = new wxButton(parent, wxID_ANY, _(L(" Set "))+dots, wxDefaultPosition, wxDefaultSize, wxBU_LEFT | wxBU_EXACTFIT); | ||||
| 
 | ||||
| 	(*btn)->SetBitmap(wxBitmap(from_u8(Slic3r::var("printer_empty.png")), wxBITMAP_TYPE_PNG)); | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,15 +1,10 @@ | |||
| #include <algorithm> | ||||
| #include <sstream> | ||||
| #include "WipeTowerDialog.hpp" | ||||
| #include "GUI.hpp" | ||||
| 
 | ||||
| #include <wx/sizer.h> | ||||
| 
 | ||||
| //! macro used to mark string used at localization,
 | ||||
| //! return same string
 | ||||
| #define L(s) s | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| RammingDialog::RammingDialog(wxWindow* parent,const std::string& parameters) | ||||
| : wxDialog(parent, wxID_ANY, _(L("Ramming customization")), wxDefaultPosition, wxDefaultSize, wxDEFAULT_DIALOG_STYLE/* | wxRESIZE_BORDER*/) | ||||
| { | ||||
|  | @ -81,7 +76,7 @@ RammingPanel::RammingPanel(wxWindow* parent, const std::string& parameters) | |||
| 	auto gsizer_param = new wxFlexGridSizer(2, 5, 15); | ||||
| 	gsizer_param->Add(new wxStaticText(this, wxID_ANY, wxString(_(L("Total ramming time")) + " (" + _(L("s")) + "):")), 0, wxALIGN_CENTER_VERTICAL); | ||||
| 	gsizer_param->Add(m_widget_time); | ||||
| 	gsizer_param->Add(new wxStaticText(this, wxID_ANY, wxString(_(L("Total rammed volume")) + " (" + _(L("mm")) + "\u00B3):")), 0, wxALIGN_CENTER_VERTICAL); | ||||
| 	gsizer_param->Add(new wxStaticText(this, wxID_ANY, wxString(_(L("Total rammed volume")) + " (" + _(L("mm")) + wxString("³):", wxConvUTF8))), 0, wxALIGN_CENTER_VERTICAL); | ||||
| 	gsizer_param->Add(m_widget_volume); | ||||
| 	gsizer_param->AddSpacer(20); | ||||
| 	gsizer_param->AddSpacer(20); | ||||
|  | @ -220,7 +215,7 @@ WipingPanel::WipingPanel(wxWindow* parent, const std::vector<float>& matrix, con | |||
| 
 | ||||
| 	// collect and format sizer
 | ||||
| 	format_sizer(m_sizer_advanced, m_page_advanced, m_gridsizer_advanced, | ||||
| 		wxString::Format(_(L("Here you can adjust required purging volume (mm%s) for any given pair of tools.")), "\u00B3"), | ||||
| 		_(L("Here you can adjust required purging volume (mm³) for any given pair of tools.")), | ||||
| 		_(L("Extruder changed to"))); | ||||
| 
 | ||||
| 	// Hide preview page before new page creating 
 | ||||
|  | @ -243,7 +238,7 @@ WipingPanel::WipingPanel(wxWindow* parent, const std::vector<float>& matrix, con | |||
| 	// collect and format sizer
 | ||||
| 	format_sizer(m_sizer_simple, m_page_simple, gridsizer_simple, | ||||
| 		_(L("Total purging volume is calculated by summing two values below, depending on which tools are loaded/unloaded.")), | ||||
| 		wxString::Format(_(L("Volume to purge (mm%s) when the filament is being")), "\u00B3"), 50); | ||||
| 		_(L("Volume to purge (mm³) when the filament is being")), 50); | ||||
| 
 | ||||
| 	m_sizer = new wxBoxSizer(wxVERTICAL); | ||||
| 	m_sizer->Add(m_page_simple, 0, wxEXPAND | wxALL, 25); | ||||
|  |  | |||
|  | @ -162,7 +162,7 @@ bool PresetUpdater::priv::get_file(const std::string &url, const fs::path &targe | |||
| 				% http_status | ||||
| 				% error; | ||||
| 		}) | ||||
| 		.on_complete([&](std::string body, unsigned http_status) { | ||||
| 		.on_complete([&](std::string body, unsigned /* http_status */) { | ||||
| 			fs::fstream file(tmp_path, std::ios::out | std::ios::binary | std::ios::trunc); | ||||
| 			file.write(body.c_str(), body.size()); | ||||
| 			file.close(); | ||||
|  | @ -204,7 +204,7 @@ void PresetUpdater::priv::sync_version() const | |||
| 				% http_status | ||||
| 				% error; | ||||
| 		}) | ||||
| 		.on_complete([&](std::string body, unsigned http_status) { | ||||
| 		.on_complete([&](std::string body, unsigned /* http_status */) { | ||||
| 			boost::trim(body); | ||||
| 			BOOST_LOG_TRIVIAL(info) << boost::format("Got Slic3rPE online version: `%1%`. Sending to GUI thread...") % body; | ||||
| 			wxCommandEvent* evt = new wxCommandEvent(version_online_event); | ||||
|  | @ -553,6 +553,12 @@ bool PresetUpdater::config_update() const | |||
| 		if (res == wxID_OK) { | ||||
| 			BOOST_LOG_TRIVIAL(debug) << "User agreed to perform the update"; | ||||
| 			p->perform_updates(std::move(updates)); | ||||
| 
 | ||||
| 			// Reload global configuration
 | ||||
| 			auto *app_config = GUI::get_app_config(); | ||||
| 			app_config->reset_selections(); | ||||
| 			GUI::get_preset_bundle()->load_presets(*app_config); | ||||
| 			GUI::load_current_presets(); | ||||
| 		} else { | ||||
| 			BOOST_LOG_TRIVIAL(info) << "User refused the update"; | ||||
| 		} | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Enrico Turri
						Enrico Turri