mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 17:51:10 -06:00 
			
		
		
		
	Some changes in the concept of the new right column
This commit is contained in:
		
							parent
							
								
									85508fab82
								
							
						
					
					
						commit
						46f71661b2
					
				
					 6 changed files with 158 additions and 48 deletions
				
			
		|  | @ -136,6 +136,12 @@ wxStaticBitmap	*g_manifold_warning_icon = nullptr; | |||
| bool		g_show_print_info = false; | ||||
| bool		g_show_manifold_warning_icon = false; | ||||
| 
 | ||||
| wxFont		g_small_font{ wxSystemSettings::GetFont(wxSYS_DEFAULT_GUI_FONT) }; | ||||
| #ifdef __WXMAC__ | ||||
| g_small_font->SetPointSize(11); | ||||
| #endif /*__WXMAC__*/ | ||||
| wxFont		g_bold_font{ wxSystemSettings::GetFont(wxSYS_DEFAULT_GUI_FONT).Bold() }; | ||||
| 
 | ||||
| static void init_label_colours() | ||||
| { | ||||
| 	auto luma = get_colour_approx_luma(wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW)); | ||||
|  | @ -739,6 +745,14 @@ void set_label_clr_sys(const wxColour& clr) { | |||
| 	g_AppConfig->save(); | ||||
| } | ||||
| 
 | ||||
| const wxFont& small_font(){ | ||||
| 	return g_small_font; | ||||
| } | ||||
| 
 | ||||
| const wxFont& bold_font(){ | ||||
| 	return g_bold_font; | ||||
| } | ||||
| 
 | ||||
| const wxColour& get_label_clr_default() { | ||||
| 	return g_color_label_default; | ||||
| } | ||||
|  | @ -879,6 +893,58 @@ wxBoxSizer* content_objects_list(wxWindow *win) | |||
| 	return objects_sz; | ||||
| } | ||||
| 
 | ||||
