mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 02:01:12 -06:00 
			
		
		
		
	Extended hover capability in DoubleSlider::Control
This commit is contained in:
		
							parent
							
								
									bd4e4535f9
								
							
						
					
					
						commit
						7b5f84b7df
					
				
					 2 changed files with 24 additions and 8 deletions
				
			
		|  | @ -600,10 +600,8 @@ void Control::draw_tick_text(wxDC& dc, const wxPoint& pos, int tick, bool right_ | ||||||
|     const wxString label = get_label(tick); |     const wxString label = get_label(tick); | ||||||
|     dc.GetMultiLineTextExtent(label, &text_width, &text_height); |     dc.GetMultiLineTextExtent(label, &text_width, &text_height); | ||||||
|     wxPoint text_pos; |     wxPoint text_pos; | ||||||
|     if (right_side) |     if (right_side) { | ||||||
|     { |         if (is_horizontal()) { | ||||||
|         if (is_horizontal()) |  | ||||||
|         { |  | ||||||
|             int width; |             int width; | ||||||
|             int height; |             int height; | ||||||
|             get_size(&width, &height); |             get_size(&width, &height); | ||||||
|  | @ -614,17 +612,21 @@ void Control::draw_tick_text(wxDC& dc, const wxPoint& pos, int tick, bool right_ | ||||||
|         } |         } | ||||||
|         else |         else | ||||||
|             text_pos = wxPoint(pos.x + m_thumb_size.x + 1, pos.y - 0.5 * text_height - 1); |             text_pos = wxPoint(pos.x + m_thumb_size.x + 1, pos.y - 0.5 * text_height - 1); | ||||||
|  | 
 | ||||||
|  |         // update text rectangle
 | ||||||
|  |         m_rect_lower_thumb_text = wxRect(text_pos, wxSize(text_width, text_height)); | ||||||
|     } |     } | ||||||
|     else |     else { | ||||||
|     { |         if (is_horizontal()) { | ||||||
|         if (is_horizontal()) |  | ||||||
|         { |  | ||||||
|             int x = pos.x - text_width - 1; |             int x = pos.x - text_width - 1; | ||||||
|             int xx = (x > 0) ? x : pos.x + 1; |             int xx = (x > 0) ? x : pos.x + 1; | ||||||
|             text_pos = wxPoint(xx, pos.y - m_thumb_size.x / 2 - text_height - 1); |             text_pos = wxPoint(xx, pos.y - m_thumb_size.x / 2 - text_height - 1); | ||||||
|         } |         } | ||||||
|         else |         else | ||||||
|             text_pos = wxPoint(pos.x - text_width - 1 - m_thumb_size.x, pos.y - 0.5 * text_height + 1); |             text_pos = wxPoint(pos.x - text_width - 1 - m_thumb_size.x, pos.y - 0.5 * text_height + 1); | ||||||
|  | 
 | ||||||
|  |         // update text rectangle
 | ||||||
|  |         m_rect_higher_thumb_text = wxRect(text_pos, wxSize(text_width, text_height)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     dc.DrawText(label, text_pos); |     dc.DrawText(label, text_pos); | ||||||
|  | @ -1206,6 +1208,14 @@ void Control::OnMotion(wxMouseEvent& event) | ||||||
|         else if (m_mode == SingleExtruder && is_point_in_rect(pos, get_colored_band_rect()) && |         else if (m_mode == SingleExtruder && is_point_in_rect(pos, get_colored_band_rect()) && | ||||||
|                  get_edited_tick_for_position(pos) >= 0 ) |                  get_edited_tick_for_position(pos) >= 0 ) | ||||||
|             m_focus = fiColorBand; |             m_focus = fiColorBand; | ||||||
|  |         else if (is_point_in_rect(pos, m_rect_lower_thumb)) | ||||||
|  |             m_focus = fiLowerThumb; | ||||||
|  |         else if (is_point_in_rect(pos, m_rect_higher_thumb)) | ||||||
|  |             m_focus = fiHigherThumb; | ||||||
|  |         else if (is_point_in_rect(pos, m_rect_lower_thumb_text)) | ||||||
|  |             m_focus = fiLowerThumbText; | ||||||
|  |         else if (is_point_in_rect(pos, m_rect_higher_thumb_text)) | ||||||
|  |             m_focus = fiHigherThumbText; | ||||||
|         else { |         else { | ||||||
|             m_focus = fiTick; |             m_focus = fiTick; | ||||||
|             tick = get_tick_near_point(pos); |             tick = get_tick_near_point(pos); | ||||||
|  |  | ||||||
|  | @ -44,6 +44,10 @@ enum FocusedItem { | ||||||
|     fiCogIcon, |     fiCogIcon, | ||||||
|     fiColorBand, |     fiColorBand, | ||||||
|     fiActionIcon, |     fiActionIcon, | ||||||
|  |     fiLowerThumb, | ||||||
|  |     fiHigherThumb, | ||||||
|  |     fiLowerThumbText, | ||||||
|  |     fiHigherThumbText, | ||||||
|     fiTick |     fiTick | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | @ -360,6 +364,8 @@ private: | ||||||
| 
 | 
 | ||||||
|     wxRect      m_rect_lower_thumb; |     wxRect      m_rect_lower_thumb; | ||||||
|     wxRect      m_rect_higher_thumb; |     wxRect      m_rect_higher_thumb; | ||||||
|  |     mutable wxRect m_rect_lower_thumb_text; | ||||||
|  |     mutable wxRect m_rect_higher_thumb_text; | ||||||
|     wxRect      m_rect_tick_action; |     wxRect      m_rect_tick_action; | ||||||
|     wxRect      m_rect_one_layer_icon; |     wxRect      m_rect_one_layer_icon; | ||||||
|     wxRect      m_rect_revert_icon; |     wxRect      m_rect_revert_icon; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 enricoturri1966
						enricoturri1966