mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 02:01:12 -06:00 
			
		
		
		
	Fixed conflicts after merge with master
This commit is contained in:
		
						commit
						f12b39be25
					
				
					 171 changed files with 23530 additions and 14236 deletions
				
			
		|  | @ -262,12 +262,6 @@ void GLGizmoBase::render_grabbers_for_picking(const BoundingBoxf3& box) const | |||
|     } | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| void GLGizmoBase::set_tooltip(const std::string& tooltip) const | ||||
| { | ||||
|     m_parent.set_tooltip(tooltip); | ||||
| } | ||||
| 
 | ||||
| std::string GLGizmoBase::format(float value, unsigned int decimals) const | ||||
| { | ||||
|     return Slic3r::string_printf("%.*f", decimals, value); | ||||
|  |  | |||
|  | @ -100,6 +100,7 @@ protected: | |||
|     mutable std::vector<Grabber> m_grabbers; | ||||
|     ImGuiWrapper* m_imgui; | ||||
|     bool m_first_input_window_render; | ||||
|     mutable std::string m_tooltip; | ||||
| 
 | ||||
| public: | ||||
|     GLGizmoBase(GLCanvas3D& parent, | ||||
|  | @ -145,10 +146,12 @@ public: | |||
| 
 | ||||
|     void update(const UpdateData& data); | ||||
| 
 | ||||
|     void render() const { on_render(); } | ||||
|     void render() const { m_tooltip.clear(); on_render(); } | ||||
|     void render_for_picking() const { on_render_for_picking(); } | ||||
|     void render_input_window(float x, float y, float bottom_limit); | ||||
| 
 | ||||
|     virtual std::string get_tooltip() const { return ""; } | ||||
| 
 | ||||
| protected: | ||||
|     virtual bool on_init() = 0; | ||||
|     virtual void on_load(cereal::BinaryInputArchive& ar) {} | ||||
|  | @ -174,7 +177,6 @@ protected: | |||
|     void render_grabbers(float size) const; | ||||
|     void render_grabbers_for_picking(const BoundingBoxf3& box) const; | ||||
| 
 | ||||
|     void set_tooltip(const std::string& tooltip) const; | ||||
|     std::string format(float value, unsigned int decimals) const; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -30,6 +30,11 @@ GLGizmoCut::GLGizmoCut(GLCanvas3D& parent, const std::string& icon_filename, uns | |||
|     , m_rotate_lower(false) | ||||
| {} | ||||
| 
 | ||||
| std::string GLGizmoCut::get_tooltip() const | ||||
| { | ||||
|     return (m_hover_id == 0 || m_grabbers[0].dragging) ? "Z: " + format(m_cut_z, 2) : ""; | ||||
| } | ||||
| 
 | ||||
| bool GLGizmoCut::on_init() | ||||
| { | ||||
|     m_grabbers.emplace_back(); | ||||
|  | @ -79,10 +84,6 @@ void GLGizmoCut::on_update(const UpdateData& data) | |||
| 
 | ||||
| void GLGizmoCut::on_render() const | ||||
| { | ||||
|     if (m_grabbers[0].dragging) { | ||||
|         set_tooltip("Z: " + format(m_cut_z, 2)); | ||||
|     } | ||||
| 
 | ||||
|     const Selection& selection = m_parent.get_selection(); | ||||
| 
 | ||||
|     update_max_z(selection); | ||||
|  |  | |||
|  | @ -28,6 +28,8 @@ public: | |||
|     double get_cut_z() const { return m_cut_z; } | ||||
|     void set_cut_z(double cut_z) const; | ||||
| 
 | ||||
|     std::string get_tooltip() const override; | ||||
| 
 | ||||
| protected: | ||||
|     virtual bool on_init(); | ||||
|     virtual void on_load(cereal::BinaryInputArchive& ar) { ar(m_cut_z, m_keep_upper, m_keep_lower, m_rotate_lower); } | ||||
|  |  | |||
|  | @ -1,5 +1,6 @@ | |||
| #include "GLGizmoHollow.hpp" | ||||
| #include "slic3r/GUI/GLCanvas3D.hpp" | ||||
| #include "slic3r/GUI/Camera.hpp" | ||||
| #include "slic3r/GUI/Gizmos/GLGizmos.hpp" | ||||
| 
 | ||||
| #include <GL/glew.h> | ||||
|  | @ -102,16 +103,11 @@ void GLGizmoHollow::on_render() const | |||
|         return; | ||||
|     } | ||||
| 
 | ||||
|     // !!! is it necessary?
 | ||||
|     //const_cast<GLGizmoHollow*>(this)->m_c->update_from_backend(m_parent, m_c->m_model_object);
 | ||||
| 
 | ||||
|     glsafe(::glEnable(GL_BLEND)); | ||||
|     glsafe(::glEnable(GL_DEPTH_TEST)); | ||||
| 
 | ||||
|     m_z_shift = selection.get_volume(*selection.get_volume_idxs().begin())->get_sla_shift_z(); | ||||
| 
 | ||||
|     render_hollowed_mesh(); | ||||
| 
 | ||||
|     if (m_quadric != nullptr && selection.is_from_single_instance()) | ||||
|         render_points(selection, false); | ||||
| 
 | ||||
|  | @ -123,28 +119,6 @@ void GLGizmoHollow::on_render() const | |||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| void GLGizmoHollow::render_hollowed_mesh() const | ||||
| { | ||||
|     /*if (m_c->m_volume_with_cavity) {
 | ||||
|         m_c->m_volume_with_cavity->set_sla_shift_z(m_z_shift); | ||||
|         m_parent.get_shader().start_using(); | ||||
| 
 | ||||
|         GLint current_program_id; | ||||
|         glsafe(::glGetIntegerv(GL_CURRENT_PROGRAM, ¤t_program_id)); | ||||
|         GLint color_id = (current_program_id > 0) ? ::glGetUniformLocation(current_program_id, "uniform_color") : -1; | ||||
|         GLint print_box_detection_id = (current_program_id > 0) ? ::glGetUniformLocation(current_program_id, "print_box.volume_detection") : -1; | ||||
|         GLint print_box_worldmatrix_id = (current_program_id > 0) ? ::glGetUniformLocation(current_program_id, "print_box.volume_world_matrix") : -1; | ||||
|         glcheck(); | ||||
|         m_c->m_volume_with_cavity->set_render_color(); | ||||
|         const Geometry::Transformation& volume_trafo = m_c->m_model_object->volumes.front()->get_transformation(); | ||||
|         m_c->m_volume_with_cavity->set_volume_transformation(volume_trafo); | ||||
|         m_c->m_volume_with_cavity->set_instance_transformation(m_c->m_model_object->instances[size_t(m_c->m_active_instance)]->get_transformation()); | ||||
|         m_c->m_volume_with_cavity->render(color_id, print_box_detection_id, print_box_worldmatrix_id); | ||||
|         m_parent.get_shader().stop_using(); | ||||
|     }*/ | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| void GLGizmoHollow::render_clipping_plane(const Selection& selection) const | ||||
| { | ||||
|     if (m_c->m_clipping_plane_distance == 0.f) | ||||
|  | @ -172,11 +146,6 @@ void GLGizmoHollow::render_clipping_plane(const Selection& selection) const | |||
|     m_c->m_object_clipper->set_plane(*m_c->m_clipping_plane); | ||||
|     m_c->m_object_clipper->set_transformation(trafo); | ||||
| 
 | ||||
| 
 | ||||
|     // Next, ask the backend if supports are already calculated. If so, we are gonna cut them too.
 | ||||
|     //if (m_c->m_print_object_idx < 0)
 | ||||
|     //    m_c->update_from_backend(m_parent, m_c->m_model_object);
 | ||||
| 
 | ||||
|     if (m_c->m_print_object_idx >= 0) { | ||||
|         const SLAPrintObject* print_object = m_parent.sla_print()->objects()[m_c->m_print_object_idx]; | ||||
| 
 | ||||
|  | @ -232,7 +201,6 @@ void GLGizmoHollow::on_render_for_picking() const | |||
| 
 | ||||
|     glsafe(::glEnable(GL_DEPTH_TEST)); | ||||
|     render_points(selection, true); | ||||
|     render_hollowed_mesh(); | ||||
| } | ||||
| 
 | ||||
| void GLGizmoHollow::render_points(const Selection& selection, bool picking) const | ||||
|  | @ -346,10 +314,6 @@ bool GLGizmoHollow::unproject_on_mesh(const Vec2d& mouse_pos, std::pair<Vec3f, V | |||
|     if (! m_c->m_mesh_raycaster) | ||||
|         return false; | ||||
| 
 | ||||
|     // if the gizmo doesn't have the V, F structures for igl, calculate them first:
 | ||||
|     // !!! is it really necessary?
 | ||||
|     //m_c->update_from_backend(m_parent, m_c->m_model_object);
 | ||||
| 
 | ||||
| #if ENABLE_NON_STATIC_CANVAS_MANAGER | ||||
|     const Camera& camera = wxGetApp().plater()->get_camera(); | ||||
| #else | ||||
|  | @ -572,87 +536,15 @@ void GLGizmoHollow::on_update(const UpdateData& data) | |||
|     } | ||||
| } | ||||
| 
 | ||||
| std::pair<const TriangleMesh *, sla::HollowingConfig> GLGizmoHollow::get_hollowing_parameters() const | ||||
| { | ||||
|     // FIXME this function is probably obsolete, caller could
 | ||||
|     // get the data from model config himself
 | ||||
|     auto opts = get_config_options({"hollowing_min_thickness", "hollowing_quality", "hollowing_closing_distance"}); | ||||
|     double offset = static_cast<const ConfigOptionFloat*>(opts[0].first)->value; | ||||
|     double quality = static_cast<const ConfigOptionFloat*>(opts[1].first)->value; | ||||
|     double closing_d = static_cast<const ConfigOptionFloat*>(opts[2].first)->value; | ||||
|     return std::make_pair(m_c->m_mesh, sla::HollowingConfig{offset, quality, closing_d}); | ||||
| } | ||||
| 
 | ||||
| void GLGizmoHollow::update_mesh_raycaster(std::unique_ptr<MeshRaycaster> &&rc) | ||||
| { | ||||
|     m_c->m_mesh_raycaster = std::move(rc); | ||||
|     m_c->m_object_clipper.reset(); | ||||
|     //m_c->m_volume_with_cavity.reset();
 | ||||
| } | ||||
| 
 | ||||
| void GLGizmoHollow::hollow_mesh(bool postpone_error_messages) | ||||
| { | ||||
|     // Trigger a UI job to hollow the mesh.
 | ||||
|    // wxGetApp().plater()->hollow();
 | ||||
| 
 | ||||
|     wxGetApp().CallAfter([this, postpone_error_messages]() { | ||||
|         wxGetApp().plater()->reslice_SLA_hollowing(*m_c->m_model_object, postpone_error_messages); | ||||
|     }); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| void GLGizmoHollow::update_hollowed_mesh(std::unique_ptr<TriangleMesh> &&mesh) | ||||
| { | ||||
|     // Called from Plater when the UI job finishes
 | ||||
|     /*m_c->m_cavity_mesh = std::move(mesh);
 | ||||
| 
 | ||||
|     if(m_c->m_cavity_mesh) { | ||||
|         // First subtract the holes:
 | ||||
|         if (! m_c->m_model_object->sla_drain_holes.empty()) { | ||||
|             TriangleMesh holes_mesh; | ||||
|             for (const sla::DrainHole& hole : m_c->m_model_object->sla_drain_holes) { | ||||
|                 TriangleMesh hole_mesh = make_cylinder(hole.radius, hole.height, 2*M_PI/32); | ||||
| 
 | ||||
|                 Vec3d scaling = m_c->m_model_object->instances[m_c->m_active_instance]->get_scaling_factor(); | ||||
|                 Vec3d normal_transformed = Vec3d(hole.normal(0)/scaling(0), hole.normal(1)/scaling(1), hole.normal(2)/scaling(2)); | ||||
|                 normal_transformed.normalize(); | ||||
| 
 | ||||
|                 // Rotate the cylinder appropriately
 | ||||
|                 Eigen::Quaterniond q; | ||||
|                 Transform3d m = Transform3d::Identity(); | ||||
|                 m.matrix().block(0, 0, 3, 3) = q.setFromTwoVectors(Vec3d::UnitZ(), normal_transformed).toRotationMatrix(); | ||||
|                 hole_mesh.transform(m); | ||||
| 
 | ||||
|                 // If the instance is scaled, undo the scaling of the hole
 | ||||
|                 hole_mesh.scale(Vec3d(1/scaling(0), 1/scaling(1), 1/scaling(2))); | ||||
| 
 | ||||
|                 // Translate the hole into position and merge with the others
 | ||||
|                 hole_mesh.translate(hole.pos); | ||||
|                 holes_mesh.merge(hole_mesh); | ||||
|                 holes_mesh.repair(); | ||||
|             } | ||||
|             MeshBoolean::minus(*m_c->m_cavity_mesh.get(), holes_mesh); | ||||
|         } | ||||
| 
 | ||||
|         // create a new GLVolume that only has the cavity inside
 | ||||
|         m_c->m_volume_with_cavity.reset(new GLVolume(GLVolume::MODEL_COLOR[2])); | ||||
|         m_c->m_volume_with_cavity->indexed_vertex_array.load_mesh(*m_c->m_cavity_mesh.get()); | ||||
|         m_c->m_volume_with_cavity->finalize_geometry(true); | ||||
|         m_c->m_volume_with_cavity->force_transparent = false; | ||||
| 
 | ||||
|         m_parent.toggle_model_objects_visibility(false, m_c->m_model_object, m_c->m_active_instance); | ||||
|         m_parent.toggle_sla_auxiliaries_visibility(true, m_c->m_model_object, m_c->m_active_instance); | ||||
| 
 | ||||
|         // Reset raycaster so it works with the new mesh:
 | ||||
|         m_c->m_mesh_raycaster.reset(new MeshRaycaster(*m_c->mesh())); | ||||
|     } | ||||
| 
 | ||||
|     if (m_c->m_clipping_plane_distance == 0.f) { | ||||
|         m_c->m_clipping_plane_distance = 0.5f; | ||||
|         update_clipping_plane(); | ||||
|     }*/ | ||||
| } | ||||
| 
 | ||||
| std::vector<std::pair<const ConfigOption*, const ConfigOptionDef*>> GLGizmoHollow::get_config_options(const std::vector<std::string>& keys) const | ||||
| { | ||||
|     std::vector<std::pair<const ConfigOption*, const ConfigOptionDef*>> out; | ||||
|  | @ -840,7 +732,6 @@ RENDER_AGAIN: | |||
|     bool remove_selected = false; | ||||
|     bool remove_all = false; | ||||
| 
 | ||||
|    // m_imgui->text(" "); // vertical gap
 | ||||
|     ImGui::Separator(); | ||||
| 
 | ||||
|     float diameter_upper_cap = 15.; | ||||
|  | @ -1024,10 +915,6 @@ void GLGizmoHollow::on_set_state() | |||
|             m_parent.toggle_model_objects_visibility(true, m_c->m_model_object, m_c->m_active_instance); | ||||
|             m_parent.toggle_sla_auxiliaries_visibility(m_show_supports, m_c->m_model_object, m_c->m_active_instance); | ||||
|         } | ||||
| 
 | ||||
|         // Set default head diameter from config.
 | ||||
|         //const DynamicPrintConfig& cfg = wxGetApp().preset_bundle->sla_prints.get_edited_preset().config;
 | ||||
|         //m_new_hole_radius = static_cast<const ConfigOptionFloat*>(cfg.option("support_head_front_diameter"))->value;
 | ||||
|     } | ||||
|     if (m_state == Off && m_old_state != Off) { // the gizmo was just turned Off
 | ||||
|         //Plater::TakeSnapshot snapshot(wxGetApp().plater(), _(L("SLA gizmo turned off")));
 | ||||
|  |  | |||
|  | @ -36,11 +36,6 @@ public: | |||
|     void delete_selected_points(); | ||||
|     ClippingPlane get_sla_clipping_plane() const; | ||||
|      | ||||
|      | ||||
|     std::pair<const TriangleMesh *, sla::HollowingConfig> get_hollowing_parameters() const; | ||||
|     void update_mesh_raycaster(std::unique_ptr<MeshRaycaster> &&rc); | ||||
|     void update_hollowed_mesh(std::unique_ptr<TriangleMesh> &&mesh); | ||||
| 
 | ||||
|     bool is_selection_rectangle_dragging() const { return m_selection_rectangle.is_dragging(); } | ||||
|     void update_clipping_plane(bool keep_normal = false) const; | ||||
|     void set_common_data_ptr(CommonGizmosData* ptr) { m_c = ptr; } | ||||
|  | @ -53,7 +48,6 @@ private: | |||
| 
 | ||||
|     void render_points(const Selection& selection, bool picking = false) const; | ||||
|     void render_clipping_plane(const Selection& selection) const; | ||||
|     void render_hollowed_mesh() const; | ||||
|     void hollow_mesh(bool postpone_error_messages = false); | ||||
|     bool unsaved_changes() const; | ||||
| 
 | ||||
|  |  | |||
|  | @ -31,6 +31,22 @@ GLGizmoMove3D::~GLGizmoMove3D() | |||
|         ::gluDeleteQuadric(m_quadric); | ||||
| } | ||||
| 
 | ||||
| std::string GLGizmoMove3D::get_tooltip() const | ||||
| { | ||||
|     const Selection& selection = m_parent.get_selection(); | ||||
|     bool show_position = selection.is_single_full_instance(); | ||||
|     const Vec3d& position = selection.get_bounding_box().center(); | ||||
| 
 | ||||
|     if (m_hover_id == 0 || m_grabbers[0].dragging) | ||||
|         return "X: " + format(show_position ? position(0) : m_displacement(0), 2); | ||||
|     else if (m_hover_id == 1 || m_grabbers[1].dragging) | ||||
|         return "Y: " + format(show_position ? position(1) : m_displacement(1), 2); | ||||
|     else if (m_hover_id == 2 || m_grabbers[2].dragging) | ||||
|         return "Z: " + format(show_position ? position(2) : m_displacement(2), 2); | ||||
|     else | ||||
|         return ""; | ||||
| } | ||||
| 
 | ||||
| bool GLGizmoMove3D::on_init() | ||||
| { | ||||
|     for (int i = 0; i < 3; ++i) | ||||
|  | @ -85,22 +101,6 @@ void GLGizmoMove3D::on_render() const | |||
| { | ||||
|     const Selection& selection = m_parent.get_selection(); | ||||
| 
 | ||||
|     bool show_position = selection.is_single_full_instance(); | ||||
|     const Vec3d& position = selection.get_bounding_box().center(); | ||||
| 
 | ||||
|     if ((show_position && (m_hover_id == 0)) || m_grabbers[0].dragging) | ||||
|         set_tooltip("X: " + format(show_position ? position(0) : m_displacement(0), 2)); | ||||
|     else if (!m_grabbers[0].dragging && (m_hover_id == 0)) | ||||
|         set_tooltip("X"); | ||||
|     else if ((show_position && (m_hover_id == 1)) || m_grabbers[1].dragging) | ||||
|         set_tooltip("Y: " + format(show_position ? position(1) : m_displacement(1), 2)); | ||||
|     else if (!m_grabbers[1].dragging && (m_hover_id == 1)) | ||||
|         set_tooltip("Y"); | ||||
|     else if ((show_position && (m_hover_id == 2)) || m_grabbers[2].dragging) | ||||
|         set_tooltip("Z: " + format(show_position ? position(2) : m_displacement(2), 2)); | ||||
|     else if (!m_grabbers[2].dragging && (m_hover_id == 2)) | ||||
|         set_tooltip("Z"); | ||||
| 
 | ||||
|     glsafe(::glClear(GL_DEPTH_BUFFER_BIT)); | ||||
|     glsafe(::glEnable(GL_DEPTH_TEST)); | ||||
| 
 | ||||
|  |  | |||
|  | @ -30,6 +30,8 @@ public: | |||
| 
 | ||||
|     const Vec3d& get_displacement() const { return m_displacement; } | ||||
| 
 | ||||
|     std::string get_tooltip() const override; | ||||
| 
 | ||||
| protected: | ||||
|     virtual bool on_init(); | ||||
|     virtual std::string on_get_name() const; | ||||
|  |  | |||
|  | @ -67,6 +67,18 @@ void GLGizmoRotate::set_angle(double angle) | |||
|     m_angle = angle; | ||||
| } | ||||
| 
 | ||||
| std::string GLGizmoRotate::get_tooltip() const | ||||
| { | ||||
|     std::string axis; | ||||
|     switch (m_axis) | ||||
|     { | ||||
|     case X: { axis = "X"; break; } | ||||
|     case Y: { axis = "Y"; break; } | ||||
|     case Z: { axis = "Z"; break; } | ||||
|     } | ||||
|     return (m_hover_id == 0 || m_grabbers[0].dragging) ? axis + ": " + format((float)Geometry::rad2deg(m_angle), 4) : ""; | ||||
| } | ||||
| 
 | ||||
| bool GLGizmoRotate::on_init() | ||||
| { | ||||
|     m_grabbers.push_back(Grabber()); | ||||
|  | @ -127,19 +139,7 @@ void GLGizmoRotate::on_render() const | |||
|     const Selection& selection = m_parent.get_selection(); | ||||
|     const BoundingBoxf3& box = selection.get_bounding_box(); | ||||
| 
 | ||||
|     std::string axis; | ||||
|     switch (m_axis) | ||||
|     { | ||||
|     case X: { axis = "X"; break; } | ||||
|     case Y: { axis = "Y"; break; } | ||||
|     case Z: { axis = "Z"; break; } | ||||
|     } | ||||
| 
 | ||||
|     if (!m_dragging && (m_hover_id == 0)) | ||||
|         set_tooltip(axis); | ||||
|     else if (m_dragging) | ||||
|         set_tooltip(axis + ": " + format((float)Geometry::rad2deg(m_angle), 4) + "\u00B0"); | ||||
|     else | ||||
|     if (m_hover_id != 0 && !m_grabbers[0].dragging) | ||||
|     { | ||||
|         m_center = box.center(); | ||||
|         m_radius = Offset + box.radius(); | ||||
|  |  | |||
|  | @ -49,6 +49,8 @@ public: | |||
|     double get_angle() const { return m_angle; } | ||||
|     void set_angle(double angle); | ||||
| 
 | ||||
|     std::string get_tooltip() const override; | ||||
| 
 | ||||
| protected: | ||||
|     virtual bool on_init(); | ||||
|     virtual std::string on_get_name() const { return ""; } | ||||
|  | @ -81,6 +83,16 @@ public: | |||
|     Vec3d get_rotation() const { return Vec3d(m_gizmos[X].get_angle(), m_gizmos[Y].get_angle(), m_gizmos[Z].get_angle()); } | ||||
|     void set_rotation(const Vec3d& rotation) { m_gizmos[X].set_angle(rotation(0)); m_gizmos[Y].set_angle(rotation(1)); m_gizmos[Z].set_angle(rotation(2)); } | ||||
| 
 | ||||
|     std::string get_tooltip() const override | ||||
|     { | ||||
|         std::string tooltip = m_gizmos[X].get_tooltip(); | ||||
|         if (tooltip.empty()) | ||||
|             tooltip = m_gizmos[Y].get_tooltip(); | ||||
|         if (tooltip.empty()) | ||||
|             tooltip = m_gizmos[Z].get_tooltip(); | ||||
|         return tooltip; | ||||
|     } | ||||
| 
 | ||||
| protected: | ||||
|     virtual bool on_init(); | ||||
|     virtual std::string on_get_name() const; | ||||
|  |  | |||
|  | @ -20,6 +20,38 @@ GLGizmoScale3D::GLGizmoScale3D(GLCanvas3D& parent, const std::string& icon_filen | |||
| { | ||||
| } | ||||
| 
 | ||||
| std::string GLGizmoScale3D::get_tooltip() const | ||||
| { | ||||
|     const Selection& selection = m_parent.get_selection(); | ||||
| 
 | ||||
|     bool single_instance = selection.is_single_full_instance(); | ||||
|     bool single_volume = selection.is_single_modifier() || selection.is_single_volume(); | ||||
|     bool single_selection = single_instance || single_volume; | ||||
| 
 | ||||
|     Vec3f scale = 100.0f * Vec3f::Ones(); | ||||
|     if (single_instance) | ||||
|         scale = 100.0f * selection.get_volume(*selection.get_volume_idxs().begin())->get_instance_scaling_factor().cast<float>(); | ||||
|     else if (single_volume) | ||||
|         scale = 100.0f * selection.get_volume(*selection.get_volume_idxs().begin())->get_volume_scaling_factor().cast<float>(); | ||||
| 
 | ||||
|     if (m_hover_id == 0 || m_hover_id == 1 || m_grabbers[0].dragging || m_grabbers[1].dragging) | ||||
|         return "X: " + format(scale(0), 4) + "%"; | ||||
|     else if (m_hover_id == 2 || m_hover_id == 3 || m_grabbers[2].dragging || m_grabbers[3].dragging) | ||||
|         return "Y: " + format(scale(1), 4) + "%"; | ||||
|     else if (m_hover_id == 4 || m_hover_id == 5 || m_grabbers[4].dragging || m_grabbers[5].dragging) | ||||
|         return "Z: " + format(scale(2), 4) + "%"; | ||||
|     else if (m_hover_id == 6 || m_hover_id == 7 || m_hover_id == 8 || m_hover_id == 9 ||  | ||||
|         m_grabbers[6].dragging || m_grabbers[7].dragging || m_grabbers[8].dragging || m_grabbers[9].dragging) | ||||
|     { | ||||
|         std::string tooltip = "X: " + format(scale(0), 4) + "%\n"; | ||||
|         tooltip += "Y: " + format(scale(1), 4) + "%\n"; | ||||
|         tooltip += "Z: " + format(scale(2), 4) + "%"; | ||||
|         return tooltip; | ||||
|     } | ||||
|     else | ||||
|         return ""; | ||||
| } | ||||
| 
 | ||||
| bool GLGizmoScale3D::on_init() | ||||
| { | ||||
|     for (int i = 0; i < 10; ++i) | ||||
|  | @ -89,37 +121,6 @@ void GLGizmoScale3D::on_render() const | |||
| 
 | ||||
|     bool single_instance = selection.is_single_full_instance(); | ||||
|     bool single_volume = selection.is_single_modifier() || selection.is_single_volume(); | ||||
|     bool single_selection = single_instance || single_volume; | ||||
| 
 | ||||
|     Vec3f scale = 100.0f * Vec3f::Ones(); | ||||
|     if (single_instance) | ||||
|         scale = 100.0f * selection.get_volume(*selection.get_volume_idxs().begin())->get_instance_scaling_factor().cast<float>(); | ||||
|     else if (single_volume) | ||||
|         scale = 100.0f * selection.get_volume(*selection.get_volume_idxs().begin())->get_volume_scaling_factor().cast<float>(); | ||||
| 
 | ||||
|     if ((single_selection && ((m_hover_id == 0) || (m_hover_id == 1))) || m_grabbers[0].dragging || m_grabbers[1].dragging) | ||||
|         set_tooltip("X: " + format(scale(0), 4) + "%"); | ||||
|     else if (!m_grabbers[0].dragging && !m_grabbers[1].dragging && ((m_hover_id == 0) || (m_hover_id == 1))) | ||||
|         set_tooltip("X"); | ||||
|     else if ((single_selection && ((m_hover_id == 2) || (m_hover_id == 3))) || m_grabbers[2].dragging || m_grabbers[3].dragging) | ||||
|         set_tooltip("Y: " + format(scale(1), 4) + "%"); | ||||
|     else if (!m_grabbers[2].dragging && !m_grabbers[3].dragging && ((m_hover_id == 2) || (m_hover_id == 3))) | ||||
|         set_tooltip("Y"); | ||||
|     else if ((single_selection && ((m_hover_id == 4) || (m_hover_id == 5))) || m_grabbers[4].dragging || m_grabbers[5].dragging) | ||||
|         set_tooltip("Z: " + format(scale(2), 4) + "%"); | ||||
|     else if (!m_grabbers[4].dragging && !m_grabbers[5].dragging && ((m_hover_id == 4) || (m_hover_id == 5))) | ||||
|         set_tooltip("Z"); | ||||
|     else if ((single_selection && ((m_hover_id == 6) || (m_hover_id == 7) || (m_hover_id == 8) || (m_hover_id == 9))) | ||||
|         || m_grabbers[6].dragging || m_grabbers[7].dragging || m_grabbers[8].dragging || m_grabbers[9].dragging) | ||||
|     { | ||||
|         std::string tooltip = "X: " + format(scale(0), 4) + "%\n"; | ||||
|         tooltip += "Y: " + format(scale(1), 4) + "%\n"; | ||||
|         tooltip += "Z: " + format(scale(2), 4) + "%"; | ||||
|         set_tooltip(tooltip); | ||||
|     } | ||||
|     else if (!m_grabbers[6].dragging && !m_grabbers[7].dragging && !m_grabbers[8].dragging && !m_grabbers[9].dragging && | ||||
|         ((m_hover_id == 6) || (m_hover_id == 7) || (m_hover_id == 8) || (m_hover_id == 9))) | ||||
|         set_tooltip("X/Y/Z"); | ||||
| 
 | ||||
|     glsafe(::glClear(GL_DEPTH_BUFFER_BIT)); | ||||
|     glsafe(::glEnable(GL_DEPTH_TEST)); | ||||
|  |  | |||
|  | @ -42,6 +42,8 @@ public: | |||
| 
 | ||||
|     const Vec3d& get_offset() const { return m_offset; } | ||||
| 
 | ||||
|     std::string get_tooltip() const override; | ||||
| 
 | ||||
| protected: | ||||
|     virtual bool on_init(); | ||||
|     virtual std::string on_get_name() const; | ||||
|  |  | |||
|  | @ -1,6 +1,7 @@ | |||
| // Include GLGizmoBase.hpp before I18N.hpp as it includes some libigl code, which overrides our localization "L" macro.
 | ||||
| #include "GLGizmoSlaSupports.hpp" | ||||
| #include "slic3r/GUI/GLCanvas3D.hpp" | ||||
| #include "slic3r/GUI/Camera.hpp" | ||||
| #include "slic3r/GUI/Gizmos/GLGizmos.hpp" | ||||
| 
 | ||||
| #include <GL/glew.h> | ||||
|  | @ -109,8 +110,6 @@ void GLGizmoSlaSupports::on_render() const | |||
| 
 | ||||
|     m_z_shift = selection.get_volume(*selection.get_volume_idxs().begin())->get_sla_shift_z(); | ||||
| 
 | ||||
|     render_hollowed_mesh(); | ||||
| 
 | ||||
|     if (m_quadric != nullptr && selection.is_from_single_instance()) | ||||
|         render_points(selection, false); | ||||
| 
 | ||||
|  | @ -122,29 +121,6 @@ void GLGizmoSlaSupports::on_render() const | |||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| void GLGizmoSlaSupports::render_hollowed_mesh() const | ||||
| { | ||||
|     /*if (m_c->m_volume_with_cavity) {
 | ||||
|         m_c->m_volume_with_cavity->set_sla_shift_z(m_z_shift); | ||||
|         m_parent.get_shader().start_using(); | ||||
| 
 | ||||
|         GLint current_program_id; | ||||
|         glsafe(::glGetIntegerv(GL_CURRENT_PROGRAM, ¤t_program_id)); | ||||
|         GLint color_id = (current_program_id > 0) ? ::glGetUniformLocation(current_program_id, "uniform_color") : -1; | ||||
|         GLint print_box_detection_id = (current_program_id > 0) ? ::glGetUniformLocation(current_program_id, "print_box.volume_detection") : -1; | ||||
|         GLint print_box_worldmatrix_id = (current_program_id > 0) ? ::glGetUniformLocation(current_program_id, "print_box.volume_world_matrix") : -1; | ||||
|         glcheck(); | ||||
|         m_c->m_volume_with_cavity->set_render_color(); | ||||
|         const Geometry::Transformation& volume_trafo = m_c->m_model_object->volumes.front()->get_transformation(); | ||||
|         m_c->m_volume_with_cavity->set_volume_transformation(volume_trafo); | ||||
|         m_c->m_volume_with_cavity->set_instance_transformation(m_c->m_model_object->instances[size_t(m_c->m_active_instance)]->get_transformation()); | ||||
|         m_c->m_volume_with_cavity->render(color_id, print_box_detection_id, print_box_worldmatrix_id); | ||||
|         m_parent.get_shader().stop_using(); | ||||
|     }*/ | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| void GLGizmoSlaSupports::render_clipping_plane(const Selection& selection) const | ||||
| { | ||||
|     if (m_c->m_clipping_plane_distance == 0.f || m_c->m_mesh->empty()) | ||||
|  | @ -241,7 +217,6 @@ void GLGizmoSlaSupports::on_render_for_picking() const | |||
| 
 | ||||
|     glsafe(::glEnable(GL_DEPTH_TEST)); | ||||
|     render_points(selection, true); | ||||
|     render_hollowed_mesh(); | ||||
| } | ||||
| 
 | ||||
| void GLGizmoSlaSupports::render_points(const Selection& selection, bool picking) const | ||||
|  | @ -638,8 +613,6 @@ void GLGizmoSlaSupports::delete_selected_points(bool force) | |||
|     } | ||||
| 
 | ||||
|     select_point(NoPoints); | ||||
| 
 | ||||
|     //m_parent.post_event(SimpleEvent(EVT_GLCANVAS_SCHEDULE_BACKGROUND_PROCESS));
 | ||||
| } | ||||
| 
 | ||||
| void GLGizmoSlaSupports::on_update(const UpdateData& data) | ||||
|  | @ -654,8 +627,6 @@ void GLGizmoSlaSupports::on_update(const UpdateData& data) | |||
|             m_editing_cache[m_hover_id].support_point.pos = pos_and_normal.first; | ||||
|             m_editing_cache[m_hover_id].support_point.is_new_island = false; | ||||
|             m_editing_cache[m_hover_id].normal = pos_and_normal.second; | ||||
|             // Do not update immediately, wait until the mouse is released.
 | ||||
|             // m_parent.post_event(SimpleEvent(EVT_GLCANVAS_SCHEDULE_BACKGROUND_PROCESS));
 | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -93,7 +93,6 @@ private: | |||
|     //void render_selection_rectangle() const;
 | ||||
|     void render_points(const Selection& selection, bool picking = false) const; | ||||
|     void render_clipping_plane(const Selection& selection) const; | ||||
|     void render_hollowed_mesh() const; | ||||
|     bool unsaved_changes() const; | ||||
| 
 | ||||
|     bool m_lock_unique_islands = false; | ||||
|  |  | |||
|  | @ -11,8 +11,9 @@ | |||
| #include "slic3r/Utils/UndoRedo.hpp" | ||||
| #include "libslic3r/SLAPrint.hpp" | ||||
| #include "slic3r/GUI/MeshUtils.hpp" | ||||
| #include "slic3r/GUI/Gizmos/GLGizmos.hpp" | ||||
| #include "slic3r/GUI/Camera.hpp" | ||||
| 
 | ||||
| #include <GL/glew.h> | ||||
| #include <wx/glcanvas.h> | ||||
| 
 | ||||
| namespace Slic3r { | ||||
|  | @ -228,7 +229,7 @@ void GLGizmosManager::update_data() | |||
|         set_scale(Vec3d::Ones()); | ||||
|         set_rotation(Vec3d::Zero()); | ||||
|         set_flattening_data(selection.is_from_single_object() ? selection.get_model()->objects[selection.get_object_idx()] : nullptr); | ||||
|         set_sla_support_data(nullptr); | ||||
|         set_sla_support_data(selection.is_from_single_instance() ? selection.get_model()->objects[selection.get_object_idx()] : nullptr); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
|  | @ -425,6 +426,15 @@ void GLGizmosManager::render_overlay() const | |||
|     do_render_overlay(); | ||||
| } | ||||
| 
 | ||||
| std::string GLGizmosManager::get_tooltip() const | ||||
| { | ||||
|     if (!m_tooltip.empty()) | ||||
|         return m_tooltip; | ||||
| 
 | ||||
|     const GLGizmoBase* curr = get_current(); | ||||
|     return (curr != nullptr) ? curr->get_tooltip() : ""; | ||||
| } | ||||
| 
 | ||||
| bool GLGizmosManager::on_mouse_wheel(wxMouseEvent& evt) | ||||
| { | ||||
|     bool processed = false; | ||||
|  | @ -450,6 +460,7 @@ bool GLGizmosManager::on_mouse(wxMouseEvent& evt) | |||
|     int selected_object_idx = selection.get_object_idx(); | ||||
|     bool processed = false; | ||||
| 
 | ||||
| #if !ENABLE_CANVAS_TOOLTIP_USING_IMGUI | ||||
|     // mouse anywhere
 | ||||
|     if (!evt.Dragging() && !evt.Leaving() && !evt.Entering() && (m_mouse_capture.parent != nullptr)) | ||||
|     { | ||||
|  | @ -459,10 +470,81 @@ bool GLGizmosManager::on_mouse(wxMouseEvent& evt) | |||
| 
 | ||||
|         m_mouse_capture.reset(); | ||||
|     } | ||||
| #endif // !ENABLE_CANVAS_TOOLTIP_USING_IMGUI
 | ||||
| 
 | ||||
|     // mouse anywhere
 | ||||
|     if (evt.Moving()) | ||||
|         m_tooltip = update_hover_state(mouse_pos); | ||||
| #if ENABLE_CANVAS_TOOLTIP_USING_IMGUI | ||||
|     else if (evt.LeftUp()) | ||||
|     { | ||||
|         if (m_mouse_capture.left) | ||||
|         { | ||||
|             processed = true; | ||||
|             m_mouse_capture.left = false; | ||||
|         } | ||||
|         else if (is_dragging()) | ||||
|         { | ||||
|             switch (m_current) { | ||||
|             case Move: m_parent.do_move(L("Gizmo-Move")); break; | ||||
|             case Scale: m_parent.do_scale(L("Gizmo-Scale")); break; | ||||
|             case Rotate: m_parent.do_rotate(L("Gizmo-Rotate")); break; | ||||
|             default: break; | ||||
|             } | ||||
| 
 | ||||
|             stop_dragging(); | ||||
|             update_data(); | ||||
| 
 | ||||
|             wxGetApp().obj_manipul()->set_dirty(); | ||||
|             // Let the plater know that the dragging finished, so a delayed refresh
 | ||||
|             // of the scene with the background processing data should be performed.
 | ||||
|             m_parent.post_event(SimpleEvent(EVT_GLCANVAS_MOUSE_DRAGGING_FINISHED)); | ||||
|             // updates camera target constraints
 | ||||
|             m_parent.refresh_camera_scene_box(); | ||||
| 
 | ||||
|             processed = true; | ||||
|         } | ||||
| //        else
 | ||||
| //            return false;
 | ||||
|     } | ||||
|     else if (evt.MiddleUp()) | ||||
|     { | ||||
|         if (m_mouse_capture.middle) | ||||
|         { | ||||
|             processed = true; | ||||
|             m_mouse_capture.middle = false; | ||||
|         } | ||||
|         else | ||||
|             return false; | ||||
|     } | ||||
|     else if (evt.RightUp()) | ||||
|     { | ||||
|         if (pending_right_up) | ||||
|         { | ||||
|             pending_right_up = false; | ||||
|             return true; | ||||
|         } | ||||
|         if (m_mouse_capture.right) | ||||
|         { | ||||
|             processed = true; | ||||
|             m_mouse_capture.right = false; | ||||
|         } | ||||
|         else | ||||
|             return false; | ||||
|     } | ||||
| #if ENABLE_GIZMO_TOOLBAR_DRAGGING_FIX | ||||
|     else if (evt.Dragging() && !is_dragging()) | ||||
| #else | ||||
|     else if (evt.Dragging()) | ||||
| #endif // ENABLE_GIZMO_TOOLBAR_DRAGGING_FIX
 | ||||
|     { | ||||
|         if (m_mouse_capture.any()) | ||||
|             // if the button down was done on this toolbar, prevent from dragging into the scene
 | ||||
|             processed = true; | ||||
| //        else
 | ||||
| //            return false;
 | ||||
|     } | ||||
| #else | ||||
|     else if (evt.LeftUp()) | ||||
|         m_mouse_capture.left = false; | ||||
|     else if (evt.MiddleUp()) | ||||
|  | @ -479,6 +561,55 @@ bool GLGizmosManager::on_mouse(wxMouseEvent& evt) | |||
|     else if (evt.Dragging() && m_mouse_capture.any()) | ||||
|         // if the button down was done on this toolbar, prevent from dragging into the scene
 | ||||
|         processed = true; | ||||
| #endif // ENABLE_CANVAS_TOOLTIP_USING_IMGUI
 | ||||
| #if ENABLE_GIZMO_TOOLBAR_DRAGGING_FIX | ||||
|     else if (evt.Dragging() && is_dragging()) | ||||
|     { | ||||
|         if (!m_parent.get_wxglcanvas()->HasCapture()) | ||||
|             m_parent.get_wxglcanvas()->CaptureMouse(); | ||||
| 
 | ||||
|         m_parent.set_mouse_as_dragging(); | ||||
|         update(m_parent.mouse_ray(pos), pos); | ||||
| 
 | ||||
|         switch (m_current) | ||||
|         { | ||||
|         case Move: | ||||
|         { | ||||
|             // Apply new temporary offset
 | ||||
|             selection.translate(get_displacement()); | ||||
|             wxGetApp().obj_manipul()->set_dirty(); | ||||
|             break; | ||||
|         } | ||||
|         case Scale: | ||||
|         { | ||||
|             // Apply new temporary scale factors
 | ||||
|             TransformationType transformation_type(TransformationType::Local_Absolute_Joint); | ||||
|             if (evt.AltDown()) | ||||
|                 transformation_type.set_independent(); | ||||
|             selection.scale(get_scale(), transformation_type); | ||||
|             if (evt.ControlDown()) | ||||
|                 selection.translate(get_scale_offset(), true); | ||||
|             wxGetApp().obj_manipul()->set_dirty(); | ||||
|             break; | ||||
|         } | ||||
|         case Rotate: | ||||
|         { | ||||
|             // Apply new temporary rotations
 | ||||
|             TransformationType transformation_type(TransformationType::World_Relative_Joint); | ||||
|             if (evt.AltDown()) | ||||
|                 transformation_type.set_independent(); | ||||
|             selection.rotate(get_rotation(), transformation_type); | ||||
|             wxGetApp().obj_manipul()->set_dirty(); | ||||
|             break; | ||||
|         } | ||||
|         default: | ||||
|             break; | ||||
|         } | ||||
| 
 | ||||
|         m_parent.set_as_dirty(); | ||||
|         processed = true; | ||||
|     } | ||||
| #endif // ENABLE_GIZMO_TOOLBAR_DRAGGING_FIX
 | ||||
| 
 | ||||
|     if (get_gizmo_idx_from_mouse(mouse_pos) == Undefined) | ||||
|     { | ||||
|  | @ -521,6 +652,7 @@ bool GLGizmosManager::on_mouse(wxMouseEvent& evt) | |||
|             m_parent.set_as_dirty(); | ||||
|             processed = true; | ||||
|         } | ||||
| #if !ENABLE_GIZMO_TOOLBAR_DRAGGING_FIX | ||||
|         else if (evt.Dragging() && is_dragging()) | ||||
|         { | ||||
|             if (!m_parent.get_wxglcanvas()->HasCapture()) | ||||
|  | @ -567,6 +699,8 @@ bool GLGizmosManager::on_mouse(wxMouseEvent& evt) | |||
|             m_parent.set_as_dirty(); | ||||
|             processed = true; | ||||
|         } | ||||
| #endif // !ENABLE_GIZMO_TOOLBAR_DRAGGING_FIX
 | ||||
| #if !ENABLE_CANVAS_TOOLTIP_USING_IMGUI | ||||
|         else if (evt.LeftUp() && is_dragging()) | ||||
|         { | ||||
|             switch (m_current) { | ||||
|  | @ -588,6 +722,7 @@ bool GLGizmosManager::on_mouse(wxMouseEvent& evt) | |||
| 
 | ||||
|             processed = true; | ||||
|         } | ||||
| #endif // !ENABLE_CANVAS_TOOLTIP_USING_IMGUI
 | ||||
|         else if (evt.LeftUp() && (m_current == SlaSupports || m_current == Hollow) && !m_parent.is_mouse_dragging()) | ||||
|         { | ||||
|             // in case SLA gizmo is selected, we just pass the LeftUp event and stop processing - neither
 | ||||
|  | @ -626,8 +761,10 @@ bool GLGizmosManager::on_mouse(wxMouseEvent& evt) | |||
|             m_mouse_capture.right = true; | ||||
|             m_mouse_capture.parent = &m_parent; | ||||
|         } | ||||
| #if !ENABLE_CANVAS_TOOLTIP_USING_IMGUI | ||||
|         else if (evt.LeftUp()) | ||||
|             processed = true; | ||||
| #endif // !ENABLE_CANVAS_TOOLTIP_USING_IMGUI
 | ||||
|     } | ||||
| 
 | ||||
|     return processed; | ||||
|  |  | |||
|  | @ -3,8 +3,8 @@ | |||
| 
 | ||||
| #include "slic3r/GUI/GLTexture.hpp" | ||||
| #include "slic3r/GUI/GLToolbar.hpp" | ||||
| #include "slic3r/GUI/Gizmos/GLGizmos.hpp" | ||||
| #include "libslic3r/ObjectID.hpp" | ||||
| #include "slic3r/GUI/Gizmos/GLGizmoBase.hpp" | ||||
| 
 | ||||
| #include <map> | ||||
| 
 | ||||
|  | @ -18,6 +18,8 @@ namespace GUI { | |||
| 
 | ||||
| class GLCanvas3D; | ||||
| class ClippingPlane; | ||||
| enum class SLAGizmoEventType : unsigned char; | ||||
| class CommonGizmosData; | ||||
| 
 | ||||
| class Rect | ||||
| { | ||||
|  | @ -204,7 +206,7 @@ public: | |||
| 
 | ||||
|     void render_overlay() const; | ||||
| 
 | ||||
|     const std::string& get_tooltip() const { return m_tooltip; } | ||||
|     std::string get_tooltip() const; | ||||
| 
 | ||||
|     bool on_mouse(wxMouseEvent& evt); | ||||
|     bool on_mouse_wheel(wxMouseEvent& evt); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 enricoturri1966
						enricoturri1966