mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 17:51:10 -06:00 
			
		
		
		
	Color_print issues :
- fixed #1933 - implemented thumb moving to the mouse click position - implemented "discard color changes" button
This commit is contained in:
		
							parent
							
								
									fe395546f0
								
							
						
					
					
						commit
						14d8621ffe
					
				
					 2 changed files with 73 additions and 9 deletions
				
			
		|  | @ -1583,6 +1583,9 @@ DoubleSlider::DoubleSlider( wxWindow *parent, | ||||||
|     m_bmp_one_layer_unlock_off = ScalableBitmap(this, "one_layer_unlock_off.png"); |     m_bmp_one_layer_unlock_off = ScalableBitmap(this, "one_layer_unlock_off.png"); | ||||||
|     m_lock_icon_dim = m_bmp_one_layer_lock_on.bmp().GetSize().x; |     m_lock_icon_dim = m_bmp_one_layer_lock_on.bmp().GetSize().x; | ||||||
| 
 | 
 | ||||||
|  |     m_bmp_revert               = ScalableBitmap(this, "undo"); | ||||||
|  |     m_revert_icon_dim = m_bmp_revert.bmp().GetSize().x; | ||||||
|  | 
 | ||||||
|     m_selection = ssUndef; |     m_selection = ssUndef; | ||||||
| 
 | 
 | ||||||
|     // slider events
 |     // slider events
 | ||||||
|  | @ -1638,6 +1641,9 @@ void DoubleSlider::msw_rescale() | ||||||
|     m_bmp_one_layer_unlock_off.msw_rescale(); |     m_bmp_one_layer_unlock_off.msw_rescale(); | ||||||
|     m_lock_icon_dim = m_bmp_one_layer_lock_on.bmp().GetSize().x; |     m_lock_icon_dim = m_bmp_one_layer_lock_on.bmp().GetSize().x; | ||||||
| 
 | 
 | ||||||
|  |     m_bmp_revert.msw_rescale(); | ||||||
|  |     m_revert_icon_dim = m_bmp_revert.bmp().GetSize().x; | ||||||
|  | 
 | ||||||
|     SLIDER_MARGIN = 4 + Slic3r::GUI::wxGetApp().em_unit(); |     SLIDER_MARGIN = 4 + Slic3r::GUI::wxGetApp().em_unit(); | ||||||
| 
 | 
 | ||||||
|     SetMinSize(get_min_size()); |     SetMinSize(get_min_size()); | ||||||
|  | @ -1874,8 +1880,11 @@ void DoubleSlider::render() | ||||||
|     //draw color print ticks
 |     //draw color print ticks
 | ||||||
|     draw_ticks(dc); |     draw_ticks(dc); | ||||||
| 
 | 
 | ||||||
|     //draw color print ticks
 |     //draw lock/unlock
 | ||||||
|     draw_one_layer_icon(dc); |     draw_one_layer_icon(dc); | ||||||
|  | 
 | ||||||
|  |     //draw revert bitmap (if it's shown)
 | ||||||
|  |     draw_revert_icon(dc); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void DoubleSlider::draw_action_icon(wxDC& dc, const wxPoint pt_beg, const wxPoint pt_end) | void DoubleSlider::draw_action_icon(wxDC& dc, const wxPoint pt_beg, const wxPoint pt_end) | ||||||
|  | @ -2102,6 +2111,24 @@ void DoubleSlider::draw_one_layer_icon(wxDC& dc) | ||||||
|     m_rect_one_layer_icon = wxRect(x_draw, y_draw, m_lock_icon_dim, m_lock_icon_dim); |     m_rect_one_layer_icon = wxRect(x_draw, y_draw, m_lock_icon_dim, m_lock_icon_dim); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void DoubleSlider::draw_revert_icon(wxDC& dc) | ||||||
|  | { | ||||||
|  |     if (m_ticks.empty()) | ||||||
|  |         return; | ||||||
|  | 
 | ||||||
|  |     int width, height; | ||||||
|  |     get_size(&width, &height); | ||||||
|  | 
 | ||||||
|  |     wxCoord x_draw, y_draw; | ||||||
|  |     is_horizontal() ? x_draw = width-2 : x_draw = 0.25*SLIDER_MARGIN; | ||||||
|  |     is_horizontal() ? y_draw = 0.25*SLIDER_MARGIN: y_draw = height-2; | ||||||
|  | 
 | ||||||
|  |     dc.DrawBitmap(m_bmp_revert.bmp(), x_draw, y_draw); | ||||||
|  | 
 | ||||||
|  |     //update rect of the lock/unlock icon
 | ||||||
|  |     m_rect_revert_icon = wxRect(x_draw, y_draw, m_revert_icon_dim, m_revert_icon_dim); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void DoubleSlider::update_thumb_rect(const wxCoord& begin_x, const wxCoord& begin_y, const SelectedSlider& selection) | void DoubleSlider::update_thumb_rect(const wxCoord& begin_x, const wxCoord& begin_y, const SelectedSlider& selection) | ||||||
| { | { | ||||||
|     const wxRect& rect = wxRect(begin_x, begin_y, m_thumb_size.x, m_thumb_size.y); |     const wxRect& rect = wxRect(begin_x, begin_y, m_thumb_size.x, m_thumb_size.y); | ||||||
|  | @ -2118,7 +2145,7 @@ int DoubleSlider::get_value_from_position(const wxCoord x, const wxCoord y) | ||||||
|      |      | ||||||
|     if (is_horizontal())  |     if (is_horizontal())  | ||||||
|         return int(double(x - SLIDER_MARGIN) / step + 0.5); |         return int(double(x - SLIDER_MARGIN) / step + 0.5); | ||||||
|     else  | 
 | ||||||
|     return int(m_min_value + double(height - SLIDER_MARGIN - y) / step + 0.5); |     return int(m_min_value + double(height - SLIDER_MARGIN - y) / step + 0.5); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -2169,7 +2196,10 @@ void DoubleSlider::ChangeOneLayerLock() | ||||||
| 
 | 
 | ||||||
| void DoubleSlider::OnLeftDown(wxMouseEvent& event) | void DoubleSlider::OnLeftDown(wxMouseEvent& event) | ||||||
| { | { | ||||||
|  |     if (HasCapture()) | ||||||
|  |         return; | ||||||
|     this->CaptureMouse(); |     this->CaptureMouse(); | ||||||
|  | 
 | ||||||
|     wxClientDC dc(this); |     wxClientDC dc(this); | ||||||
|     wxPoint pos = event.GetLogicalPosition(dc); |     wxPoint pos = event.GetLogicalPosition(dc); | ||||||
|     if (is_point_in_rect(pos, m_rect_tick_action) && m_is_enabled_tick_manipulation) { |     if (is_point_in_rect(pos, m_rect_tick_action) && m_is_enabled_tick_manipulation) { | ||||||
|  | @ -2179,6 +2209,7 @@ void DoubleSlider::OnLeftDown(wxMouseEvent& event) | ||||||
| 
 | 
 | ||||||
|     m_is_left_down = true; |     m_is_left_down = true; | ||||||
|     if (is_point_in_rect(pos, m_rect_one_layer_icon)) { |     if (is_point_in_rect(pos, m_rect_one_layer_icon)) { | ||||||
|  |         // switch on/off one layer mode
 | ||||||
|         m_is_one_layer = !m_is_one_layer; |         m_is_one_layer = !m_is_one_layer; | ||||||
|         if (!m_is_one_layer) { |         if (!m_is_one_layer) { | ||||||
|             SetLowerValue(m_min_value); |             SetLowerValue(m_min_value); | ||||||
|  | @ -2187,20 +2218,36 @@ void DoubleSlider::OnLeftDown(wxMouseEvent& event) | ||||||
|         m_selection == ssLower ? correct_lower_value() : correct_higher_value(); |         m_selection == ssLower ? correct_lower_value() : correct_higher_value(); | ||||||
|         if (!m_selection) m_selection = ssHigher; |         if (!m_selection) m_selection = ssHigher; | ||||||
|     } |     } | ||||||
|  |     else if (is_point_in_rect(pos, m_rect_revert_icon)) { | ||||||
|  |         // discard all color changes
 | ||||||
|  |         SetLowerValue(m_min_value); | ||||||
|  |         SetHigherValue(m_max_value); | ||||||
|  | 
 | ||||||
|  |         m_selection == ssLower ? correct_lower_value() : correct_higher_value(); | ||||||
|  |         if (!m_selection) m_selection = ssHigher; | ||||||
|  | 
 | ||||||
|  |         m_ticks.clear(); | ||||||
|  |         wxPostEvent(this->GetParent(), wxCommandEvent(wxCUSTOMEVT_TICKSCHANGED)); | ||||||
|  |     } | ||||||
|     else |     else | ||||||
|         detect_selected_slider(pos); |         detect_selected_slider(pos); | ||||||
| 
 | 
 | ||||||
|     if (!m_selection && m_is_enabled_tick_manipulation) { |     if (!m_selection) { | ||||||
|         const auto tick = is_point_near_tick(pos); |         const int tick_val  = is_point_near_tick(pos); | ||||||
|         if (tick >= 0) |         /* Set current thumb position to the nearest tick (if it is)
 | ||||||
|  |          * OR to a value corresponding to the mouse click | ||||||
|  |          * */  | ||||||
|  |         const int mouse_val = tick_val >= 0 && m_is_enabled_tick_manipulation ? tick_val :  | ||||||
|  |                               get_value_from_position(pos.x, pos.y); | ||||||
|  |         if (mouse_val >= 0) | ||||||
|         { |         { | ||||||
|             if (abs(tick - m_lower_value) < abs(tick - m_higher_value)) { |             if (abs(mouse_val - m_lower_value) < abs(mouse_val - m_higher_value)) { | ||||||
|                 SetLowerValue(tick); |                 SetLowerValue(mouse_val); | ||||||
|                 correct_lower_value(); |                 correct_lower_value(); | ||||||
|                 m_selection = ssLower; |                 m_selection = ssLower; | ||||||
|             } |             } | ||||||
|             else { |             else { | ||||||
|                 SetHigherValue(tick); |                 SetHigherValue(mouse_val); | ||||||
|                 correct_higher_value(); |                 correct_higher_value(); | ||||||
|                 m_selection = ssHigher; |                 m_selection = ssHigher; | ||||||
|             } |             } | ||||||
|  | @ -2240,9 +2287,13 @@ void DoubleSlider::OnMotion(wxMouseEvent& event) | ||||||
| 
 | 
 | ||||||
|     const wxClientDC dc(this); |     const wxClientDC dc(this); | ||||||
|     const wxPoint pos = event.GetLogicalPosition(dc); |     const wxPoint pos = event.GetLogicalPosition(dc); | ||||||
|  | 
 | ||||||
|     m_is_one_layer_icon_focesed = is_point_in_rect(pos, m_rect_one_layer_icon); |     m_is_one_layer_icon_focesed = is_point_in_rect(pos, m_rect_one_layer_icon); | ||||||
|  |     bool is_revert_icon_focused = false; | ||||||
|  | 
 | ||||||
|     if (!m_is_left_down && !m_is_one_layer) { |     if (!m_is_left_down && !m_is_one_layer) { | ||||||
|         m_is_action_icon_focesed = is_point_in_rect(pos, m_rect_tick_action); |         m_is_action_icon_focesed = is_point_in_rect(pos, m_rect_tick_action); | ||||||
|  |         is_revert_icon_focused = !m_ticks.empty() && is_point_in_rect(pos, m_rect_revert_icon); | ||||||
|     } |     } | ||||||
|     else if (m_is_left_down || m_is_right_down) { |     else if (m_is_left_down || m_is_right_down) { | ||||||
|         if (m_selection == ssLower) { |         if (m_selection == ssLower) { | ||||||
|  | @ -2262,6 +2313,13 @@ void DoubleSlider::OnMotion(wxMouseEvent& event) | ||||||
|     Update(); |     Update(); | ||||||
|     event.Skip(); |     event.Skip(); | ||||||
| 
 | 
 | ||||||
|  |     // Set tooltips with information for each icon
 | ||||||
|  |     const wxString tooltip = m_is_one_layer_icon_focesed    ? _(L("One layer mode"))    : | ||||||
|  |                              m_is_action_icon_focesed       ? _(L("Add/Del color change")) : | ||||||
|  |                              is_revert_icon_focused         ? _(L("Discard all color changes")) : | ||||||
|  |                              wxEmptyString; | ||||||
|  |     this->SetToolTip(tooltip); | ||||||
|  | 
 | ||||||
|     if (action) |     if (action) | ||||||
|     { |     { | ||||||
|         wxCommandEvent e(wxEVT_SCROLL_CHANGED); |         wxCommandEvent e(wxEVT_SCROLL_CHANGED); | ||||||
|  | @ -2412,7 +2470,9 @@ void DoubleSlider::OnChar(wxKeyEvent& event) | ||||||
| 
 | 
 | ||||||
| void DoubleSlider::OnRightDown(wxMouseEvent& event) | void DoubleSlider::OnRightDown(wxMouseEvent& event) | ||||||
| { | { | ||||||
|  |     if (HasCapture()) return; | ||||||
|     this->CaptureMouse(); |     this->CaptureMouse(); | ||||||
|  | 
 | ||||||
|     const wxClientDC dc(this); |     const wxClientDC dc(this); | ||||||
|     detect_selected_slider(event.GetLogicalPosition(dc)); |     detect_selected_slider(event.GetLogicalPosition(dc)); | ||||||
|     if (!m_selection) |     if (!m_selection) | ||||||
|  |  | ||||||
|  | @ -742,6 +742,7 @@ protected: | ||||||
|     void    draw_ticks(wxDC& dc); |     void    draw_ticks(wxDC& dc); | ||||||
|     void    draw_colored_band(wxDC& dc); |     void    draw_colored_band(wxDC& dc); | ||||||
|     void    draw_one_layer_icon(wxDC& dc); |     void    draw_one_layer_icon(wxDC& dc); | ||||||
|  |     void    draw_revert_icon(wxDC& dc); | ||||||
|     void    draw_thumb_item(wxDC& dc, const wxPoint& pos, const SelectedSlider& selection); |     void    draw_thumb_item(wxDC& dc, const wxPoint& pos, const SelectedSlider& selection); | ||||||
|     void    draw_info_line_with_icon(wxDC& dc, const wxPoint& pos, SelectedSlider selection); |     void    draw_info_line_with_icon(wxDC& dc, const wxPoint& pos, SelectedSlider selection); | ||||||
|     void    draw_thumb_text(wxDC& dc, const wxPoint& pos, const SelectedSlider& selection) const; |     void    draw_thumb_text(wxDC& dc, const wxPoint& pos, const SelectedSlider& selection) const; | ||||||
|  | @ -783,6 +784,7 @@ private: | ||||||
|     ScalableBitmap    m_bmp_one_layer_lock_off; |     ScalableBitmap    m_bmp_one_layer_lock_off; | ||||||
|     ScalableBitmap    m_bmp_one_layer_unlock_on; |     ScalableBitmap    m_bmp_one_layer_unlock_on; | ||||||
|     ScalableBitmap    m_bmp_one_layer_unlock_off; |     ScalableBitmap    m_bmp_one_layer_unlock_off; | ||||||
|  |     ScalableBitmap    m_bmp_revert; | ||||||
|     SelectedSlider  m_selection; |     SelectedSlider  m_selection; | ||||||
|     bool        m_is_left_down = false; |     bool        m_is_left_down = false; | ||||||
|     bool        m_is_right_down = false; |     bool        m_is_right_down = false; | ||||||
|  | @ -796,9 +798,11 @@ private: | ||||||
|     wxRect      m_rect_higher_thumb; |     wxRect      m_rect_higher_thumb; | ||||||
|     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; | ||||||
|     wxSize      m_thumb_size; |     wxSize      m_thumb_size; | ||||||
|     int         m_tick_icon_dim; |     int         m_tick_icon_dim; | ||||||
|     int         m_lock_icon_dim; |     int         m_lock_icon_dim; | ||||||
|  |     int         m_revert_icon_dim; | ||||||
|     long        m_style; |     long        m_style; | ||||||
|     float       m_label_koef = 1.0; |     float       m_label_koef = 1.0; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 YuSanka
						YuSanka