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 = "     "; |     option.opt.sidetext = "     "; | ||||||
|     line.append_option(option); |     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); |         m_wiping_dialog_button = new wxButton(parent, wxID_ANY, _(L("Purging volumes")) + dots, wxDefaultPosition, wxDefaultSize, wxBU_EXACTFIT); | ||||||
|         auto sizer = new wxBoxSizer(wxHORIZONTAL); |         auto sizer = new wxBoxSizer(wxHORIZONTAL); | ||||||
|         sizer->Add(m_wiping_dialog_button); |         sizer->Add(m_wiping_dialog_button); | ||||||
|         m_wiping_dialog_button->Bind(wxEVT_BUTTON, ([parent](wxCommandEvent& e) |         m_wiping_dialog_button->Bind(wxEVT_BUTTON, ([parent](wxCommandEvent& e) | ||||||
|         { |         { | ||||||
|             auto &config = wxGetApp().preset_bundle->project_config; |             auto &project_config = wxGetApp().preset_bundle->project_config; | ||||||
|             const std::vector<double> &init_matrix = (config.option<ConfigOptionFloats>("wiping_volumes_matrix"))->values; |             const std::vector<double> &init_matrix = (project_config.option<ConfigOptionFloats>("wiping_volumes_matrix"))->values; | ||||||
|             const std::vector<double> &init_extruders = (config.option<ConfigOptionFloats>("wiping_volumes_extruders"))->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) { |             if (dlg.ShowModal() == wxID_OK) { | ||||||
|                 std::vector<float> matrix = dlg.get_matrix(); |                 std::vector<float> matrix = dlg.get_matrix(); | ||||||
|                 std::vector<float> extruders = dlg.get_extruders(); |                 std::vector<float> extruders = dlg.get_extruders(); | ||||||
|                 (config.option<ConfigOptionFloats>("wiping_volumes_matrix"))->values = std::vector<double>(matrix.begin(), matrix.end()); |                 (project_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_extruders"))->values = std::vector<double>(extruders.begin(), extruders.end()); | ||||||
|                 wxPostEvent(parent, SimpleEvent(EVT_SCHEDULE_BACKGROUND_PROCESS, parent)); |                 wxPostEvent(parent, SimpleEvent(EVT_SCHEDULE_BACKGROUND_PROCESS, parent)); | ||||||
|             } |             } | ||||||
|         })); |         })); | ||||||
|  |  | ||||||
|  | @ -1,6 +1,7 @@ | ||||||
| #include <algorithm> | #include <algorithm> | ||||||
| #include <sstream> | #include <sstream> | ||||||
| #include "WipeTowerDialog.hpp" | #include "WipeTowerDialog.hpp" | ||||||
|  | #include "PresetBundle.hpp" | ||||||
| #include "GUI.hpp" | #include "GUI.hpp" | ||||||
| #include "I18N.hpp" | #include "I18N.hpp" | ||||||
| #include "GUI_App.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:
 | // 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*/) | : 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); |     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); |     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)
 | // 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*/) | : wxPanel(parent,wxID_ANY, wxDefaultPosition, wxDefaultSize/*,wxBORDER_RAISED*/) | ||||||
| { | { | ||||||
|     m_widget_button = widget_button;    // pointer to the button in parent dialog
 |     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); |     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
 | 	// Create two switched panels with their own sizers
 | ||||||
|     m_sizer_simple          = new wxBoxSizer(wxVERTICAL); |     m_sizer_simple          = new wxBoxSizer(wxVERTICAL); | ||||||
|     m_sizer_advanced        = 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(""))); | 	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) { | 	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) |     for (unsigned int j = 0; j < m_number_of_extruders; ++j) | ||||||
|         m_gridsizer_advanced->Add(edit_boxes[j][i], 0); |         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) { | 	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_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])); |         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_old.back(),0); | ||||||
|         gridsizer_simple->Add(m_new.back(),0); |         gridsizer_simple->Add(m_new.back(),0); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | @ -46,7 +46,7 @@ private: | ||||||
| 
 | 
 | ||||||
| class WipingPanel : public wxPanel { | class WipingPanel : public wxPanel { | ||||||
| public: | 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_matrix_values(); | ||||||
|     std::vector<float> read_extruders_values(); |     std::vector<float> read_extruders_values(); | ||||||
|     void toggle_advanced(bool user_action = false); |     void toggle_advanced(bool user_action = false); | ||||||
|  | @ -59,6 +59,7 @@ private: | ||||||
|     std::vector<wxSpinCtrl*> m_old; |     std::vector<wxSpinCtrl*> m_old; | ||||||
|     std::vector<wxSpinCtrl*> m_new; |     std::vector<wxSpinCtrl*> m_new; | ||||||
|     std::vector<std::vector<wxTextCtrl*>> edit_boxes; |     std::vector<std::vector<wxTextCtrl*>> edit_boxes; | ||||||
|  |     std::vector<wxColour> m_colours; | ||||||
|     unsigned int m_number_of_extruders  = 0; |     unsigned int m_number_of_extruders  = 0; | ||||||
|     bool m_advanced                     = false; |     bool m_advanced                     = false; | ||||||
| 	wxPanel*	m_page_simple = nullptr; | 	wxPanel*	m_page_simple = nullptr; | ||||||
|  | @ -76,7 +77,7 @@ private: | ||||||
| 
 | 
 | ||||||
| class WipingDialog : public wxDialog { | class WipingDialog : public wxDialog { | ||||||
| public: | 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_matrix() const    { return m_output_matrix; } | ||||||
|     std::vector<float> get_extruders() const { return m_output_extruders; } |     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