mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 09:41:11 -06:00 
			
		
		
		
	DoubleSlider::Control -> Fixed crash when pressing numpad [+] and [-] keys while the horizontal slider has focus
This commit is contained in:
		
							parent
							
								
									94a4689b00
								
							
						
					
					
						commit
						a0acf24ab8
					
				
					 1 changed files with 31 additions and 7 deletions
				
			
		|  | @ -1387,6 +1387,22 @@ void Control::OnWheel(wxMouseEvent& event) | ||||||
| void Control::OnKeyDown(wxKeyEvent &event) | void Control::OnKeyDown(wxKeyEvent &event) | ||||||
| { | { | ||||||
|     const int key = event.GetKeyCode(); |     const int key = event.GetKeyCode(); | ||||||
|  | #if ENABLE_GCODE_VIEWER | ||||||
|  |     if (m_draw_mode != dmSequentialGCodeView && key == WXK_NUMPAD_ADD) { | ||||||
|  |         // OnChar() is called immediately after OnKeyDown(), which can cause call of add_tick() twice.
 | ||||||
|  |         // To avoid this case we should suppress second add_tick() call.
 | ||||||
|  |         m_ticks.suppress_plus(true); | ||||||
|  |         add_current_tick(true); | ||||||
|  |     } | ||||||
|  |     else if (m_draw_mode != dmSequentialGCodeView && (key == WXK_NUMPAD_SUBTRACT || key == WXK_DELETE || key == WXK_BACK)) { | ||||||
|  |         // OnChar() is called immediately after OnKeyDown(), which can cause call of delete_tick() twice.
 | ||||||
|  |         // To avoid this case we should suppress second delete_tick() call.
 | ||||||
|  |         m_ticks.suppress_minus(true); | ||||||
|  |         delete_current_tick(); | ||||||
|  |     } | ||||||
|  |     else if (m_draw_mode != dmSequentialGCodeView && event.GetKeyCode() == WXK_SHIFT) | ||||||
|  |         UseDefaultColors(false); | ||||||
|  | #else | ||||||
|     if (key == WXK_NUMPAD_ADD) { |     if (key == WXK_NUMPAD_ADD) { | ||||||
|         // OnChar() is called immediately after OnKeyDown(), which can cause call of add_tick() twice.
 |         // OnChar() is called immediately after OnKeyDown(), which can cause call of add_tick() twice.
 | ||||||
|         // To avoid this case we should suppress second add_tick() call.
 |         // To avoid this case we should suppress second add_tick() call.
 | ||||||
|  | @ -1401,6 +1417,7 @@ void Control::OnKeyDown(wxKeyEvent &event) | ||||||
|     } |     } | ||||||
|     else if (event.GetKeyCode() == WXK_SHIFT) |     else if (event.GetKeyCode() == WXK_SHIFT) | ||||||
|         UseDefaultColors(false); |         UseDefaultColors(false); | ||||||
|  | #endif // ENABLE_GCODE_VIEWER
 | ||||||
|     else if (is_horizontal()) |     else if (is_horizontal()) | ||||||
|     { |     { | ||||||
| #if ENABLE_GCODE_VIEWER | #if ENABLE_GCODE_VIEWER | ||||||
|  | @ -1451,14 +1468,21 @@ void Control::OnKeyUp(wxKeyEvent &event) | ||||||
| void Control::OnChar(wxKeyEvent& event) | void Control::OnChar(wxKeyEvent& event) | ||||||
| { | { | ||||||
|     const int key = event.GetKeyCode(); |     const int key = event.GetKeyCode(); | ||||||
|     if (key == '+' && !m_ticks.suppressed_plus()) { | #if ENABLE_GCODE_VIEWER | ||||||
|         add_current_tick(true); |     if (m_draw_mode != dmSequentialGCodeView) | ||||||
|         m_ticks.suppress_plus(false); |     { | ||||||
|     } | #endif // ENABLE_GCODE_VIEWER
 | ||||||
|     else if (key == '-' && !m_ticks.suppressed_minus()) { |         if (key == '+' && !m_ticks.suppressed_plus()) { | ||||||
|         delete_current_tick(); |             add_current_tick(true); | ||||||
|         m_ticks.suppress_minus(false); |             m_ticks.suppress_plus(false); | ||||||
|  |         } | ||||||
|  |         else if (key == '-' && !m_ticks.suppressed_minus()) { | ||||||
|  |             delete_current_tick(); | ||||||
|  |             m_ticks.suppress_minus(false); | ||||||
|  |         } | ||||||
|  | #if ENABLE_GCODE_VIEWER | ||||||
|     } |     } | ||||||
|  | #endif // ENABLE_GCODE_VIEWER
 | ||||||
|     if (key == 'G') |     if (key == 'G') | ||||||
| #if ENABLE_GCODE_VIEWER | #if ENABLE_GCODE_VIEWER | ||||||
|         jump_to_value(); |         jump_to_value(); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 enricoturri1966
						enricoturri1966