mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 10:11:10 -06:00 
			
		
		
		
	Fixed artifacts on toolbar and gizmobar icons showing up when changing screen or toolbar scale factors
This commit is contained in:
		
							parent
							
								
									bea82a4501
								
							
						
					
					
						commit
						5b2e2fe7b3
					
				
					 5 changed files with 123 additions and 5 deletions
				
			
		|  | @ -838,8 +838,14 @@ void GLGizmosManager::render_background(float left, float top, float right, floa | |||
| 
 | ||||
| void GLGizmosManager::do_render_overlay() const | ||||
| { | ||||
| #if ENABLE_MODIFIED_TOOLBAR_TEXTURES | ||||
|     std::vector<size_t> selectable_idxs = get_selectable_idxs(); | ||||
|     if (selectable_idxs.empty()) | ||||
|         return; | ||||
| #else | ||||
|     if (m_gizmos.empty()) | ||||
|         return; | ||||
| #endif // ENABLE_MODIFIED_TOOLBAR_TEXTURES
 | ||||
| 
 | ||||
|     float cnv_w = (float)m_parent.get_canvas_size().get_width(); | ||||
|     float cnv_h = (float)m_parent.get_canvas_size().get_height(); | ||||
|  | @ -870,13 +876,34 @@ void GLGizmosManager::do_render_overlay() const | |||
|     unsigned int icons_texture_id = m_icons_texture.get_id(); | ||||
|     int tex_width = m_icons_texture.get_width(); | ||||
|     int tex_height = m_icons_texture.get_height(); | ||||
|     float inv_tex_width = (tex_width != 0) ? 1.0f / tex_width : 0.0f; | ||||
|     float inv_tex_height = (tex_height != 0) ? 1.0f / tex_height : 0.0f; | ||||
| 
 | ||||
| #if ENABLE_MODIFIED_TOOLBAR_TEXTURES | ||||
|     if ((icons_texture_id == 0) || (tex_width <= 1) || (tex_height <= 1)) | ||||
|         return; | ||||
| 
 | ||||
| #if ENABLE_GIZMO_ICONS_NON_ACTIVABLE_STATE | ||||
|     float du = (float)(tex_width - 1) / (4.0f * (float)tex_width); // 4 is the number of possible states if the icons
 | ||||
| #else | ||||
|     float du = (float)(tex_width - 1) / (3.0f * (float)tex_width); // 3 is the number of possible states if the icons
 | ||||
| #endif // ENABLE_GIZMO_ICONS_NON_ACTIVABLE_STATE
 | ||||
|     float dv = (float)(tex_height - 1) / (float)(selectable_idxs.size() * tex_height); | ||||
| 
 | ||||
|     // tiles in the texture are spaced by 1 pixel
 | ||||
|     float u_offset = 1.0f / (float)tex_width; | ||||
|     float v_offset = 1.0f / (float)tex_height; | ||||
| #else | ||||
|     if ((icons_texture_id == 0) || (tex_width <= 0) || (tex_height <= 0)) | ||||
|         return; | ||||
| 
 | ||||
|     float inv_tex_width = (tex_width != 0) ? 1.0f / tex_width : 0.0f; | ||||
|     float inv_tex_height = (tex_height != 0) ? 1.0f / tex_height : 0.0f; | ||||
| #endif // ENABLE_MODIFIED_TOOLBAR_TEXTURES
 | ||||
| 
 | ||||
| #if ENABLE_MODIFIED_TOOLBAR_TEXTURES | ||||
|     for (size_t idx : selectable_idxs) | ||||
| #else | ||||
|     for (size_t idx : get_selectable_idxs()) | ||||
| #endif // ENABLE_MODIFIED_TOOLBAR_TEXTURES
 | ||||
|     { | ||||
|         GLGizmoBase* gizmo = m_gizmos[idx].get(); | ||||
| 
 | ||||
|  | @ -887,6 +914,12 @@ void GLGizmosManager::do_render_overlay() const | |||
|         int icon_idx = m_current == idx ? 2 : (m_hover == idx ? 1 : 0); | ||||
| #endif // ENABLE_GIZMO_ICONS_NON_ACTIVABLE_STATE
 | ||||
| 
 | ||||
| #if ENABLE_MODIFIED_TOOLBAR_TEXTURES | ||||
|         float v_top = v_offset + sprite_id * dv; | ||||
|         float u_left = u_offset + icon_idx * du; | ||||
|         float v_bottom = v_top + dv - v_offset; | ||||
|         float u_right = u_left + du - u_offset; | ||||
| #else | ||||
|         float u_icon_size = icons_size * inv_tex_width; | ||||
|         float v_icon_size = icons_size * inv_tex_height; | ||||
| 
 | ||||
|  | @ -894,6 +927,7 @@ void GLGizmosManager::do_render_overlay() const | |||
|         float u_left = icon_idx * u_icon_size; | ||||
|         float v_bottom = v_top + v_icon_size; | ||||
|         float u_right = u_left + u_icon_size; | ||||
| #endif // ENABLE_MODIFIED_TOOLBAR_TEXTURES
 | ||||
| 
 | ||||
|         GLTexture::render_sub_texture(icons_texture_id, zoomed_top_x, zoomed_top_x + zoomed_icons_size, zoomed_top_y - zoomed_icons_size, zoomed_top_y, { { u_left, v_bottom }, { u_right, v_bottom }, { u_right, v_top }, { u_left, v_top } }); | ||||
|         if (idx == m_current) { | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Enrico Turri
						Enrico Turri