mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 10:11:10 -06:00 
			
		
		
		
	Some rework on layout of imgui dialogs
This commit is contained in:
		
							parent
							
								
									e747577271
								
							
						
					
					
						commit
						57d069bd0a
					
				
					 13 changed files with 50 additions and 96 deletions
				
			
		|  | @ -140,17 +140,22 @@ void GLGizmoCut::on_render_input_window(float x, float y, float bottom_limit) | |||
|     y = std::min(y, bottom_limit - approx_height); | ||||
|     m_imgui->set_next_window_pos(x, y, ImGuiCond_Always); | ||||
| 
 | ||||
|     m_imgui->set_next_window_bg_alpha(0.5f); | ||||
|     m_imgui->begin(_(L("Cut")), ImGuiWindowFlags_AlwaysAutoResize | ImGuiWindowFlags_NoMove | ImGuiWindowFlags_NoResize | ImGuiWindowFlags_NoCollapse); | ||||
| 
 | ||||
|     m_imgui->begin(_(L("Cut")), ImGuiWindowFlags_NoMove | ImGuiWindowFlags_NoResize | ImGuiWindowFlags_NoCollapse); | ||||
|     ImGui::AlignTextToFramePadding(); | ||||
|     m_imgui->text("Z"); | ||||
|     ImGui::SameLine(); | ||||
|     ImGui::PushItemWidth(m_imgui->get_style_scaling() * 150.0f); | ||||
|     ImGui::InputDouble("", &m_cut_z, 0.0f, 0.0f, "%.2f"); | ||||
| 
 | ||||
|     ImGui::PushItemWidth(m_imgui->scaled(5.0f)); | ||||
|     ImGui::InputDouble("Z", &m_cut_z, 0.0f, 0.0f, "%.2f"); | ||||
|     ImGui::Separator(); | ||||
| 
 | ||||
|     m_imgui->checkbox(_(L("Keep upper part")), m_keep_upper); | ||||
|     m_imgui->checkbox(_(L("Keep lower part")), m_keep_lower); | ||||
|     m_imgui->checkbox(_(L("Rotate lower part upwards")), m_rotate_lower); | ||||
| 
 | ||||
|     ImGui::Separator(); | ||||
| 
 | ||||
|     m_imgui->disabled_begin(!m_keep_upper && !m_keep_lower); | ||||
|     const bool cut_clicked = m_imgui->button(_(L("Perform cut"))); | ||||
|     m_imgui->disabled_end(); | ||||
|  |  | |||
|  | @ -173,25 +173,6 @@ void GLGizmoMove3D::on_render_for_picking() const | |||
|     render_grabber_extension(Z, box, true); | ||||
| } | ||||
| 
 | ||||
| #if !DISABLE_MOVE_ROTATE_SCALE_GIZMOS_IMGUI | ||||
| void GLGizmoMove3D::on_render_input_window(float x, float y, float bottom_limit) | ||||
| { | ||||
|     const Selection& selection = m_parent.get_selection(); | ||||
|     bool show_position = selection.is_single_full_instance(); | ||||
|     const Vec3d& position = selection.get_bounding_box().center(); | ||||
| 
 | ||||
|     Vec3d displacement = show_position ? position : m_displacement; | ||||
|     wxString label = show_position ? _(L("Position (mm)")) : _(L("Displacement (mm)")); | ||||
| 
 | ||||
|     m_imgui->set_next_window_pos(x, y, ImGuiCond_Always); | ||||
|     m_imgui->set_next_window_bg_alpha(0.5f); | ||||
|     m_imgui->begin(label, ImGuiWindowFlags_NoMove | ImGuiWindowFlags_NoResize | ImGuiWindowFlags_NoCollapse); | ||||
|     m_imgui->input_vec3("", displacement, 100.0f, "%.2f"); | ||||
| 
 | ||||
|     m_imgui->end(); | ||||
| } | ||||
| #endif // !DISABLE_MOVE_ROTATE_SCALE_GIZMOS_IMGUI
 | ||||
| 
 | ||||
