mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	Added color indicators to Purging volumes dialog
This commit is contained in:
		
							parent
							
								
									460887cdde
								
							
						
					
					
						commit
						8b685c1881
					
				
					 3 changed files with 57 additions and 19 deletions
				
			
		|  | @ -475,23 +475,26 @@ FreqChangedParams::FreqChangedParams(wxWindow* parent, const int label_width) : | |||
|     option.opt.sidetext = "     "; | ||||
|     line.append_option(option); | ||||
| 
 | ||||
|     auto wiping_dialog_btn = [config, this](wxWindow* parent) { | ||||
|     auto wiping_dialog_btn = [this](wxWindow* parent) { | ||||
|         m_wiping_dialog_button = new wxButton(parent, wxID_ANY, _(L("Purging volumes")) + dots, wxDefaultPosition, wxDefaultSize, wxBU_EXACTFIT); | ||||
|         auto sizer = new wxBoxSizer(wxHORIZONTAL); | ||||
|         sizer->Add(m_wiping_dialog_button); | ||||
|         m_wiping_dialog_button->Bind(wxEVT_BUTTON, ([parent](wxCommandEvent& e) | ||||
|         { | ||||
|             auto &config = wxGetApp().preset_bundle->project_config; | ||||
|             const std::vector<double> &init_matrix = (config.option<ConfigOptionFloats>("wiping_volumes_matrix"))->values; | ||||
|             const std::vector<double> &init_extruders = (config.option<ConfigOptionFloats>("wiping_volumes_extruders"))->values; | ||||
|             auto &project_config = wxGetApp().preset_bundle->project_config; | ||||
|             const std::vector<double> &init_matrix = (project_config.option<ConfigOptionFloats>("wiping_volumes_matrix"))->values; | ||||
|             const std::vector<double> &init_extruders = (project_config.option<ConfigOptionFloats>("wiping_volumes_extruders"))->values; | ||||
| 
 | ||||
|             WipingDialog dlg(parent, cast<float>(init_matrix), cast<float>(init_extruders)); | ||||
|             const DynamicPrintConfig* config = &wxGetApp().preset_bundle->printers.get_edited_preset().config; | ||||
|             const std::vector<std::string> &extruder_colours = (config->option<ConfigOptionStrings>("extruder_colour"))->values; | ||||
| 
 | ||||
|             WipingDialog dlg(parent, cast<float>(init_matrix), cast<float>(init_extruders), extruder_colours); | ||||
| 
 | ||||
|             if (dlg.ShowModal() == wxID_OK) { | ||||
|                 std::vector<float> matrix = dlg.get_matrix(); | ||||
|                 std::vector<float> extruders = dlg.get_extruders(); | ||||
|                 (config.option<ConfigOptionFloats>("wiping_volumes_matrix"))->values = std::vector<double>(matrix.begin(), matrix.end()); | ||||
|                 (config.option<ConfigOptionFloats>("wiping_volumes_extruders"))->values = std::vector<double>(extruders.begin(), extruders.end()); | ||||
|                 (project_config.option<ConfigOptionFloats>("wiping_volumes_matrix"))->values = std::vector<double>(matrix.begin(), matrix.end()); | ||||
|                 (project_config.option<ConfigOptionFloats>("wiping_volumes_extruders"))->values = std::vector<double>(extruders.begin(), extruders.end()); | ||||
|                 wxPostEvent(parent, SimpleEvent(EVT_SCHEDULE_BACKGROUND_PROCESS, parent)); | ||||
|             } | ||||
|         })); | ||||
|  |  | |||
|  | @ -1,6 +1,7 @@ | |||
| #include <algorithm> | ||||
| #include <sstream> | ||||
| #include "WipeTowerDialog.hpp" | ||||
| #include "PresetBundle.hpp" | ||||
| #include "GUI.hpp" | ||||
| #include "I18N.hpp" | ||||
| #include "GUI_App.hpp" | ||||
|  | @ -137,11 +138,11 @@ std::string RammingPanel::get_parameters() | |||
| 
 | ||||
| 
 | ||||
| // Parent dialog for purging volume adjustments - it fathers WipingPanel widget (that contains all controls) and a button to toggle simple/advanced mode:
 | ||||
| WipingDialog::WipingDialog(wxWindow* parent,const std::vector<float>& matrix, const std::vector<float>& extruders) | ||||
| WipingDialog::WipingDialog(wxWindow* parent, const std::vector<float>& matrix, const std::vector<float>& extruders, const std::vector<std::string>& extruder_colours) | ||||
| : wxDialog(parent, wxID_ANY, _(L("Wipe tower - Purging volume adjustment")), wxDefaultPosition, wxDefaultSize, wxDEFAULT_DIALOG_STYLE/* | wxRESIZE_BORDER*/) | ||||
| { | ||||
|     auto widget_button = new wxButton(this,wxID_ANY,"-",wxPoint(0,0),wxDefaultSize); | ||||
|     m_panel_wiping  = new WipingPanel(this,matrix,extruders, widget_button); | ||||
|     m_panel_wiping  = new WipingPanel(this,matrix,extruders, extruder_colours, widget_button); | ||||
| 
 | ||||
|     auto main_sizer = new wxBoxSizer(wxVERTICAL); | ||||
| 
 | ||||
|  | @ -180,7 +181,7 @@ void WipingPanel::format_sizer(wxSizer* sizer, wxPanel* page, wxGridSizer* grid_ | |||
| } | ||||
| 
 | ||||
| // This panel contains all control widgets for both simple and advanced mode (these reside in separate sizers)
 | ||||
| WipingPanel::WipingPanel(wxWindow* parent, const std::vector<float>& matrix, const std::vector<float>& extruders, wxButton* widget_button) | ||||
| WipingPanel::WipingPanel(wxWindow* parent, const std::vector<float>& matrix, const std::vector<float>& extruders, const std::vector<std::string>& extruder_colours, wxButton* widget_button) | ||||
| : wxPanel(parent,wxID_ANY, wxDefaultPosition, wxDefaultSize/*,wxBORDER_RAISED*/) | ||||
| { | ||||
|     m_widget_button = widget_button;    // pointer to the button in parent dialog
 | ||||
|  | @ -188,6 +189,12 @@ WipingPanel::WipingPanel(wxWindow* parent, const std::vector<float>& matrix, con | |||
| 
 | ||||
|     m_number_of_extruders = (int)(sqrt(matrix.size())+0.001); | ||||
| 
 | ||||
|     for (const std::string& color : extruder_colours) { | ||||
|         unsigned char rgb[3]; | ||||
|         Slic3r::PresetBundle::parse_color(color, rgb); | ||||
|         m_colours.push_back(wxColor(rgb[0], rgb[1], rgb[2])); | ||||
|     } | ||||
| 
 | ||||
| 	// Create two switched panels with their own sizers
 | ||||
|     m_sizer_simple          = new wxBoxSizer(wxVERTICAL); | ||||
|     m_sizer_advanced        = new wxBoxSizer(wxVERTICAL); | ||||
|  | @ -212,10 +219,28 @@ WipingPanel::WipingPanel(wxWindow* parent, const std::vector<float>& matrix, con | |||
| 		} | ||||
| 	} | ||||
| 	m_gridsizer_advanced->Add(new wxStaticText(m_page_advanced, wxID_ANY, wxString(""))); | ||||
| 	for (unsigned int i = 0; i < m_number_of_extruders; ++i) | ||||
| 		m_gridsizer_advanced->Add(new wxStaticText(m_page_advanced, wxID_ANY, wxString("") << i + 1), 0, wxALIGN_CENTER | wxALIGN_CENTER_VERTICAL); | ||||
| 	for (unsigned int i = 0; i < m_number_of_extruders; ++i) { | ||||
| 		m_gridsizer_advanced->Add(new wxStaticText(m_page_advanced, wxID_ANY, wxString("") << i + 1), 0, wxALIGN_CENTER | wxALIGN_CENTER_VERTICAL); | ||||
|         auto hsizer = new wxBoxSizer(wxHORIZONTAL); | ||||
|         hsizer->AddSpacer(20); | ||||
|         hsizer->Add(new wxStaticText(m_page_advanced, wxID_ANY, wxString("") << i + 1), 0, wxALIGN_CENTER); | ||||
|         wxWindow* w = new wxWindow(m_page_advanced, wxID_ANY, wxDefaultPosition, wxSize(25, 25), wxBORDER_SIMPLE); | ||||
|         w->SetCanFocus(false); | ||||
|         w->SetBackgroundColour(m_colours[i]); | ||||
|         hsizer->AddSpacer(10); | ||||
|         hsizer->Add(w); | ||||
| 		m_gridsizer_advanced->Add(hsizer); | ||||
|     } | ||||
| 	for (unsigned int i = 0; i < m_number_of_extruders; ++i) { | ||||
|         auto hsizer = new wxBoxSizer(wxHORIZONTAL); | ||||
|         wxWindow* w = new wxWindow(m_page_advanced, wxID_ANY, wxDefaultPosition, wxSize(25, 25), wxBORDER_SIMPLE); | ||||
|         w->SetCanFocus(false); | ||||
|         w->SetBackgroundColour(m_colours[i]); | ||||
|         hsizer->AddSpacer(20); | ||||
|         hsizer->Add(new wxStaticText(m_page_advanced, wxID_ANY, wxString("") << i + 1), 0, wxALIGN_CENTER | wxALIGN_CENTER_VERTICAL); | ||||
|         hsizer->AddSpacer(10); | ||||
|         hsizer->Add(w); | ||||
|         m_gridsizer_advanced->Add(hsizer); | ||||
| 
 | ||||
|     for (unsigned int j = 0; j < m_number_of_extruders; ++j) | ||||
|         m_gridsizer_advanced->Add(edit_boxes[j][i], 0); | ||||
|     } | ||||
|  | @ -237,7 +262,16 @@ WipingPanel::WipingPanel(wxWindow* parent, const std::vector<float>& matrix, con | |||
| 	for (unsigned int i=0;i<m_number_of_extruders;++i) { | ||||
|         m_old.push_back(new wxSpinCtrl(m_page_simple,wxID_ANY,wxEmptyString,wxDefaultPosition, wxSize(ITEM_WIDTH(), -1),wxSP_ARROW_KEYS|wxALIGN_RIGHT,0,300,extruders[2*i])); | ||||
|         m_new.push_back(new wxSpinCtrl(m_page_simple,wxID_ANY,wxEmptyString,wxDefaultPosition, wxSize(ITEM_WIDTH(), -1),wxSP_ARROW_KEYS|wxALIGN_RIGHT,0,300,extruders[2*i+1])); | ||||
| 		gridsizer_simple->Add(new wxStaticText(m_page_simple, wxID_ANY, wxString(_(L("Tool #"))) << i + 1 << ": "), 0, wxALIGN_LEFT | wxALIGN_CENTER_VERTICAL); | ||||
| 
 | ||||
|         auto hsizer = new wxBoxSizer(wxHORIZONTAL); | ||||
|         wxWindow* w = new wxWindow(m_page_simple, wxID_ANY, wxDefaultPosition, wxSize(25, 25), wxBORDER_SIMPLE); | ||||
|         w->SetCanFocus(false); | ||||
|         w->SetBackgroundColour(m_colours[i]); | ||||
|         hsizer->Add(w, wxALIGN_CENTER_VERTICAL); | ||||
|         hsizer->AddSpacer(10); | ||||
|         hsizer->Add(new wxStaticText(m_page_simple, wxID_ANY, wxString(_(L("Tool #"))) << i + 1 << ": "), 0, wxALIGN_LEFT | wxALIGN_CENTER_VERTICAL); | ||||
| 
 | ||||
|         gridsizer_simple->Add(hsizer,  wxALIGN_CENTER_VERTICAL); | ||||
|         gridsizer_simple->Add(m_old.back(),0); | ||||
|         gridsizer_simple->Add(m_new.back(),0); | ||||
| 	} | ||||
|  |  | |||
|  | @ -46,7 +46,7 @@ private: | |||
| 
 | ||||
| class WipingPanel : public wxPanel { | ||||
| public: | ||||
|     WipingPanel(wxWindow* parent, const std::vector<float>& matrix, const std::vector<float>& extruders, wxButton* widget_button); | ||||
|     WipingPanel(wxWindow* parent, const std::vector<float>& matrix, const std::vector<float>& extruders, const std::vector<std::string>& extruder_colours, wxButton* widget_button); | ||||
|     std::vector<float> read_matrix_values(); | ||||
|     std::vector<float> read_extruders_values(); | ||||
|     void toggle_advanced(bool user_action = false); | ||||
|  | @ -59,6 +59,7 @@ private: | |||
|     std::vector<wxSpinCtrl*> m_old; | ||||
|     std::vector<wxSpinCtrl*> m_new; | ||||
|     std::vector<std::vector<wxTextCtrl*>> edit_boxes; | ||||
|     std::vector<wxColour> m_colours; | ||||
|     unsigned int m_number_of_extruders  = 0; | ||||
|     bool m_advanced                     = false; | ||||
| 	wxPanel*	m_page_simple = nullptr; | ||||
|  | @ -76,7 +77,7 @@ private: | |||
| 
 | ||||
| class WipingDialog : public wxDialog { | ||||
| public: | ||||
|     WipingDialog(wxWindow* parent,const std::vector<float>& matrix, const std::vector<float>& extruders); | ||||
|     WipingDialog(wxWindow* parent, const std::vector<float>& matrix, const std::vector<float>& extruders, const std::vector<std::string>& extruder_colours); | ||||
|     std::vector<float> get_matrix() const    { return m_output_matrix; } | ||||
|     std::vector<float> get_extruders() const { return m_output_extruders; } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lukas Matena
						Lukas Matena