| wxBoxSizer* content_edit_object_buttons(wxWindow* win) | ||||
| { | ||||
| 	auto sizer = new wxBoxSizer(wxVERTICAL); | ||||
| 
 | ||||
| 	auto btn_load_part = new wxButton(win, wxID_ANY, "Load part…", wxDefaultPosition, wxDefaultSize, wxBU_LEFT); | ||||
|     auto btn_load_modifier = new wxButton(win, wxID_ANY, "Load modifier…", wxDefaultPosition, wxDefaultSize, wxBU_LEFT); | ||||
|     auto btn_load_lambda_modifier = new wxButton(win, wxID_ANY, "Load generic…", wxDefaultPosition, wxDefaultSize, wxBU_LEFT); | ||||
|     auto btn_delete = new wxButton(win, wxID_ANY, "Delete part", wxDefaultPosition, wxDefaultSize, wxBU_LEFT); | ||||
|     auto btn_split = new wxButton(win, wxID_ANY, "Split part", wxDefaultPosition, wxDefaultSize, wxBU_LEFT); | ||||
| 	auto btn_move_up = new wxButton(win, wxID_ANY, "", wxDefaultPosition, wxDefaultSize/*wxSize(30, -1)*/, wxBU_LEFT); | ||||
| 	auto btn_move_down = new wxButton(win, wxID_ANY, "", wxDefaultPosition, wxDefaultSize/*wxSize(30, -1)*/, wxBU_LEFT); | ||||
| 	btn_move_up->SetMinSize(wxSize(20, -1)); | ||||
| 	btn_move_down->SetMinSize(wxSize(20, -1)); | ||||
| 	btn_load_part->SetBitmap(wxBitmap(from_u8(Slic3r::var("brick_add.png")), wxBITMAP_TYPE_PNG)); | ||||
|     btn_load_modifier->SetBitmap(wxBitmap(from_u8(Slic3r::var("brick_add.png")), wxBITMAP_TYPE_PNG)); | ||||
|     btn_load_lambda_modifier->SetBitmap(wxBitmap(from_u8(Slic3r::var("brick_add.png")), wxBITMAP_TYPE_PNG)); | ||||
|     btn_delete->SetBitmap(wxBitmap(from_u8(Slic3r::var("brick_delete.png")), wxBITMAP_TYPE_PNG)); | ||||
|     btn_split->SetBitmap(wxBitmap(from_u8(Slic3r::var("shape_ungroup.png")), wxBITMAP_TYPE_PNG)); | ||||
|     btn_move_up->SetBitmap(wxBitmap(from_u8(Slic3r::var("bullet_arrow_up.png")), wxBITMAP_TYPE_PNG)); | ||||
|     btn_move_down->SetBitmap(wxBitmap(from_u8(Slic3r::var("bullet_arrow_down.png")), wxBITMAP_TYPE_PNG)); | ||||
| 
 | ||||
| 	auto buttons_object_sizer = new wxFlexGridSizer(1, 3, 0, 1); | ||||
| 	buttons_object_sizer->SetFlexibleDirection(wxBOTH); | ||||
| 	buttons_object_sizer->Add(btn_load_part, 0, wxEXPAND); | ||||
| 	buttons_object_sizer->Add(btn_load_modifier, 0, wxEXPAND); | ||||
| 	buttons_object_sizer->Add(btn_load_lambda_modifier, 0, wxEXPAND); | ||||
| 
 | ||||
| 	auto buttons_part_sizer = new wxFlexGridSizer(1, 3, 0, 1); | ||||
| 	buttons_part_sizer->SetFlexibleDirection(wxBOTH); | ||||
| 	buttons_part_sizer->Add(btn_delete, 0, wxEXPAND); | ||||
| 	buttons_part_sizer->Add(btn_split, 0, wxEXPAND); | ||||
| 	{ | ||||
| 		auto up_down_sizer = new wxGridSizer(1, 2, 0, 1); | ||||
| 		up_down_sizer->Add(btn_move_up, 1, wxEXPAND); | ||||
| 		up_down_sizer->Add(btn_move_down, 1, wxEXPAND); | ||||
| 		buttons_part_sizer->Add(up_down_sizer, 0, wxEXPAND); | ||||
| 	} | ||||
| 	buttons_part_sizer->Show(false); | ||||
| 
 | ||||
| 	btn_load_part->SetFont(Slic3r::GUI::small_font()); | ||||
| 	btn_load_modifier->SetFont(Slic3r::GUI::small_font()); | ||||
| 	btn_load_lambda_modifier->SetFont(Slic3r::GUI::small_font()); | ||||
| 	btn_delete->SetFont(Slic3r::GUI::small_font()); | ||||
| 	btn_split->SetFont(Slic3r::GUI::small_font()); | ||||
| 	btn_move_up->SetFont(Slic3r::GUI::small_font()); | ||||
| 	btn_move_down->SetFont(Slic3r::GUI::small_font()); | ||||
| 
 | ||||
| 	sizer->Add(buttons_object_sizer, 0, wxALIGN_CENTER_HORIZONTAL); | ||||
| 	sizer->Add(buttons_part_sizer, 0, wxALIGN_CENTER_HORIZONTAL); | ||||
| 	return sizer; | ||||
| } | ||||
| 
 | ||||
