mirror of
				https://git.mirrors.martin98.com/https://github.com/slic3r/Slic3r.git
				synced 2025-10-21 02:41:07 +08:00 
			
		
		
		
	Some code refactoring
This commit is contained in:
		
							parent
							
								
									e2349bdd2e
								
							
						
					
					
						commit
						452eb62f11
					
				| @ -530,7 +530,7 @@ void GUI_App::update_mode() | |||||||
|     sidebar().update_mode(); |     sidebar().update_mode(); | ||||||
| 
 | 
 | ||||||
|     for (auto tab : tabs_list) |     for (auto tab : tabs_list) | ||||||
|         tab->update_visibility(); |         tab->update_mode(); | ||||||
| 
 | 
 | ||||||
|     plater()->update_object_menu(); |     plater()->update_object_menu(); | ||||||
| } | } | ||||||
|  | |||||||
| @ -705,25 +705,28 @@ void Tab::reload_config() | |||||||
| // 	Thaw();
 | // 	Thaw();
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Tab::update_visibility() | void Tab::update_mode() | ||||||
| { | { | ||||||
|     const ConfigOptionMode mode = wxGetApp().get_mode(); |     m_mode = wxGetApp().get_mode(); | ||||||
| //    Freeze();
 |  | ||||||
| 
 |  | ||||||
| 	for (auto page : m_pages) |  | ||||||
|         page->update_visibility(mode); |  | ||||||
|     update_page_tree_visibility(); |  | ||||||
| 
 | 
 | ||||||
|     // update mode for ModeSizer
 |     // update mode for ModeSizer
 | ||||||
|     m_mode_sizer->SetMode(mode); |     m_mode_sizer->SetMode(m_mode); | ||||||
|  | 
 | ||||||
|  |     update_visibility(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void Tab::update_visibility() | ||||||
|  | { | ||||||
|  |     Freeze(); // There is needed Freeze/Thaw to avoid a flashing after Show/Layout
 | ||||||
|  | 
 | ||||||
|  | 	for (auto page : m_pages) | ||||||
|  |         page->update_visibility(m_mode); | ||||||
|  |     update_page_tree_visibility(); | ||||||
| 
 | 
 | ||||||
|     Layout(); |     Layout(); | ||||||
| //	Thaw();
 | 	Thaw(); | ||||||
| 
 | 
 | ||||||
|     // to update tree items color
 |  | ||||||
| //    wxTheApp->CallAfter([this]() {
 |  | ||||||
|     update_changed_tree_ui(); |     update_changed_tree_ui(); | ||||||
| //     });
 |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Field* Tab::get_field(const t_config_option_key& opt_key, int opt_index/* = -1*/) const | Field* Tab::get_field(const t_config_option_key& opt_key, int opt_index/* = -1*/) const | ||||||
| @ -2264,7 +2267,7 @@ void TabPrinter::update_pages() | |||||||
|     else  |     else  | ||||||
|         m_pages_sla.empty() ? build_sla() : m_pages.swap(m_pages_sla); |         m_pages_sla.empty() ? build_sla() : m_pages.swap(m_pages_sla); | ||||||
| 
 | 
 | ||||||
|     rebuild_page_tree(true); |     rebuild_page_tree(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void TabPrinter::update() | void TabPrinter::update() | ||||||
| @ -2470,10 +2473,8 @@ void Tab::load_current_preset() | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| //Regerenerate content of the page tree.
 | //Regerenerate content of the page tree.
 | ||||||
| void Tab::rebuild_page_tree(bool tree_sel_change_event /*= false*/) | void Tab::rebuild_page_tree() | ||||||
| { | { | ||||||
| // 	Freeze();
 |  | ||||||
| 
 |  | ||||||
| 	// get label of the currently selected item
 | 	// get label of the currently selected item
 | ||||||
|     const auto sel_item = m_treectrl->GetSelection(); |     const auto sel_item = m_treectrl->GetSelection(); | ||||||
| 	const auto selected = sel_item ? m_treectrl->GetItemText(sel_item) : ""; | 	const auto selected = sel_item ? m_treectrl->GetItemText(sel_item) : ""; | ||||||
| @ -2486,10 +2487,7 @@ void Tab::rebuild_page_tree(bool tree_sel_change_event /*= false*/) | |||||||
| 		auto itemId = m_treectrl->AppendItem(rootItem, p->title(), p->iconID()); | 		auto itemId = m_treectrl->AppendItem(rootItem, p->title(), p->iconID()); | ||||||
| 		m_treectrl->SetItemTextColour(itemId, p->get_item_colour()); | 		m_treectrl->SetItemTextColour(itemId, p->get_item_colour()); | ||||||
| 		if (p->title() == selected) { | 		if (p->title() == selected) { | ||||||
| // 			if (!(p->title() == _(L("Machine limits")) || p->title() == _(L("Single extruder MM setup")))) // These Pages have to be updated inside OnTreeSelChange
 |  | ||||||
| // 				m_disable_tree_sel_changed_event = !tree_sel_change_event;
 |  | ||||||
| 			m_treectrl->SelectItem(itemId); | 			m_treectrl->SelectItem(itemId); | ||||||
| 			m_disable_tree_sel_changed_event = false; |  | ||||||
| 			have_selection = 1; | 			have_selection = 1; | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -209,6 +209,7 @@ protected: | |||||||
|     int                 m_em_unit; |     int                 m_em_unit; | ||||||
|     // To avoid actions with no-completed Tab
 |     // To avoid actions with no-completed Tab
 | ||||||
|     bool                m_complited { false }; |     bool                m_complited { false }; | ||||||
|  |     ConfigOptionMode    m_mode = comSimple; | ||||||
| 
 | 
 | ||||||
| public: | public: | ||||||
| 	PresetBundle*		m_preset_bundle; | 	PresetBundle*		m_preset_bundle; | ||||||
| @ -236,7 +237,7 @@ public: | |||||||
| 
 | 
 | ||||||
| 	void		create_preset_tab(); | 	void		create_preset_tab(); | ||||||
| 	void		load_current_preset(); | 	void		load_current_preset(); | ||||||
| 	void        rebuild_page_tree(bool tree_sel_change_event = false); | 	void        rebuild_page_tree(); | ||||||
| 	void        update_page_tree_visibility(); | 	void        update_page_tree_visibility(); | ||||||
| 	void		select_preset(std::string preset_name = ""); | 	void		select_preset(std::string preset_name = ""); | ||||||
| 	bool		may_discard_current_dirty_preset(PresetCollection* presets = nullptr, const std::string& new_printer_name = ""); | 	bool		may_discard_current_dirty_preset(PresetCollection* presets = nullptr, const std::string& new_printer_name = ""); | ||||||
| @ -270,6 +271,7 @@ public: | |||||||
| 	void			update_tab_ui(); | 	void			update_tab_ui(); | ||||||
| 	void			load_config(const DynamicPrintConfig& config); | 	void			load_config(const DynamicPrintConfig& config); | ||||||
| 	virtual void	reload_config(); | 	virtual void	reload_config(); | ||||||
|  |     void            update_mode(); | ||||||
|     void            update_visibility(); |     void            update_visibility(); | ||||||
| 	Field*			get_field(const t_config_option_key& opt_key, int opt_index = -1) const; | 	Field*			get_field(const t_config_option_key& opt_key, int opt_index = -1) const; | ||||||
| 	bool			set_value(const t_config_option_key& opt_key, const boost::any& value); | 	bool			set_value(const t_config_option_key& opt_key, const boost::any& value); | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 YuSanka
						YuSanka