mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 10:11:10 -06:00 
			
		
		
		
	GLCanvas3D -> added support for cursor change and change cursor when using SLA support gizmo rectangle selection
This commit is contained in:
		
							parent
							
								
									9710140948
								
							
						
					
					
						commit
						d79a2b8d2d
					
				
					 7 changed files with 79 additions and 13 deletions
				
			
		|  | @ -485,7 +485,7 @@ bool GLGizmoSlaSupports::gizmo_event(SLAGizmoEventType action, const Vec2d& mous | |||
|         } | ||||
| 
 | ||||
|         // left down without selection rectangle - place point on the mesh:
 | ||||
|         if (action == SLAGizmoEventType::LeftDown && !m_selection_rectangle.is_active() && !shift_down) { | ||||
|         if (action == SLAGizmoEventType::LeftDown && !m_selection_rectangle.is_dragging() && !shift_down) { | ||||
|             // If any point is in hover state, this should initiate its move - return control back to GLCanvas:
 | ||||
|             if (m_hover_id != -1) | ||||
|                 return false; | ||||
|  | @ -510,7 +510,7 @@ bool GLGizmoSlaSupports::gizmo_event(SLAGizmoEventType action, const Vec2d& mous | |||
|         } | ||||
| 
 | ||||
|         // left up with selection rectangle - select points inside the rectangle:
 | ||||
|         if ((action == SLAGizmoEventType::LeftUp || action == SLAGizmoEventType::ShiftUp || action == SLAGizmoEventType::AltUp) && m_selection_rectangle.is_active()) { | ||||
|         if ((action == SLAGizmoEventType::LeftUp || action == SLAGizmoEventType::ShiftUp || action == SLAGizmoEventType::AltUp) && m_selection_rectangle.is_dragging()) { | ||||
|             // Is this a selection or deselection rectangle?
 | ||||
|             GLSelectionRectangle::EState rectangle_status = m_selection_rectangle.get_status(); | ||||
| 
 | ||||
|  | @ -601,7 +601,7 @@ bool GLGizmoSlaSupports::gizmo_event(SLAGizmoEventType action, const Vec2d& mous | |||
|                 return true; // point has been placed and the button not released yet
 | ||||
|                              // this prevents GLCanvas from starting scene rotation
 | ||||
| 
 | ||||
|             if (m_selection_rectangle.is_active())  { | ||||
|             if (m_selection_rectangle.is_dragging())  { | ||||
|                 m_selection_rectangle.dragging(mouse_position); | ||||
|                 return true; | ||||
|             } | ||||
|  |  | |||
|  | @ -68,6 +68,9 @@ public: | |||
|     void delete_selected_points(bool force = false); | ||||
|     ClippingPlane get_sla_clipping_plane() const; | ||||
| 
 | ||||
|     bool is_in_editing_mode() const { return m_editing_mode; } | ||||
|     bool is_selection_rectangle_dragging() const { return m_selection_rectangle.is_dragging(); } | ||||
| 
 | ||||
| private: | ||||
|     bool on_init(); | ||||
|     void on_update(const UpdateData& data, const Selection& selection); | ||||
|  |  | |||
|  | @ -843,13 +843,34 @@ bool GLGizmosManager::on_key(wxKeyEvent& evt, GLCanvas3D& canvas) | |||
| 
 | ||||
|     if (evt.GetEventType() == wxEVT_KEY_UP) | ||||
|     { | ||||
|         if ((m_current == SlaSupports) && (keyCode == WXK_SHIFT) && gizmo_event(SLAGizmoEventType::ShiftUp)) | ||||
|             // shift has been just released - SLA gizmo might want to close rectangular selection.
 | ||||
|             processed = true; | ||||
|         if (m_current == SlaSupports) | ||||
|         { | ||||
|             GLGizmoSlaSupports* gizmo = reinterpret_cast<GLGizmoSlaSupports*>(get_current()); | ||||
| 
 | ||||
|         if ((m_current == SlaSupports) && (keyCode == WXK_ALT) && gizmo_event(SLAGizmoEventType::AltUp)) | ||||
|             // alt has been just released - SLA gizmo might want to close rectangular selection.
 | ||||
|             if (keyCode == WXK_SHIFT) | ||||
|             { | ||||
|                 // shift has been just released - SLA gizmo might want to close rectangular selection.
 | ||||
|                 if (gizmo_event(SLAGizmoEventType::ShiftUp) || (gizmo->is_in_editing_mode() && gizmo->is_selection_rectangle_dragging())) | ||||
|                     processed = true; | ||||
|             } | ||||
|             else if (keyCode == WXK_ALT) | ||||
|             { | ||||
|                 // alt has been just released - SLA gizmo might want to close rectangular selection.
 | ||||
|                 if (gizmo_event(SLAGizmoEventType::AltUp) || (gizmo->is_in_editing_mode() && gizmo->is_selection_rectangle_dragging())) | ||||
|                     processed = true; | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         if (processed) | ||||
|             canvas.set_cursor(GLCanvas3D::Standard); | ||||
|     } | ||||
|     else if (evt.GetEventType() == wxEVT_KEY_DOWN) | ||||
|     { | ||||
|         if ((m_current == SlaSupports) && ((keyCode == WXK_SHIFT) || (keyCode == WXK_ALT)) && reinterpret_cast<GLGizmoSlaSupports*>(get_current())->is_in_editing_mode()) | ||||
|         { | ||||
|             canvas.set_cursor(GLCanvas3D::Cross); | ||||
|             processed = true; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     if (processed) | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Enrico Turri
						Enrico Turri