mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	Do not allow 'replace by stl' when a gizmo is active,
some of the gizmos might not cope well. ALso avoided code duplication in all such cases (currently fix by Netfabb, simplify, replace by stl).
This commit is contained in:
		
							parent
							
								
									a4300b8e64
								
							
						
					
					
						commit
						315663980b
					
				
					 4 changed files with 31 additions and 25 deletions
				
			
		|  | @ -4030,17 +4030,12 @@ void ObjectList::simplify() | ||||||
| 
 | 
 | ||||||
|     // Do not simplify when a gizmo is open. There might be issues with updates
 |     // Do not simplify when a gizmo is open. There might be issues with updates
 | ||||||
|     // and what is worse, the snapshot time would refer to the internal stack.
 |     // and what is worse, the snapshot time would refer to the internal stack.
 | ||||||
|     auto current_type = gizmos_mgr.get_current_type(); |     if (! gizmos_mgr.check_gizmos_closed_except(GLGizmosManager::EType::Simplify)) | ||||||
|     if (current_type == GLGizmosManager::Simplify) { |         return; | ||||||
|  | 
 | ||||||
|  |     if (gizmos_mgr.get_current_type() == GLGizmosManager::Simplify) { | ||||||
|         // close first
 |         // close first
 | ||||||
|         gizmos_mgr.open_gizmo(GLGizmosManager::EType::Simplify); |         gizmos_mgr.open_gizmo(GLGizmosManager::EType::Simplify); | ||||||
|     }else if (current_type != GLGizmosManager::Undefined) { |  | ||||||
|         plater->get_notification_manager()->push_notification( |  | ||||||
|             NotificationType::CustomSupportsAndSeamRemovedAfterRepair, |  | ||||||
|             NotificationManager::NotificationLevel::RegularNotification, |  | ||||||
|             _u8L("ERROR: Please close all manipulators available from " |  | ||||||
|                  "the left toolbar before start simplify the mesh.")); |  | ||||||
|         return; |  | ||||||
|     } |     } | ||||||
|     gizmos_mgr.open_gizmo(GLGizmosManager::EType::Simplify); |     gizmos_mgr.open_gizmo(GLGizmosManager::EType::Simplify); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -164,10 +164,8 @@ void GLGizmosManager::refresh_on_off_state() | ||||||
|         return; |         return; | ||||||
| 
 | 
 | ||||||
