mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 09:41:11 -06:00 
			
		
		
		
	Added possibility for upload to Duet
Further changes: - Added new configuration option Host Type - Added abstract base class for future printer hosts - Moved location of upload dialog (also made it a little bit more configureable) - added possibility to send file via postfield instead a new frame
This commit is contained in:
		
							parent
							
								
									3433e8e374
								
							
						
					
					
						commit
						dd1fd66a47
					
				
					 29 changed files with 699 additions and 128 deletions
				
			
		|  | @ -586,6 +586,8 @@ boost::any& Choice::get_value() | |||
| 			m_value = static_cast<SupportMaterialPattern>(ret_enum); | ||||
| 		else if (m_opt_id.compare("seam_position") == 0) | ||||
| 			m_value = static_cast<SeamPosition>(ret_enum); | ||||
| 		else if (m_opt_id.compare("host_type") == 0) | ||||
| 			m_value = static_cast<PrintHostType>(ret_enum); | ||||
| 	}	 | ||||
| 
 | ||||
| 	return m_value; | ||||
|  |  | |||
|  | @ -604,6 +604,8 @@ void change_opt_value(DynamicPrintConfig& config, const t_config_option_key& opt | |||
| 				config.set_key_value(opt_key, new ConfigOptionEnum<SupportMaterialPattern>(boost::any_cast<SupportMaterialPattern>(value))); | ||||
| 			else if (opt_key.compare("seam_position") == 0) | ||||
| 				config.set_key_value(opt_key, new ConfigOptionEnum<SeamPosition>(boost::any_cast<SeamPosition>(value))); | ||||
| 			else if (opt_key.compare("host_type") == 0) | ||||
| 				config.set_key_value(opt_key, new ConfigOptionEnum<PrintHostType>(boost::any_cast<PrintHostType>(value))); | ||||
| 			} | ||||
| 			break; | ||||
| 		case coPoints:{ | ||||
|  |  | |||
|  | @ -459,8 +459,12 @@ boost::any ConfigOptionsGroup::get_config_value(const DynamicPrintConfig& config | |||
| 		else if (opt_key.compare("support_material_pattern") == 0){ | ||||
| 			ret = static_cast<int>(config.option<ConfigOptionEnum<SupportMaterialPattern>>(opt_key)->value); | ||||
| 		} | ||||
| 		else if (opt_key.compare("seam_position") == 0) | ||||
| 		else if (opt_key.compare("seam_position") == 0){ | ||||
| 			ret = static_cast<int>(config.option<ConfigOptionEnum<SeamPosition>>(opt_key)->value); | ||||
| 		} | ||||
| 		else if (opt_key.compare("host_type") == 0){ | ||||
| 			ret = static_cast<int>(config.option<ConfigOptionEnum<PrintHostType>>(opt_key)->value); | ||||
| 		} | ||||
| 	} | ||||
| 		break; | ||||
| 	case coPoints: | ||||
|  |  | |||
|  | @ -329,8 +329,8 @@ const std::vector<std::string>& Preset::printer_options() | |||
|     static std::vector<std::string> s_opts; | ||||
|     if (s_opts.empty()) { | ||||
|         s_opts = { | ||||
|             "bed_shape", "z_offset", "gcode_flavor", "use_relative_e_distances", "serial_port", "serial_speed",  | ||||
|             "octoprint_host", "octoprint_apikey", "octoprint_cafile", "use_firmware_retraction", "use_volumetric_e", "variable_layer_height", | ||||
|             "bed_shape", "z_offset", "gcode_flavor", "use_relative_e_distances", "serial_port", "serial_speed", "host_type", | ||||
|             "print_host", "printhost_apikey", "printhost_cafile", "use_firmware_retraction", "use_volumetric_e", "variable_layer_height", | ||||
|             "single_extruder_multi_material", "start_gcode", "end_gcode", "before_layer_gcode", "layer_gcode", "toolchange_gcode", | ||||
|             "between_objects_gcode", "printer_vendor", "printer_model", "printer_variant", "printer_notes", "cooling_tube_retraction", | ||||
|             "cooling_tube_length", "parking_pos_retraction", "extra_loading_move", "max_print_height", "default_print_profile", "inherits", | ||||
|  |  | |||
|  | @ -5,7 +5,8 @@ | |||
| #include "../../libslic3r/Utils.hpp" | ||||
| 
 | ||||
| #include "slic3r/Utils/Http.hpp" | ||||
| #include "slic3r/Utils/OctoPrint.hpp" | ||||
| #include "slic3r/Utils/PrintHostFactory.hpp" | ||||
| #include "slic3r/Utils/PrintHost.hpp" | ||||
| #include "slic3r/Utils/Serial.hpp" | ||||
| #include "BonjourDialog.hpp" | ||||
| #include "WipeTowerDialog.hpp" | ||||
|  | @ -1521,10 +1522,12 @@ void TabPrinter::build() | |||
| 			optgroup->append_line(line); | ||||
| 		} | ||||
| 
 | ||||
| 		optgroup = page->new_optgroup(_(L("OctoPrint upload"))); | ||||
| 		optgroup = page->new_optgroup(_(L("Printer Host upload"))); | ||||
| 
 | ||||
| 		auto octoprint_host_browse = [this, optgroup] (wxWindow* parent) { | ||||
| 			auto btn = new wxButton(parent, wxID_ANY, _(L(" Browse "))+dots, wxDefaultPosition, wxDefaultSize, wxBU_LEFT); | ||||
| 		optgroup->append_single_option_line("host_type"); | ||||
| 
 | ||||
| 		auto printhost_browse = [this, optgroup] (wxWindow* parent) { | ||||
| 			auto btn = m_printhost_browse_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); | ||||
|  | @ -1532,47 +1535,52 @@ void TabPrinter::build() | |||
| 			btn->Bind(wxEVT_BUTTON, [this, parent, optgroup](wxCommandEvent e) { | ||||
| 				BonjourDialog dialog(parent); | ||||
| 				if (dialog.show_and_lookup()) { | ||||
| 					optgroup->set_value("octoprint_host", std::move(dialog.get_selected()), true); | ||||
| 					optgroup->set_value("print_host", std::move(dialog.get_selected()), true); | ||||
| 				} | ||||
| 			}); | ||||
| 
 | ||||
| 			return sizer; | ||||
| 		}; | ||||
| 
 | ||||
| 		auto octoprint_host_test = [this](wxWindow* parent) { | ||||
| 			auto btn = m_octoprint_host_test_btn = new wxButton(parent, wxID_ANY, _(L("Test")),  | ||||
| 		auto print_host_test = [this](wxWindow* parent) { | ||||
| 			auto btn = m_print_host_test_btn = new wxButton(parent, wxID_ANY, _(L("Test")),  | ||||
| 				wxDefaultPosition, wxDefaultSize, wxBU_LEFT | wxBU_EXACTFIT); | ||||
| 			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](wxCommandEvent e) { | ||||
| 				OctoPrint octoprint(m_config); | ||||
| 				wxString msg; | ||||
| 				if (octoprint.test(msg)) { | ||||
| 					show_info(this, _(L("Connection to OctoPrint works correctly.")), _(L("Success!"))); | ||||
| 				} else { | ||||
| 					const auto text = wxString::Format("%s: %s\n\n%s", | ||||
| 						_(L("Could not connect to OctoPrint")), msg, _(L("Note: OctoPrint version at least 1.1.0 is required.")) | ||||
| 					); | ||||
| 				PrintHost *host = PrintHostFactory::get_print_host(m_config); | ||||
| 				if (host == NULL) { | ||||
| 					const auto text = wxString::Format("%s", | ||||
| 						_(L("Could not get a valid Printer Host reference"))); | ||||
| 					show_error(this, text); | ||||
| 					return; | ||||
| 				} | ||||
| 				wxString msg; | ||||
| 				if (host->test(msg)) { | ||||
| 					show_info(this, host->get_test_ok_msg(), _(L("Success!"))); | ||||
| 				} else { | ||||
| 					show_error(this, host->get_test_failed_msg(msg)); | ||||
| 				} | ||||
| 
 | ||||
| 				delete (host); | ||||
| 			}); | ||||
| 
 | ||||
| 			return sizer; | ||||
| 		}; | ||||
| 
 | ||||
| 		Line host_line = optgroup->create_single_option_line("octoprint_host"); | ||||
| 		host_line.append_widget(octoprint_host_browse); | ||||
| 		host_line.append_widget(octoprint_host_test); | ||||
| 		Line host_line = optgroup->create_single_option_line("print_host"); | ||||
| 		host_line.append_widget(printhost_browse); | ||||
| 		host_line.append_widget(print_host_test); | ||||
| 		optgroup->append_line(host_line); | ||||
| 		optgroup->append_single_option_line("octoprint_apikey"); | ||||
| 		optgroup->append_single_option_line("printhost_apikey"); | ||||
| 
 | ||||
| 		if (Http::ca_file_supported()) { | ||||
| 
 | ||||
| 			Line cafile_line = optgroup->create_single_option_line("octoprint_cafile"); | ||||
| 			Line cafile_line = optgroup->create_single_option_line("printhost_cafile"); | ||||
| 
 | ||||
| 			auto octoprint_cafile_browse = [this, optgroup] (wxWindow* parent) { | ||||
| 			auto printhost_cafile_browse = [this, optgroup] (wxWindow* parent) { | ||||
| 				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); | ||||
|  | @ -1582,17 +1590,17 @@ void TabPrinter::build() | |||
| 					static const auto filemasks = _(L("Certificate files (*.crt, *.pem)|*.crt;*.pem|All files|*.*")); | ||||
| 					wxFileDialog openFileDialog(this, _(L("Open CA certificate file")), "", "", filemasks, wxFD_OPEN | wxFD_FILE_MUST_EXIST); | ||||
| 					if (openFileDialog.ShowModal() != wxID_CANCEL) { | ||||
| 						optgroup->set_value("octoprint_cafile", std::move(openFileDialog.GetPath()), true); | ||||
| 						optgroup->set_value("printhost_cafile", std::move(openFileDialog.GetPath()), true); | ||||
| 					} | ||||
| 				}); | ||||
| 
 | ||||
| 				return sizer; | ||||
| 			}; | ||||
| 
 | ||||
| 			cafile_line.append_widget(octoprint_cafile_browse); | ||||
| 			cafile_line.append_widget(printhost_cafile_browse); | ||||
| 			optgroup->append_line(cafile_line); | ||||
| 
 | ||||
| 			auto octoprint_cafile_hint = [this, optgroup] (wxWindow* parent) { | ||||
| 			auto printhost_cafile_hint = [this, optgroup] (wxWindow* parent) { | ||||
| 				auto txt = new wxStaticText(parent, wxID_ANY,  | ||||
| 					_(L("HTTPS CA file is optional. It is only needed if you use HTTPS with a self-signed certificate."))); | ||||
| 				auto sizer = new wxBoxSizer(wxHORIZONTAL); | ||||
|  | @ -1602,7 +1610,7 @@ void TabPrinter::build() | |||
| 
 | ||||
| 			Line cafile_hint { "", "" }; | ||||
| 			cafile_hint.full_width = 1; | ||||
| 			cafile_hint.widget = std::move(octoprint_cafile_hint); | ||||
| 			cafile_hint.widget = std::move(printhost_cafile_hint); | ||||
| 			optgroup->append_line(cafile_hint); | ||||
| 
 | ||||
| 		} | ||||
|  | @ -1897,7 +1905,10 @@ void TabPrinter::update(){ | |||
| 			m_serial_test_btn->Disable(); | ||||
| 	} | ||||
| 
 | ||||
| 	m_octoprint_host_test_btn->Enable(!m_config->opt_string("octoprint_host").empty()); | ||||
| 	PrintHost *host = PrintHostFactory::get_print_host(m_config); | ||||
| 	m_print_host_test_btn->Enable(!m_config->opt_string("print_host").empty() && host->can_test()); | ||||
| 	m_printhost_browse_btn->Enable(host->have_auto_discovery()); | ||||
| 	delete (host); | ||||
| 	 | ||||
| 	bool have_multiple_extruders = m_extruders_count > 1; | ||||
| 	get_field("toolchange_gcode")->toggle(have_multiple_extruders); | ||||
|  |  | |||
|  | @ -321,7 +321,8 @@ class TabPrinter : public Tab | |||
| 	bool		m_rebuild_kinematics_page = false; | ||||
| public: | ||||
| 	wxButton*	m_serial_test_btn; | ||||
| 	wxButton*	m_octoprint_host_test_btn; | ||||
| 	wxButton*	m_print_host_test_btn; | ||||
| 	wxButton*	m_printhost_browse_btn; | ||||
| 
 | ||||
| 	size_t		m_extruders_count; | ||||
| 	size_t		m_extruders_count_old = 0; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Martin Loidl
						Martin Loidl