mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 10:11:10 -06:00 
			
		
		
		
	Fixed the layout of the painting gizmos after the edit icon for sliders was added.
This commit is contained in:
		
							parent
							
								
									9cac904f97
								
							
						
					
					
						commit
						8a4323c5b9
					
				
					 5 changed files with 53 additions and 23 deletions
				
			
		|  | @ -133,8 +133,13 @@ void GLGizmoFdmSupports::on_render_input_window(float x, float y, float bottom_l | |||
|     total_text_max += caption_max + m_imgui->scaled(1.f); | ||||
|     caption_max    += m_imgui->scaled(1.f); | ||||
| 
 | ||||
|     float sliders_left_width = std::max(std::max(autoset_slider_left, smart_fill_slider_left), std::max(cursor_slider_left, clipping_slider_left)); | ||||
|     float window_width       = minimal_slider_width + sliders_left_width; | ||||
|     const float sliders_left_width = std::max(std::max(autoset_slider_left, smart_fill_slider_left), std::max(cursor_slider_left, clipping_slider_left)); | ||||
| #if ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT | ||||
|     const float slider_icon_width  = m_imgui->get_slider_icon_size().x; | ||||
|     float       window_width       = minimal_slider_width + sliders_left_width + slider_icon_width; | ||||
| #else | ||||
|     float       window_width       = minimal_slider_width + sliders_left_width; | ||||
| #endif // ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT
 | ||||
|     window_width = std::max(window_width, total_text_max); | ||||
|     window_width = std::max(window_width, button_width); | ||||
|     window_width = std::max(window_width, split_triangles_checkbox_width); | ||||
|  | @ -163,18 +168,19 @@ void GLGizmoFdmSupports::on_render_input_window(float x, float y, float bottom_l | |||
|         "Degree sign to use in the respective slider in FDM supports gizmo," | ||||
|         "placed after the number with no whitespace in between."); | ||||
|     ImGui::SameLine(sliders_left_width); | ||||
|     ImGui::PushItemWidth(window_width - sliders_left_width); | ||||
| 
 | ||||
|     float slider_height = m_imgui->get_slider_float_height(); | ||||
|     // Makes slider to be aligned to bottom of the multi-line text.
 | ||||
|     float slider_start_position = std::max(position_before_text_y, position_after_text_y - slider_height); | ||||
|     ImGui::SetCursorPosY(slider_start_position); | ||||
|     float slider_start_position_y = std::max(position_before_text_y, position_after_text_y - slider_height); | ||||
|     ImGui::SetCursorPosY(slider_start_position_y); | ||||
| 
 | ||||
| #if ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT | ||||
|     ImGui::PushItemWidth(window_width - sliders_left_width - slider_icon_width); | ||||
|     wxString tooltip = format_wxstr(_L("Preselects faces by overhang angle. It is possible to restrict paintable facets to only preselected faces when " | ||||
|             "the option \"%1%\" is enabled."), m_desc["on_overhangs_only"]); | ||||
|     if (m_imgui->slider_float("##angle_threshold_deg", &m_highlight_by_angle_threshold_deg, 0.f, 90.f, format_str.data(), 1.0f, true, tooltip)) { | ||||
| #else | ||||
|     ImGui::PushItemWidth(window_width - sliders_left_width); | ||||
|     if (m_imgui->slider_float("##angle_threshold_deg", &m_highlight_by_angle_threshold_deg, 0.f, 90.f, format_str.data())) { | ||||
| #endif // ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT
 | ||||
|         m_parent.set_slope_normal_angle(90.f - m_highlight_by_angle_threshold_deg); | ||||
|  | @ -274,10 +280,11 @@ void GLGizmoFdmSupports::on_render_input_window(float x, float y, float bottom_l | |||
|         ImGui::AlignTextToFramePadding(); | ||||
|         m_imgui->text(m_desc.at("cursor_size")); | ||||
|         ImGui::SameLine(sliders_left_width); | ||||
|         ImGui::PushItemWidth(window_width - sliders_left_width); | ||||
| #if ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT | ||||
|         ImGui::PushItemWidth(window_width - sliders_left_width - slider_icon_width); | ||||
|         m_imgui->slider_float("##cursor_radius", &m_cursor_radius, CursorRadiusMin, CursorRadiusMax, "%.2f", 1.0f, true, _L("Alt + Mouse wheel")); | ||||
| #else | ||||
|         ImGui::PushItemWidth(window_width - sliders_left_width); | ||||
|         m_imgui->slider_float("##cursor_radius", &m_cursor_radius, CursorRadiusMin, CursorRadiusMax, "%.2f"); | ||||
|         if (ImGui::IsItemHovered()) | ||||
|             m_imgui->tooltip(_L("Alt + Mouse wheel"), max_tooltip_width); | ||||
|  | @ -295,10 +302,11 @@ void GLGizmoFdmSupports::on_render_input_window(float x, float y, float bottom_l | |||
|         m_imgui->text(m_desc["smart_fill_angle"] + ":"); | ||||
| 
 | ||||
|         ImGui::SameLine(sliders_left_width); | ||||
|         ImGui::PushItemWidth(window_width - sliders_left_width); | ||||
| #if ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT | ||||
|         ImGui::PushItemWidth(window_width - sliders_left_width - slider_icon_width); | ||||
|         if (m_imgui->slider_float("##smart_fill_angle", &m_smart_fill_angle, SmartFillAngleMin, SmartFillAngleMax, format_str.data(), 1.0f, true, _L("Alt + Mouse wheel"))) | ||||
| #else | ||||
|         ImGui::PushItemWidth(window_width - sliders_left_width); | ||||
|         if (m_imgui->slider_float("##smart_fill_angle", &m_smart_fill_angle, SmartFillAngleMin, SmartFillAngleMax, format_str.data())) | ||||
| #endif // ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT
 | ||||
|             for (auto &triangle_selector : m_triangle_selectors) { | ||||
|  | @ -325,13 +333,14 @@ void GLGizmoFdmSupports::on_render_input_window(float x, float y, float bottom_l | |||
|         } | ||||
|     } | ||||
| 
 | ||||
|     ImGui::SameLine(sliders_left_width); | ||||
|     ImGui::PushItemWidth(window_width - sliders_left_width); | ||||
|     auto clp_dist = float(m_c->object_clipper()->get_position()); | ||||
|     ImGui::SameLine(sliders_left_width); | ||||
| #if ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT | ||||
|     ImGui::PushItemWidth(window_width - sliders_left_width - slider_icon_width); | ||||
|     if (m_imgui->slider_float("##clp_dist", &clp_dist, 0.f, 1.f, "%.2f", 1.0f, true, _L("Ctrl + Mouse wheel"))) | ||||
|         m_c->object_clipper()->set_position(clp_dist, true); | ||||
| #else | ||||
|     ImGui::PushItemWidth(window_width - sliders_left_width); | ||||
|     if (m_imgui->slider_float("##clp_dist", &clp_dist, 0.f, 1.f, "%.2f")) | ||||
|         m_c->object_clipper()->set_position(clp_dist, true); | ||||
| 
 | ||||
|  |  | |||
|  | @ -311,8 +311,13 @@ void GLGizmoMmuSegmentation::on_render_input_window(float x, float y, float bott | |||
|     total_text_max += caption_max + m_imgui->scaled(1.f); | ||||
|     caption_max    += m_imgui->scaled(1.f); | ||||
| 
 | ||||
|     float sliders_width = std::max(smart_fill_slider_left, std::max(cursor_slider_left, clipping_slider_left)); | ||||
|     float window_width = minimal_slider_width + sliders_width; | ||||
|     const float sliders_left_width = std::max(smart_fill_slider_left, std::max(cursor_slider_left, clipping_slider_left)); | ||||
| #if ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT | ||||
|     const float slider_icon_width  = m_imgui->get_slider_icon_size().x; | ||||
|     float       window_width       = minimal_slider_width + sliders_left_width + slider_icon_width; | ||||
| #else | ||||
|     float       window_width       = minimal_slider_width + sliders_left_width; | ||||
| #endif // ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT
 | ||||
|     window_width       = std::max(window_width, total_text_max); | ||||
|     window_width       = std::max(window_width, button_width); | ||||
|     window_width       = std::max(window_width, split_triangles_checkbox_width); | ||||
|  | @ -439,11 +444,12 @@ void GLGizmoMmuSegmentation::on_render_input_window(float x, float y, float bott | |||
| 
 | ||||
|         ImGui::AlignTextToFramePadding(); | ||||
|         m_imgui->text(m_desc.at("cursor_size")); | ||||
|         ImGui::SameLine(sliders_width); | ||||
|         ImGui::PushItemWidth(window_width - sliders_width); | ||||
|         ImGui::SameLine(sliders_left_width); | ||||
| #if ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT | ||||
|         ImGui::PushItemWidth(window_width - sliders_left_width - slider_icon_width); | ||||
|         m_imgui->slider_float("##cursor_radius", &m_cursor_radius, CursorRadiusMin, CursorRadiusMax, "%.2f", 1.0f, true, _L("Alt + Mouse wheel")); | ||||
| #else | ||||
|         ImGui::PushItemWidth(window_width - sliders_left_width); | ||||
|         m_imgui->slider_float("##cursor_radius", &m_cursor_radius, CursorRadiusMin, CursorRadiusMax, "%.2f"); | ||||
|         if (ImGui::IsItemHovered()) | ||||
|             m_imgui->tooltip(_L("Alt + Mouse wheel"), max_tooltip_width); | ||||
|  | @ -462,11 +468,12 @@ void GLGizmoMmuSegmentation::on_render_input_window(float x, float y, float bott | |||
|         m_imgui->text(m_desc["smart_fill_angle"] + ":"); | ||||
|         std::string format_str = std::string("%.f") + I18N::translate_utf8("°", "Degree sign to use in the respective slider in MMU gizmo," | ||||
|                                                                                 "placed after the number with no whitespace in between."); | ||||
|         ImGui::SameLine(sliders_width); | ||||
|         ImGui::PushItemWidth(window_width - sliders_width); | ||||
|         ImGui::SameLine(sliders_left_width); | ||||
| #if ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT | ||||
|         ImGui::PushItemWidth(window_width - sliders_left_width - slider_icon_width); | ||||
|         if (m_imgui->slider_float("##smart_fill_angle", &m_smart_fill_angle, SmartFillAngleMin, SmartFillAngleMax, format_str.data(), 1.0f, true, _L("Alt + Mouse wheel"))) | ||||
| #else | ||||
|         ImGui::PushItemWidth(window_width - sliders_left_width); | ||||
|         if(m_imgui->slider_float("##smart_fill_angle", &m_smart_fill_angle, SmartFillAngleMin, SmartFillAngleMax, format_str.data())) | ||||
| #endif // ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT
 | ||||
|             for (auto &triangle_selector : m_triangle_selectors) { | ||||
|  | @ -491,13 +498,14 @@ void GLGizmoMmuSegmentation::on_render_input_window(float x, float y, float bott | |||
|         } | ||||
|     } | ||||
| 
 | ||||
|     ImGui::SameLine(sliders_width); | ||||
|     ImGui::PushItemWidth(window_width - sliders_width); | ||||
|     auto clp_dist = float(m_c->object_clipper()->get_position()); | ||||
|     ImGui::SameLine(sliders_left_width); | ||||
| #if ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT | ||||
|     ImGui::PushItemWidth(window_width - sliders_left_width - slider_icon_width); | ||||
|     if (m_imgui->slider_float("##clp_dist", &clp_dist, 0.f, 1.f, "%.2f", 1.0f, true, _L("Ctrl + Mouse wheel"))) | ||||
|         m_c->object_clipper()->set_position(clp_dist, true); | ||||
| #else | ||||
|     ImGui::PushItemWidth(window_width - sliders_left_width); | ||||
|     if (m_imgui->slider_float("##clp_dist", &clp_dist, 0.f, 1.f, "%.2f")) | ||||
|         m_c->object_clipper()->set_position(clp_dist, true); | ||||
| 
 | ||||
|  |  | |||
|  | @ -104,8 +104,13 @@ void GLGizmoSeam::on_render_input_window(float x, float y, float bottom_limit) | |||
|     total_text_max += caption_max + m_imgui->scaled(1.f); | ||||
|     caption_max    += m_imgui->scaled(1.f); | ||||
| 
 | ||||
|     float sliders_width = std::max(cursor_size_slider_left, clipping_slider_left); | ||||
|     float window_width  = minimal_slider_width + sliders_width; | ||||
|     const float sliders_left_width = std::max(cursor_size_slider_left, clipping_slider_left); | ||||
| #if ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT | ||||
|     const float slider_icon_width  = m_imgui->get_slider_icon_size().x; | ||||
|     float       window_width       = minimal_slider_width + sliders_left_width + slider_icon_width; | ||||
| #else | ||||
|     float       window_width       = minimal_slider_width + sliders_left_width; | ||||
| #endif // ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT
 | ||||
|     window_width = std::max(window_width, total_text_max); | ||||
|     window_width = std::max(window_width, button_width); | ||||
|     window_width = std::max(window_width, cursor_type_radio_left + cursor_type_radio_sphere + cursor_type_radio_circle); | ||||
|  | @ -126,11 +131,12 @@ void GLGizmoSeam::on_render_input_window(float x, float y, float bottom_limit) | |||
| 
 | ||||
|     ImGui::AlignTextToFramePadding(); | ||||
|     m_imgui->text(m_desc.at("cursor_size")); | ||||
|     ImGui::SameLine(sliders_width); | ||||
|     ImGui::PushItemWidth(window_width - sliders_width); | ||||
|     ImGui::SameLine(sliders_left_width); | ||||
| #if ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT | ||||
|     ImGui::PushItemWidth(window_width - sliders_left_width - slider_icon_width); | ||||
|     m_imgui->slider_float("##cursor_radius", &m_cursor_radius, CursorRadiusMin, CursorRadiusMax, "%.2f", 1.0f, true, _L("Alt + Mouse wheel")); | ||||
| #else | ||||
|     ImGui::PushItemWidth(window_width - sliders_left_width); | ||||
|     m_imgui->slider_float("##cursor_radius", &m_cursor_radius, CursorRadiusMin, CursorRadiusMax, "%.2f"); | ||||
|     if (ImGui::IsItemHovered()) | ||||
|         m_imgui->tooltip(_L("Alt + Mouse wheel"), max_tooltip_width); | ||||
|  | @ -169,13 +175,14 @@ void GLGizmoSeam::on_render_input_window(float x, float y, float bottom_limit) | |||
|         } | ||||
|     } | ||||
| 
 | ||||
|     ImGui::SameLine(sliders_width); | ||||
|     ImGui::PushItemWidth(window_width - sliders_width); | ||||
|     auto clp_dist = float(m_c->object_clipper()->get_position()); | ||||
|     ImGui::SameLine(sliders_left_width); | ||||
| #if ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT | ||||
|     ImGui::PushItemWidth(window_width - sliders_left_width - slider_icon_width); | ||||
|     if (m_imgui->slider_float("##clp_dist", &clp_dist, 0.f, 1.f, "%.2f", 1.0f, true, _L("Ctrl + Mouse wheel"))) | ||||
|         m_c->object_clipper()->set_position(clp_dist, true); | ||||
| #else | ||||
|     ImGui::PushItemWidth(window_width - sliders_left_width); | ||||
|     if (m_imgui->slider_float("##clp_dist", &clp_dist, 0.f, 1.f, "%.2f")) | ||||
|         m_c->object_clipper()->set_position(clp_dist, true); | ||||
| 
 | ||||
|  |  | |||
|  | @ -483,6 +483,11 @@ void ImGuiWrapper::tooltip(const wxString &label, float wrap_width) | |||
| } | ||||
| 
 | ||||
| #if ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT | ||||
| ImVec2 ImGuiWrapper::get_slider_icon_size() const | ||||
| { | ||||
|     return this->calc_button_size(std::wstring(&ImGui::SliderFloatEditBtnIcon, 1)); | ||||
| } | ||||
| 
 | ||||
| bool ImGuiWrapper::slider_float(const char* label, float* v, float v_min, float v_max, const char* format/* = "%.3f"*/, float power/* = 1.0f*/, bool clamp /*= true*/, const wxString& tooltip /*= ""*/, bool show_edit_btn /*= true*/) | ||||
| { | ||||
|     const float max_tooltip_width = ImGui::GetFontSize() * 20.0f; | ||||
|  |  | |||
|  | @ -96,6 +96,7 @@ public: | |||
| 
 | ||||
|     // Float sliders: Manually inserted values aren't clamped by ImGui.Using this wrapper function does (when clamp==true).
 | ||||
| #if ENABLE_ENHANCED_IMGUI_SLIDER_FLOAT | ||||
|     ImVec2 get_slider_icon_size() const; | ||||
|     bool slider_float(const char* label, float* v, float v_min, float v_max, const char* format = "%.3f", float power = 1.0f, bool clamp = true, const wxString& tooltip = "", bool show_edit_btn = true); | ||||
|     bool slider_float(const std::string& label, float* v, float v_min, float v_max, const char* format = "%.3f", float power = 1.0f, bool clamp = true, const wxString& tooltip = "", bool show_edit_btn = true); | ||||
|     bool slider_float(const wxString& label, float* v, float v_min, float v_max, const char* format = "%.3f", float power = 1.0f, bool clamp = true, const wxString& tooltip = "", bool show_edit_btn = true); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lukáš Hejl
						Lukáš Hejl