| Line add_og_to_object_settings(const std::string& option_name, const std::string& sidetext, int def_value=0) | ||||
| { | ||||
| 	Line line = { _(option_name), "" }; | ||||
|  | @ -888,7 +954,7 @@ Line add_og_to_object_settings(const std::string& option_name, const std::string | |||
| 	def.type = coInt; | ||||
| 	def.default_value = new ConfigOptionInt(def_value); | ||||
| 	def.sidetext = sidetext; | ||||
| 	def.width = 50; | ||||
|  	def.width = 70; | ||||
| 
 | ||||
| 	const std::string lower_name = boost::algorithm::to_lower_copy(option_name); | ||||
| 
 | ||||
|  | @ -903,39 +969,29 @@ Line add_og_to_object_settings(const std::string& option_name, const std::string | |||
| 	def.label = L("Z"); | ||||
| 	option = Option(def, lower_name + "_Z"); | ||||
| 	line.append_option(option); | ||||
| 
 | ||||
| 	if (option_name == "Scale") | ||||
| 	{ | ||||
| 		def.label = L("Units"); | ||||
| 		def.type = coStrings; | ||||
| 		def.gui_type = "select_open"; | ||||
| 		def.enum_labels.push_back(L("%")); | ||||
| 		def.enum_labels.push_back(L("mm")); | ||||
| 		def.default_value = new ConfigOptionStrings{ "%" }; | ||||
| 		def.sidetext = " "; | ||||
| 
 | ||||
| 		option = Option(def, lower_name + "_unit"); | ||||
| 		line.append_option(option); | ||||
| 	} | ||||
| 	return line; | ||||
| } | ||||
| 
 | ||||
| wxBoxSizer* content_object_settings(wxWindow *win) | ||||
| { | ||||
| 	DynamicPrintConfig* config = /*&g_PresetBundle->full_config();*/&g_PresetBundle->prints.get_edited_preset().config; | ||||
| 	std::shared_ptr<ConfigOptionsGroup> optgroup = std::make_shared<ConfigOptionsGroup>(win, "", config); | ||||
| 	DynamicPrintConfig* config = &g_PresetBundle->printers.get_edited_preset().config; // TODO get config from Model_volume
 | ||||
| 	std::shared_ptr<ConfigOptionsGroup> optgroup = std::make_shared<ConfigOptionsGroup>(win, "Extruders", config); | ||||
| 	optgroup->label_width = m_label_width; | ||||
| 
 | ||||
| 	ConfigOptionDef def; | ||||
| 	def.label = L("Name"); | ||||
| 	def.type = coString; | ||||
| 	def.tooltip = L("Object name"); | ||||
| 	def.full_width = true; | ||||
| 	def.default_value = new ConfigOptionString{ "BlaBla_object.stl" }; | ||||
| 	optgroup->append_single_option_line(Option(def, "object_name")); | ||||
| 
 | ||||
| 	optgroup->set_flag(ogSIDE_OPTIONS_VERTICAL); | ||||
| 	 | ||||
| 	optgroup->append_line(add_og_to_object_settings(L("Position"), L("mm"))); | ||||
|  	optgroup->append_line(add_og_to_object_settings(L("Rotation"), "°"/*"\u00b0"*/, 1)); | ||||
|  	optgroup->append_line(add_og_to_object_settings(L("Scale"), "%", 2)); | ||||
| 
 | ||||
| 	optgroup->set_flag(ogDEFAULT); | ||||
| 	 | ||||
| 	def.label = L("Place on bed"); | ||||
| 	def.type = coBool; | ||||
| 	def.tooltip = L("Automatic placing of models on printing bed in Y axis"); | ||||
| 	def.gui_type = ""; | ||||
| 	def.sidetext = ""; | ||||
| 	def.default_value = new ConfigOptionBool{ false }; | ||||
| 	optgroup->append_single_option_line(Option(def, "place_on_bed")); | ||||
| 
 | ||||
| 	Option option = optgroup->get_option("extruder"); | ||||
| 	option.opt.default_value = new ConfigOptionInt(1); | ||||
| 	optgroup->append_single_option_line(option); | ||||
|  | @ -957,15 +1013,17 @@ wxBoxSizer* content_part_settings(wxWindow *win) | |||
| void add_expert_mode_part(wxWindow* parent, wxBoxSizer* sizer) | ||||
| { | ||||
| 	auto main_sizer = new wxBoxSizer(wxVERTICAL); | ||||
| 	auto main_page = new wxScrolledWindow(parent, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL); | ||||
| 	auto main_page = new wxPanel/*ScrolledWindow*/(parent, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL); | ||||
| 	main_page->SetSizer(main_sizer); | ||||
| 	main_page->SetScrollbars(1, 1, 1, 1); | ||||
| // 	main_page->SetScrollbars(0, 1, 1, 1);
 | ||||
| 	sizer->Add(main_page, 1, wxEXPAND | wxALL, 1); | ||||
| 
 | ||||
| 	// Experiments with new UI
 | ||||
| 
 | ||||
| 	// *** Objects List ***	
 | ||||
|  	add_prusa_collapsible_pane(main_page, main_sizer, "Objects List:", content_objects_list); | ||||
| 	// *** Edit Object Buttons***	
 | ||||
|  	main_sizer->Add(content_edit_object_buttons(main_page), 0, wxEXPAND, 0); | ||||
| 	// *** Object Settings ***
 | ||||
| 	add_prusa_collapsible_pane(main_page, main_sizer, "Object Settings:", content_object_settings); | ||||
| 	// *** Part Settings ***
 | ||||
|  | @ -1109,9 +1167,42 @@ void add_frequently_changed_parameters(wxWindow* parent, wxBoxSizer* sizer, wxFl | |||
| 		}; | ||||
| 		optgroup->append_line(line); | ||||
| 
 | ||||
| 	sizer->Add(optgroup->sizer, 1, wxEXPAND | wxBOTTOM, 2); | ||||
| 	sizer->Add(optgroup->sizer, 0, wxEXPAND | wxBOTTOM, 2); | ||||
| 
 | ||||
| 	m_optgroups.push_back(optgroup);// ogFrequentlyChangingParameters
 | ||||
| 
 | ||||
| 	// Frequently Object Settings
 | ||||
| 	optgroup = std::make_shared<ConfigOptionsGroup>(parent, _(L("Object Settings")), config); | ||||
|  	optgroup->label_width = 100; | ||||
| 	optgroup->set_grid_vgap(5); | ||||
| 
 | ||||
| 	def.label = L("Name"); | ||||
| 	def.type = coString; | ||||
| 	def.tooltip = L("Object name"); | ||||
| 	def.full_width = true; | ||||
| 	def.default_value = new ConfigOptionString{ "BlaBla_object.stl" }; | ||||
| 	optgroup->append_single_option_line(Option(def, "object_name")); | ||||
| 
 | ||||
| 	optgroup->set_flag(ogSIDE_OPTIONS_VERTICAL); | ||||
| 	optgroup->sidetext_width = 25; | ||||
| 	 | ||||
| 	optgroup->append_line(add_og_to_object_settings(L("Position"), L("mm"))); | ||||
| 	optgroup->append_line(add_og_to_object_settings(L("Rotation"), "°", 1)); | ||||
| 	optgroup->append_line(add_og_to_object_settings(L("Scale"), "%", 2)); | ||||
| 
 | ||||
| 	optgroup->set_flag(ogDEFAULT); | ||||
| 
 | ||||
| 	def.label = L("Place on bed"); | ||||
| 	def.type = coBool; | ||||
| 	def.tooltip = L("Automatic placing of models on printing bed in Y axis"); | ||||
| 	def.gui_type = ""; | ||||
| 	def.sidetext = ""; | ||||
| 	def.default_value = new ConfigOptionBool{ false }; | ||||
| 	optgroup->append_single_option_line(Option(def, "place_on_bed")); | ||||
| 
 | ||||
| 	sizer->Add(optgroup->sizer, 0, wxEXPAND | wxLEFT, 20); | ||||
| 
 | ||||
| 	m_optgroups.push_back(optgroup);  // ogFrequentlyObjectSettings
 | ||||
| } | ||||
| 
 | ||||
| void show_frequently_changed_parameters(bool show) | ||||
|  |  | |||
|  | @ -21,6 +21,7 @@ class wxFlexGridSizer; | |||
| class wxButton; | ||||
| class wxFileDialog; | ||||
| class wxStaticBitmap; | ||||
| class wxFont; | ||||
| 
 | ||||
| namespace Slic3r {  | ||||
| 
 | ||||
|  | @ -49,6 +50,7 @@ namespace GUI { | |||
| 
 | ||||
| enum ogGroup{ | ||||
| 	ogFrequentlyChangingParameters, | ||||
| 	ogFrequentlyObjectSettings, | ||||
| 	ogObjectSettings, | ||||
| 	ogPartSettings | ||||
| }; | ||||
|  | @ -108,6 +110,9 @@ unsigned get_colour_approx_luma(const wxColour &colour); | |||
| void set_label_clr_modified(const wxColour& clr); | ||||
| void set_label_clr_sys(const wxColour& clr); | ||||
| 
 | ||||
| const wxFont& small_font(); | ||||
| const wxFont& bold_font(); | ||||
| 
 | ||||
| extern void add_menus(wxMenuBar *menu, int event_preferences_changed, int event_language_change); | ||||
| 
 | ||||
| // This is called when closing the application, when loading a config file or when starting the config wizard
 | ||||
|  |  | |||
|  | @ -91,7 +91,7 @@ const t_field& OptionsGroup::build_field(const t_config_option_key& id, const Co | |||
|     return field; | ||||
| } | ||||
| 
 | ||||
| void OptionsGroup::add_undo_buttuns_to_sizer(wxBoxSizer* sizer, const t_field& field) | ||||
| void OptionsGroup::add_undo_buttuns_to_sizer(wxSizer* sizer, const t_field& field) | ||||
| { | ||||
| 	if (!m_is_tab_opt) { | ||||
| 		field->m_Undo_btn->Hide(); | ||||
|  | @ -177,7 +177,7 @@ void OptionsGroup::append_line(const Line& line, wxStaticText**	colored_Label/* | |||
| 	// If we're here, we have more than one option or a single option with sidetext
 | ||||
|     // so we need a horizontal sizer to arrange these things
 | ||||
| 	auto sizer = new wxBoxSizer(m_flag == ogSIDE_OPTIONS_VERTICAL ? wxVERTICAL : wxHORIZONTAL); | ||||
| 	grid_sizer->Add(sizer, 0, wxEXPAND | (staticbox ? wxALL : wxBOTTOM|wxTOP|wxLEFT), staticbox ? 0 : 1); | ||||
| 	grid_sizer->Add(sizer, 0, wxEXPAND | (staticbox ? wxALL : wxBOTTOM | wxTOP | wxLEFT), staticbox ? 0 : 1); | ||||
| 	// 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) { | ||||
|  | @ -195,7 +195,14 @@ void OptionsGroup::append_line(const Line& line, wxStaticText**	colored_Label/* | |||
| 
 | ||||
|     for (auto opt : option_set) { | ||||
| 		ConfigOptionDef option = opt.opt; | ||||
| 		wxBoxSizer* sizer_tmp = m_flag == ogSIDE_OPTIONS_VERTICAL ? new wxBoxSizer(wxHORIZONTAL) : sizer; | ||||
| 		wxSizer* sizer_tmp; | ||||
| 		if (m_flag == ogSIDE_OPTIONS_VERTICAL){ | ||||
| 			auto sz = new wxFlexGridSizer(1, 3, 2, 2); | ||||
| 			sz->RemoveGrowableCol(2); | ||||
| 			sizer_tmp = sz; | ||||
| 		} | ||||
|     	else | ||||
|     		sizer_tmp = sizer; | ||||
| 		// add label if any
 | ||||
| 		if (option.label != "") { | ||||
| 			wxString str_label = L_str(option.label); | ||||
|  | @ -205,7 +212,7 @@ void OptionsGroup::append_line(const Line& line, wxStaticText**	colored_Label/* | |||
| // 								L_str(option.label);
 | ||||
| 			label = new wxStaticText(parent(), wxID_ANY, str_label + ":", wxDefaultPosition, wxDefaultSize); | ||||
| 			label->SetFont(label_font); | ||||
| 			sizer_tmp->Add(label, 0, wxALIGN_CENTER_VERTICAL, 0); | ||||
| 			sizer_tmp->Add(label, 0, wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL, 0); | ||||
| 		} | ||||
| 
 | ||||
| 		// add field
 | ||||
|  | @ -218,9 +225,10 @@ void OptionsGroup::append_line(const Line& line, wxStaticText**	colored_Label/* | |||
| 		 | ||||
| 		// add sidetext if any
 | ||||
| 		if (option.sidetext != "") { | ||||
| 			auto sidetext = new wxStaticText(parent(), wxID_ANY, L_str(option.sidetext), wxDefaultPosition, wxDefaultSize); | ||||
| 			auto sidetext = new wxStaticText(	parent(), wxID_ANY, L_str(option.sidetext), wxDefaultPosition,  | ||||
| 												wxSize(sidetext_width, -1)/*wxDefaultSize*/, wxALIGN_LEFT); | ||||
| 			sidetext->SetFont(sidetext_font); | ||||
| 			sizer_tmp->Add(sidetext, 0, wxLEFT | wxALIGN_CENTER_VERTICAL, 4); | ||||
| 			sizer_tmp->Add(sidetext, 0, wxLEFT | wxALIGN_CENTER_VERTICAL, m_flag == ogSIDE_OPTIONS_VERTICAL ? 0 : 4); | ||||
| 		} | ||||
| 
 | ||||
| 		// add side widget if any
 | ||||
|  | @ -232,8 +240,9 @@ void OptionsGroup::append_line(const Line& line, wxStaticText**	colored_Label/* | |||
| 		{ | ||||
| 			sizer_tmp->AddSpacer(6); | ||||
| 	    } | ||||
| 
 | ||||
| 		if (m_flag == ogSIDE_OPTIONS_VERTICAL) | ||||
| 			sizer->Add(sizer_tmp, 1, wxEXPAND|wxALIGN_RIGHT|wxALL, 0); | ||||
| 			sizer->Add(sizer_tmp, 0, wxALIGN_RIGHT|wxALL, 0); | ||||
| 	} | ||||
| 	// add extra sizers if any
 | ||||
| 	for (auto extra_widget : line.get_extra_widgets()) { | ||||
|  |  | |||
|  | @ -93,8 +93,7 @@ public: | |||
| 
 | ||||
|     wxFont			sidetext_font {wxSystemSettings::GetFont(wxSYS_DEFAULT_GUI_FONT) }; | ||||
|     wxFont			label_font {wxSystemSettings::GetFont(wxSYS_DEFAULT_GUI_FONT) }; | ||||
| 
 | ||||
| //	std::function<const wxBitmap&()>	nonsys_btn_icon{ nullptr };
 | ||||
| 	int				sidetext_width{ -1 }; | ||||
| 
 | ||||
|     /// Returns a copy of the pointer of the parent wxWindow.
 | ||||
|     /// Accessor function is because users are not allowed to change the parent
 | ||||
|  | @ -132,14 +131,17 @@ public: | |||
| 	inline void		enable() { for (auto& field : m_fields) field.second->enable(); } | ||||
|     inline void		disable() { for (auto& field : m_fields) field.second->disable(); } | ||||
| 	void			set_flag(ogDrawFlag flag) { m_flag = flag; } | ||||
| 	void			set_grid_vgap(int gap) { m_grid_sizer->SetVGap(gap); } | ||||
| 
 | ||||
|     OptionsGroup(wxWindow* _parent, const wxString& title, bool is_tab_opt=false, ogDrawFlag flag = ogDEFAULT) :  | ||||
| 		m_parent(_parent), title(title), m_is_tab_opt(is_tab_opt), staticbox(title!=""), m_flag(flag) { | ||||
|         sizer = (staticbox ? new wxStaticBoxSizer(new wxStaticBox(_parent, wxID_ANY, title), wxVERTICAL) : new wxBoxSizer(wxVERTICAL)); | ||||
| 		auto stb = new wxStaticBox(_parent, wxID_ANY, title); | ||||
| 		stb->SetFont(bold_font()); | ||||
|         sizer = (staticbox ? new wxStaticBoxSizer(stb/*new wxStaticBox(_parent, wxID_ANY, title)*/, wxVERTICAL) : new wxBoxSizer(wxVERTICAL)); | ||||
|         auto num_columns = 1U; | ||||
|         if (label_width != 0) num_columns++; | ||||
|         if (extra_column != nullptr) num_columns++; | ||||
|         m_grid_sizer = new wxFlexGridSizer(0, num_columns, 0,0); | ||||
|         m_grid_sizer = new wxFlexGridSizer(0, num_columns, 1,0); | ||||
|         static_cast<wxFlexGridSizer*>(m_grid_sizer)->SetFlexibleDirection(wxBOTH/*wxHORIZONTAL*/); | ||||
|         static_cast<wxFlexGridSizer*>(m_grid_sizer)->AddGrowableCol(label_width != 0); | ||||
| #ifdef __WXGTK__ | ||||
|  | @ -179,7 +181,7 @@ protected: | |||
| 	const t_field&		build_field(const t_config_option_key& id, const ConfigOptionDef& opt, wxStaticText* label = nullptr); | ||||
| 	const t_field&		build_field(const t_config_option_key& id, wxStaticText* label = nullptr); | ||||
| 	const t_field&		build_field(const Option& opt, wxStaticText* label = nullptr); | ||||
| 	void				add_undo_buttuns_to_sizer(wxBoxSizer* sizer, const t_field& field); | ||||
| 	void				add_undo_buttuns_to_sizer(wxSizer* sizer, const t_field& field); | ||||
| 
 | ||||
|     virtual void		on_kill_focus (){}; | ||||
| 	virtual void		on_change_OG(const t_config_option_key& opt_id, const boost::any& value); | ||||
|  |  | |||
|  | @ -1446,7 +1446,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); | ||||
| 			//			btn->SetFont(Slic3r::GUI::small_font);
 | ||||
| 			btn->SetFont(Slic3r::GUI::small_font()); | ||||
| 			btn->SetBitmap(wxBitmap(from_u8(Slic3r::var("printer_empty.png")), wxBITMAP_TYPE_PNG)); | ||||
| 
 | ||||
| 			auto sizer = new wxBoxSizer(wxHORIZONTAL); | ||||
|  | @ -1514,7 +1514,7 @@ 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); | ||||
| //				btn->SetFont($Slic3r::GUI::small_font);
 | ||||
| 				btn->SetFont(Slic3r::GUI::small_font()); | ||||
| 				btn->SetBitmap(wxBitmap(from_u8(Slic3r::var("wrench.png")), wxBITMAP_TYPE_PNG)); | ||||
| 				auto sizer = new wxBoxSizer(wxHORIZONTAL); | ||||
| 				sizer->Add(btn); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 YuSanka
						YuSanka