|     if (m_current != Undefined |     if (m_current != Undefined | ||||||
|     && ! m_gizmos[m_current]->is_activable()) { |     && ! m_gizmos[m_current]->is_activable() && activate_gizmo(Undefined)) | ||||||
|         activate_gizmo(Undefined); |  | ||||||
|         update_data(); |         update_data(); | ||||||
|     } |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void GLGizmosManager::reset_all_states() | void GLGizmosManager::reset_all_states() | ||||||
|  | @ -182,14 +180,28 @@ void GLGizmosManager::reset_all_states() | ||||||
| bool GLGizmosManager::open_gizmo(EType type) | bool GLGizmosManager::open_gizmo(EType type) | ||||||
| { | { | ||||||
|     int idx = int(type); |     int idx = int(type); | ||||||
|     if (m_gizmos[idx]->is_activable()) { |     if (m_gizmos[idx]->is_activable() | ||||||
|         activate_gizmo(m_current == idx ? Undefined : (EType)idx); |      && activate_gizmo(m_current == idx ? Undefined : (EType)idx)) { | ||||||
|         update_data(); |         update_data(); | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|     return false; |     return false; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|  | bool GLGizmosManager::check_gizmos_closed_except(EType type) const | ||||||
|  | { | ||||||
|  |     if (get_current_type() != type && get_current_type() != Undefined) { | ||||||
|  |         wxGetApp().plater()->get_notification_manager()->push_notification( | ||||||
|  |                     NotificationType::CustomSupportsAndSeamRemovedAfterRepair, | ||||||
|  |                     NotificationManager::NotificationLevel::RegularNotification, | ||||||
|  |                     _u8L("ERROR: Please close all manipulators available from " | ||||||
|  |                          "the left toolbar first")); | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |     return true; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void GLGizmosManager::set_hover_id(int id) | void GLGizmosManager::set_hover_id(int id) | ||||||
| { | { | ||||||
|     if (!m_enabled || m_current == Undefined) |     if (!m_enabled || m_current == Undefined) | ||||||
|  | @ -1194,10 +1206,10 @@ std::string GLGizmosManager::update_hover_state(const Vec2d& mouse_pos) | ||||||
|     return name; |     return name; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void GLGizmosManager::activate_gizmo(EType type) | bool GLGizmosManager::activate_gizmo(EType type) | ||||||
| { | { | ||||||
|     if (m_gizmos.empty() || m_current == type) |     if (m_gizmos.empty() || m_current == type) | ||||||
|         return; |         return true; | ||||||
| 
 | 
 | ||||||
|     GLGizmoBase* old_gizmo = m_current == Undefined ? nullptr : m_gizmos[m_current].get(); |     GLGizmoBase* old_gizmo = m_current == Undefined ? nullptr : m_gizmos[m_current].get(); | ||||||
|     GLGizmoBase* new_gizmo = type == Undefined ? nullptr : m_gizmos[type].get(); |     GLGizmoBase* new_gizmo = type == Undefined ? nullptr : m_gizmos[type].get(); | ||||||
|  | @ -1205,7 +1217,7 @@ void GLGizmosManager::activate_gizmo(EType type) | ||||||
|     if (old_gizmo) { |     if (old_gizmo) { | ||||||
|         old_gizmo->set_state(GLGizmoBase::Off); |         old_gizmo->set_state(GLGizmoBase::Off); | ||||||
|         if (old_gizmo->get_state() != GLGizmoBase::Off) |         if (old_gizmo->get_state() != GLGizmoBase::Off) | ||||||
|             return; // gizmo refused to be turned off, do nothing.
 |             return false; // gizmo refused to be turned off, do nothing.
 | ||||||
| 
 | 
 | ||||||
|         if (! m_parent.get_gizmos_manager().is_serializing() |         if (! m_parent.get_gizmos_manager().is_serializing() | ||||||
|          && old_gizmo->wants_enter_leave_snapshots()) |          && old_gizmo->wants_enter_leave_snapshots()) | ||||||
|  | @ -1222,6 +1234,7 @@ void GLGizmosManager::activate_gizmo(EType type) | ||||||
| 
 | 
 | ||||||
|     if (new_gizmo) |     if (new_gizmo) | ||||||
|         new_gizmo->set_state(GLGizmoBase::On); |         new_gizmo->set_state(GLGizmoBase::On); | ||||||
|  |     return true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -104,7 +104,7 @@ private: | ||||||
|     std::vector<size_t> get_selectable_idxs() const; |     std::vector<size_t> get_selectable_idxs() const; | ||||||
|     size_t get_gizmo_idx_from_mouse(const Vec2d& mouse_pos) const; |     size_t get_gizmo_idx_from_mouse(const Vec2d& mouse_pos) const; | ||||||
| 
 | 
 | ||||||
|     void activate_gizmo(EType type); |     bool activate_gizmo(EType type); | ||||||
| 
 | 
 | ||||||
|     struct MouseCapture |     struct MouseCapture | ||||||
|     { |     { | ||||||
|  | @ -176,6 +176,7 @@ public: | ||||||
|     void reset_all_states(); |     void reset_all_states(); | ||||||
|     bool is_serializing() const { return m_serializing; } |     bool is_serializing() const { return m_serializing; } | ||||||
|     bool open_gizmo(EType type); |     bool open_gizmo(EType type); | ||||||
|  |     bool check_gizmos_closed_except(EType) const; | ||||||
| 
 | 
 | ||||||
|     void set_hover_id(int id); |     void set_hover_id(int id); | ||||||
|     void enable_grabber(EType type, unsigned int id, bool enable); |     void enable_grabber(EType type, unsigned int id, bool enable); | ||||||
|  |  | ||||||
|  | @ -3186,6 +3186,9 @@ void Plater::priv::update_sla_scene() | ||||||
| 
 | 
 | ||||||
| void Plater::priv::replace_with_stl() | void Plater::priv::replace_with_stl() | ||||||
| { | { | ||||||
|  |     if (! q->canvas3D()->get_gizmos_manager().check_gizmos_closed_except(GLGizmosManager::EType::Undefined)) | ||||||
|  |         return; | ||||||
|  | 
 | ||||||
|     const Selection& selection = get_selection(); |     const Selection& selection = get_selection(); | ||||||
| 
 | 
 | ||||||
|     if (selection.is_wipe_tower() || get_selection().get_volume_idxs().size() != 1) |     if (selection.is_wipe_tower() || get_selection().get_volume_idxs().size() != 1) | ||||||
|  | @ -3530,14 +3533,8 @@ void Plater::priv::fix_through_netfabb(const int obj_idx, const int vol_idx/* = | ||||||
| 
 | 
 | ||||||
|     // Do not fix anything when a gizmo is open. There might be issues with updates
 |     // Do not fix anything when a gizmo is open. There might be issues with updates
 | ||||||
|     // and what is worse, the snapshot time would refer to the internal stack.
 |     // and what is worse, the snapshot time would refer to the internal stack.
 | ||||||
|     if (q->canvas3D()->get_gizmos_manager().get_current_type() != GLGizmosManager::Undefined) { |     if (! q->canvas3D()->get_gizmos_manager().check_gizmos_closed_except(GLGizmosManager::Undefined)) | ||||||
|         notification_manager->push_notification( |  | ||||||
|                     NotificationType::CustomSupportsAndSeamRemovedAfterRepair, |  | ||||||
|                     NotificationManager::NotificationLevel::RegularNotification, |  | ||||||
|                     _u8L("ERROR: Please close all manipulators available from " |  | ||||||
|                          "the left toolbar before fixing the mesh.")); |  | ||||||
|         return; |         return; | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
|     // size_t snapshot_time = undo_redo_stack().active_snapshot_time();
 |     // size_t snapshot_time = undo_redo_stack().active_snapshot_time();
 | ||||||
|     Plater::TakeSnapshot snapshot(q, _L("Fix through NetFabb")); |     Plater::TakeSnapshot snapshot(q, _L("Fix through NetFabb")); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lukas Matena
						Lukas Matena