| double GLGizmoMove3D::calc_projection(const UpdateData& data) const | ||||
| { | ||||
|     double projection = 0.0; | ||||
|  |  | |||
|  | @ -41,9 +41,6 @@ protected: | |||
|     virtual void on_update(const UpdateData& data); | ||||
|     virtual void on_render() const; | ||||
|     virtual void on_render_for_picking() const; | ||||
| #if !DISABLE_MOVE_ROTATE_SCALE_GIZMOS_IMGUI | ||||
|     virtual void on_render_input_window(float x, float y, float bottom_limit); | ||||
| #endif // !DISABLE_MOVE_ROTATE_SCALE_GIZMOS_IMGUI
 | ||||
| 
 | ||||
| private: | ||||
|     double calc_projection(const UpdateData& data) const; | ||||
|  |  | |||
|  | @ -482,21 +482,5 @@ void GLGizmoRotate3D::on_render() const | |||
|         m_gizmos[Z].render(); | ||||
| } | ||||
| 
 | ||||
| #if !DISABLE_MOVE_ROTATE_SCALE_GIZMOS_IMGUI | ||||
| void GLGizmoRotate3D::on_render_input_window(float x, float y, float bottom_limit) | ||||
| { | ||||
|     Vec3d rotation(Geometry::rad2deg(m_gizmos[0].get_angle()), Geometry::rad2deg(m_gizmos[1].get_angle()), Geometry::rad2deg(m_gizmos[2].get_angle())); | ||||
|     wxString label = _(L("Rotation (deg)")); | ||||
| 
 | ||||
|     m_imgui->set_next_window_pos(x, y, ImGuiCond_Always); | ||||
|     m_imgui->set_next_window_bg_alpha(0.5f); | ||||
|     m_imgui->begin(label, ImGuiWindowFlags_NoMove | ImGuiWindowFlags_NoResize | ImGuiWindowFlags_NoCollapse); | ||||
|     m_imgui->input_vec3("", rotation, 100.0f, "%.2f"); | ||||
|     m_imgui->end(); | ||||
| } | ||||
| #endif // !DISABLE_MOVE_ROTATE_SCALE_GIZMOS_IMGUI
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| } // namespace GUI
 | ||||
| } // namespace Slic3r
 | ||||
|  |  | |||
|  | @ -124,13 +124,8 @@ protected: | |||
|             g.render_for_picking(); | ||||
|         } | ||||
|     } | ||||
| #if !DISABLE_MOVE_ROTATE_SCALE_GIZMOS_IMGUI | ||||
|     virtual void on_render_input_window(float x, float y, float bottom_limit); | ||||
| #endif // !DISABLE_MOVE_ROTATE_SCALE_GIZMOS_IMGUI
 | ||||
| }; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| } // namespace GUI
 | ||||
| } // namespace Slic3r
 | ||||
| 
 | ||||
|  |  | |||
|  | @ -289,21 +289,6 @@ void GLGizmoScale3D::on_render_for_picking() const | |||
|     render_grabbers_for_picking(m_parent.get_selection().get_bounding_box()); | ||||
| } | ||||
| 
 | ||||
| #if !DISABLE_MOVE_ROTATE_SCALE_GIZMOS_IMGUI | ||||
| void GLGizmoScale3D::on_render_input_window(float x, float y, float bottom_limit) | ||||
| { | ||||
|     const Selection& selection = m_parent.get_selection(); | ||||
|     bool single_instance = selection.is_single_full_instance(); | ||||
|     wxString label = _(L("Scale (%)")); | ||||
| 
 | ||||
|     m_imgui->set_next_window_pos(x, y, ImGuiCond_Always); | ||||
|     m_imgui->set_next_window_bg_alpha(0.5f); | ||||
|     m_imgui->begin(label, ImGuiWindowFlags_NoMove | ImGuiWindowFlags_NoResize | ImGuiWindowFlags_NoCollapse); | ||||
|     m_imgui->input_vec3("", m_scale * 100.f, 100.0f, "%.2f"); | ||||
|     m_imgui->end(); | ||||
| } | ||||
| #endif // !DISABLE_MOVE_ROTATE_SCALE_GIZMOS_IMGUI
 | ||||
| 
 | ||||
