mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	Workaround for mouse events sent out of order
(mouse button down being sent before mouse enter)
This commit is contained in:
		
							parent
							
								
									f23919985f
								
							
						
					
					
						commit
						feef5608b9
					
				
					 1 changed files with 65 additions and 2 deletions
				
			
		|  | @ -4773,6 +4773,54 @@ void GLCanvas3D::on_timer(wxTimerEvent& evt) | ||||||
|         _perform_layer_editing_action(); |         _perform_layer_editing_action(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #ifndef NDEBUG | ||||||
|  | // #define SLIC3R_DEBUG_MOUSE_EVENTS
 | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | #ifdef SLIC3R_DEBUG_MOUSE_EVENTS | ||||||
|  | std::string format_mouse_event_debug_message(const wxMouseEvent &evt) | ||||||
|  | { | ||||||
|  | 	static int idx = 0; | ||||||
|  | 	char buf[2048]; | ||||||
|  | 	std::string out; | ||||||
|  | 	sprintf(buf, "Mouse Event %d - ", idx ++); | ||||||
|  | 	out = buf; | ||||||
|  | 
 | ||||||
|  | 	if (evt.Entering()) | ||||||
|  | 		out += "Entering "; | ||||||
|  | 	if (evt.Leaving()) | ||||||
|  | 		out += "Leaving "; | ||||||
|  | 	if (evt.Dragging()) | ||||||
|  | 		out += "Dragging "; | ||||||
|  | 	if (evt.Moving()) | ||||||
|  | 		out += "Moving "; | ||||||
|  | 	if (evt.Magnify()) | ||||||
|  | 		out += "Magnify "; | ||||||
|  | 	if (evt.LeftDown()) | ||||||
|  | 		out += "LeftDown "; | ||||||
|  | 	if (evt.LeftUp()) | ||||||
|  | 		out += "LeftUp "; | ||||||
|  | 	if (evt.LeftDClick()) | ||||||
|  | 		out += "LeftDClick "; | ||||||
|  | 	if (evt.MiddleDown()) | ||||||
|  | 		out += "MiddleDown "; | ||||||
|  | 	if (evt.MiddleUp()) | ||||||
|  | 		out += "MiddleUp "; | ||||||
|  | 	if (evt.MiddleDClick()) | ||||||
|  | 		out += "MiddleDClick "; | ||||||
|  | 	if (evt.RightDown()) | ||||||
|  | 		out += "RightDown "; | ||||||
|  | 	if (evt.RightUp()) | ||||||
|  | 		out += "RightUp "; | ||||||
|  | 	if (evt.RightDClick()) | ||||||
|  | 		out += "RightDClick "; | ||||||
|  | 
 | ||||||
|  | 	sprintf(buf, "(%d, %d)", evt.GetX(), evt.GetY()); | ||||||
|  | 	out += buf; | ||||||
|  | 	return out; | ||||||
|  | } | ||||||
|  | #endif /* SLIC3R_DEBUG_MOUSE_EVENTS */ | ||||||
|  | 
 | ||||||
| void GLCanvas3D::on_mouse(wxMouseEvent& evt) | void GLCanvas3D::on_mouse(wxMouseEvent& evt) | ||||||
| { | { | ||||||
| #if ENABLE_RETINA_GL | #if ENABLE_RETINA_GL | ||||||
|  | @ -4788,15 +4836,27 @@ void GLCanvas3D::on_mouse(wxMouseEvent& evt) | ||||||
|     if (imgui->update_mouse_data(evt)) { |     if (imgui->update_mouse_data(evt)) { | ||||||
|         m_mouse.position = evt.Leaving() ? Vec2d(-1.0, -1.0) : pos.cast<double>(); |         m_mouse.position = evt.Leaving() ? Vec2d(-1.0, -1.0) : pos.cast<double>(); | ||||||
|         render(); |         render(); | ||||||
|         return; | #ifdef SLIC3R_DEBUG_MOUSE_EVENTS | ||||||
|  | 		printf((format_mouse_event_debug_message(evt) + " - Consumed by ImGUI\n").c_str()); | ||||||
|  | #endif /* SLIC3R_DEBUG_MOUSE_EVENTS */ | ||||||
|  | 		return; | ||||||
|     } |     } | ||||||
| #endif // ENABLE_IMGUI
 | #endif // ENABLE_IMGUI
 | ||||||
| 
 | 
 | ||||||
|  | 	bool on_enter_workaround = false; | ||||||
|     if (! evt.Entering() && ! evt.Leaving() && m_mouse.position.x() == -1.0) { |     if (! evt.Entering() && ! evt.Leaving() && m_mouse.position.x() == -1.0) { | ||||||
|         // Workaround for SPE-832: There seems to be a mouse event sent to the window before evt.Entering()
 |         // Workaround for SPE-832: There seems to be a mouse event sent to the window before evt.Entering()
 | ||||||
|         m_mouse.position = pos.cast<double>(); |         m_mouse.position = pos.cast<double>(); | ||||||
|         render(); |         render(); | ||||||
|     } | #ifdef SLIC3R_DEBUG_MOUSE_EVENTS | ||||||
|  | 		printf((format_mouse_event_debug_message(evt) + " - OnEnter workaround\n").c_str()); | ||||||
|  | #endif /* SLIC3R_DEBUG_MOUSE_EVENTS */ | ||||||
|  | 		on_enter_workaround = true; | ||||||
|  |     } else { | ||||||
|  | #ifdef SLIC3R_DEBUG_MOUSE_EVENTS | ||||||
|  | 		printf((format_mouse_event_debug_message(evt) + " - other\n").c_str()); | ||||||
|  | #endif /* SLIC3R_DEBUG_MOUSE_EVENTS */ | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
|     if (m_picking_enabled) |     if (m_picking_enabled) | ||||||
|         _set_current(); |         _set_current(); | ||||||
|  | @ -5244,6 +5304,9 @@ void GLCanvas3D::on_mouse(wxMouseEvent& evt) | ||||||
|     } |     } | ||||||
|     else |     else | ||||||
|         evt.Skip(); |         evt.Skip(); | ||||||
|  | 
 | ||||||
|  | 	if (on_enter_workaround) | ||||||
|  | 		m_mouse.position = Vec2d(-1., -1.); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void GLCanvas3D::on_paint(wxPaintEvent& evt) | void GLCanvas3D::on_paint(wxPaintEvent& evt) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bubnikv
						bubnikv