| void GLGizmoScale3D::render_grabbers_connection(unsigned int id_1, unsigned int id_2) const | ||||
| { | ||||
|     unsigned int grabbers_count = (unsigned int)m_grabbers.size(); | ||||
|  |  | |||
|  | @ -50,9 +50,6 @@ protected: | |||
|     virtual void on_update(const UpdateData& data); | ||||
|     virtual void on_render() const; | ||||
|     virtual void on_render_for_picking() const; | ||||
| #if !DISABLE_MOVE_ROTATE_SCALE_GIZMOS_IMGUI | ||||
|     virtual void on_render_input_window(float x, float y, float bottom_limit); | ||||
| #endif // !DISABLE_MOVE_ROTATE_SCALE_GIZMOS_IMGUI
 | ||||
| 
 | ||||
| private: | ||||
|     void render_grabbers_connection(unsigned int id_1, unsigned int id_2) const; | ||||
|  |  | |||
|  | @ -700,7 +700,6 @@ RENDER_AGAIN: | |||
|     const float approx_height = m_imgui->scaled(18.0f); | ||||
|     y = std::min(y, bottom_limit - approx_height); | ||||
|     m_imgui->set_next_window_pos(x, y, ImGuiCond_Always); | ||||
|     m_imgui->set_next_window_bg_alpha(0.5f); | ||||
|     m_imgui->begin(on_get_name(), ImGuiWindowFlags_NoMove | ImGuiWindowFlags_AlwaysAutoResize | ImGuiWindowFlags_NoCollapse); | ||||
| 
 | ||||
|     // First calculate width of all the texts that are could possibly be shown. We will decide set the dialog width based on that:
 | ||||
|  | @ -725,6 +724,7 @@ RENDER_AGAIN: | |||
|         float diameter_upper_cap = static_cast<ConfigOptionFloat*>(wxGetApp().preset_bundle->sla_prints.get_edited_preset().config.option("support_pillar_diameter"))->value; | ||||
|         if (m_new_point_head_diameter > diameter_upper_cap) | ||||
|             m_new_point_head_diameter = diameter_upper_cap; | ||||
|         ImGui::AlignTextToFramePadding(); | ||||
|         m_imgui->text(m_desc.at("head_diameter")); | ||||
|         ImGui::SameLine(diameter_slider_left); | ||||
|         ImGui::PushItemWidth(window_width - diameter_slider_left); | ||||
|  | @ -785,6 +785,7 @@ RENDER_AGAIN: | |||
|         } | ||||
|     } | ||||
|     else { // not in editing mode:
 | ||||
|         ImGui::AlignTextToFramePadding(); | ||||
|         m_imgui->text(m_desc.at("minimal_distance")); | ||||
|         ImGui::SameLine(settings_sliders_left); | ||||
|         ImGui::PushItemWidth(window_width - settings_sliders_left); | ||||
|  | @ -798,6 +799,7 @@ RENDER_AGAIN: | |||
|         bool slider_edited = ImGui::IsItemEdited(); // someone is dragging the slider
 | ||||
|         bool slider_released = ImGui::IsItemDeactivatedAfterEdit(); // someone has just released the slider
 | ||||
| 
 | ||||
|         ImGui::AlignTextToFramePadding(); | ||||
|         m_imgui->text(m_desc.at("points_density")); | ||||
|         ImGui::SameLine(settings_sliders_left); | ||||
| 
 | ||||
|  | @ -828,7 +830,7 @@ RENDER_AGAIN: | |||
|         if (generate) | ||||
|             auto_generate(); | ||||
| 
 | ||||
|         m_imgui->text(""); | ||||
|         ImGui::Separator(); | ||||
|         if (m_imgui->button(m_desc.at("manual_editing"))) | ||||
|             switch_to_editing_mode(); | ||||
| 
 | ||||
|  | @ -845,9 +847,12 @@ RENDER_AGAIN: | |||
| 
 | ||||
| 
 | ||||
|     // Following is rendered in both editing and non-editing mode:
 | ||||
|     m_imgui->text(""); | ||||
|     ImGui::Separator(); | ||||
|     if (m_clipping_plane_distance == 0.f) | ||||
|     { | ||||
|         ImGui::AlignTextToFramePadding(); | ||||
|         m_imgui->text(m_desc.at("clipping_of_view")); | ||||
|     } | ||||
|     else { | ||||
|         if (m_imgui->button(m_desc.at("reset_direction"))) { | ||||
|             wxGetApp().CallAfter([this](){ | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Enrico Turri
						Enrico Turri