mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 10:11:10 -06:00 
			
		
		
		
	Merge branch 'lm_painter_fixes'
This commit is contained in:
		
						commit
						dbedd3f9b0
					
				
					 12 changed files with 170 additions and 66 deletions
				
			
		|  | @ -1670,8 +1670,9 @@ void GLCanvas3D::toggle_model_objects_visibility(bool visible, const ModelObject | |||
|                 } else { | ||||
|                     const GLGizmosManager& gm = get_gizmos_manager(); | ||||
|                     auto gizmo_type = gm.get_current_type(); | ||||
|                     if (gizmo_type == GLGizmosManager::FdmSupports | ||||
|                      || gizmo_type == GLGizmosManager::Seam) | ||||
|                     if (    (gizmo_type == GLGizmosManager::FdmSupports | ||||
|                           || gizmo_type == GLGizmosManager::Seam) | ||||
|                         && ! vol->is_modifier) | ||||
|                         vol->force_neutral_color = true; | ||||
|                     else | ||||
|                         vol->force_native_color = true; | ||||
|  | @ -5460,6 +5461,20 @@ void GLCanvas3D::_render_objects() const | |||
|             }); | ||||
|         } | ||||
| 
 | ||||
|         // In case a painting gizmo is open, it should render the painted triangles
 | ||||
|         // before transparent objects are rendered. Otherwise they would not be
 | ||||
|         // visible when inside modifier meshes etc.
 | ||||
|         { | ||||
|             const GLGizmosManager& gm = get_gizmos_manager(); | ||||
|             GLGizmosManager::EType type = gm.get_current_type(); | ||||
|             if (type == GLGizmosManager::FdmSupports | ||||
|              || type == GLGizmosManager::Seam) { | ||||
|                 shader->stop_using(); | ||||
|                 gm.render_painter_gizmo(); | ||||
|                 shader->start_using(); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         m_volumes.render(GLVolumeCollection::Transparent, false, wxGetApp().plater()->get_camera().get_view_matrix()); | ||||
|         shader->stop_using(); | ||||
|     } | ||||
|  |  | |||
|  | @ -56,7 +56,7 @@ bool GLGizmoFdmSupports::on_init() | |||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| void GLGizmoFdmSupports::on_render() const | ||||
| void GLGizmoFdmSupports::render_painter_gizmo() const | ||||
| { | ||||
|     const Selection& selection = m_parent.get_selection(); | ||||
| 
 | ||||
|  |  | |||
|  | @ -13,14 +13,14 @@ public: | |||
|     GLGizmoFdmSupports(GLCanvas3D& parent, const std::string& icon_filename, unsigned int sprite_id) | ||||
|         : GLGizmoPainterBase(parent, icon_filename, sprite_id) {} | ||||
| 
 | ||||
|     void render_painter_gizmo() const override; | ||||
| 
 | ||||
| protected: | ||||
|     void on_render_input_window(float x, float y, float bottom_limit) override; | ||||
|     std::string on_get_name() const override; | ||||
| 
 | ||||
| private: | ||||
|     bool on_init() override; | ||||
|     void on_render() const override; | ||||
|     void on_render_for_picking() const override {} | ||||
| 
 | ||||
|     void update_model_object() const override; | ||||
|     void update_from_model_object() override; | ||||
|  |  | |||
|  | @ -350,19 +350,12 @@ bool GLGizmoPainterBase::gizmo_event(SLAGizmoEventType action, const Vec2d& mous | |||
| 
 | ||||
|             const Transform3d& trafo_matrix = trafo_matrices[m_rr.mesh_id]; | ||||
| 
 | ||||
|             // Calculate how far can a point be from the line (in mesh coords).
 | ||||
|             // FIXME: The scaling of the mesh can be non-uniform.
 | ||||
|             const Vec3d sf = Geometry::Transformation(trafo_matrix).get_scaling_factor(); | ||||
|             const float avg_scaling = (sf(0) + sf(1) + sf(2))/3.; | ||||
|             const float limit = m_cursor_radius/avg_scaling; | ||||
| 
 | ||||
|             // Calculate direction from camera to the hit (in mesh coords):
 | ||||
|             Vec3f camera_pos = (trafo_matrix.inverse() * camera.get_position()).cast<float>(); | ||||
|             Vec3f dir = (m_rr.hit - camera_pos).normalized(); | ||||
| 
 | ||||
|             assert(m_rr.mesh_id < int(m_triangle_selectors.size())); | ||||
|             m_triangle_selectors[m_rr.mesh_id]->select_patch(m_rr.hit, m_rr.facet, camera_pos, | ||||
|                                               dir, limit, m_cursor_type, new_state); | ||||
|                                        m_cursor_radius, m_cursor_type, new_state, trafo_matrix); | ||||
|             m_last_mouse_click = mouse_position; | ||||
|         } | ||||
| 
 | ||||
|  |  | |||
|  | @ -59,6 +59,8 @@ class GLGizmoPainterBase : public GLGizmoBase | |||
| private: | ||||
|     ObjectID m_old_mo_id; | ||||
|     size_t m_old_volumes_size = 0; | ||||
|     virtual void on_render() const {} | ||||
|     virtual void on_render_for_picking() const {} | ||||
| 
 | ||||
| public: | ||||
|     GLGizmoPainterBase(GLCanvas3D& parent, const std::string& icon_filename, unsigned int sprite_id); | ||||
|  | @ -66,6 +68,12 @@ public: | |||
|     void set_painter_gizmo_data(const Selection& selection); | ||||
|     bool gizmo_event(SLAGizmoEventType action, const Vec2d& mouse_position, bool shift_down, bool alt_down, bool control_down); | ||||
| 
 | ||||
|     // Following function renders the triangles and cursor. Having this separated
 | ||||
|     // from usual on_render method allows to render them before transparent objects,
 | ||||
|     // so they can be seen inside them. The usual on_render is called after all
 | ||||
|     // volumes (including transparent ones) are rendered.
 | ||||
|     virtual void render_painter_gizmo() const = 0; | ||||
| 
 | ||||
| protected: | ||||
|     void render_triangles(const Selection& selection) const; | ||||
|     void render_cursor() const; | ||||
|  |  | |||
|  | @ -46,7 +46,7 @@ std::string GLGizmoSeam::on_get_name() const | |||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| void GLGizmoSeam::on_render() const | ||||
| void GLGizmoSeam::render_painter_gizmo() const | ||||
| { | ||||
|     const Selection& selection = m_parent.get_selection(); | ||||
| 
 | ||||
|  |  | |||
|  | @ -13,6 +13,8 @@ public: | |||
|     GLGizmoSeam(GLCanvas3D& parent, const std::string& icon_filename, unsigned int sprite_id) | ||||
|         : GLGizmoPainterBase(parent, icon_filename, sprite_id) {} | ||||
| 
 | ||||
|     void render_painter_gizmo() const override; | ||||
| 
 | ||||
| protected: | ||||
|     void on_render_input_window(float x, float y, float bottom_limit) override; | ||||
|     std::string on_get_name() const override; | ||||
|  | @ -20,8 +22,6 @@ protected: | |||
| 
 | ||||
| private: | ||||
|     bool on_init() override; | ||||
|     void on_render() const override; | ||||
|     void on_render_for_picking() const override {} | ||||
| 
 | ||||
|     void update_model_object() const override; | ||||
|     void update_from_model_object() override; | ||||
|  |  | |||
|  | @ -295,11 +295,9 @@ void ObjectClipper::on_update() | |||
|     if (has_hollowed) | ||||
|         meshes.push_back(get_pool()->hollowed_mesh()->get_hollowed_mesh()); | ||||
| 
 | ||||
|     if (meshes.empty()) { | ||||
|     if (meshes.empty()) | ||||
|         for (const ModelVolume* mv : mo->volumes) | ||||
|             if (mv->is_model_part()) | ||||
|                 meshes.push_back(&mv->mesh()); | ||||
|     } | ||||
|             meshes.push_back(&mv->mesh()); | ||||
| 
 | ||||
|     if (meshes != m_old_meshes) { | ||||
|         m_clippers.clear(); | ||||
|  | @ -335,9 +333,6 @@ void ObjectClipper::render_cut() const | |||
| 
 | ||||
|     size_t clipper_id = 0; | ||||
|     for (const ModelVolume* mv : mo->volumes) { | ||||
|         if (! mv->is_model_part()) | ||||
|             continue; | ||||
| 
 | ||||
|         Geometry::Transformation vol_trafo  = mv->get_transformation(); | ||||
|         Geometry::Transformation trafo = inst_trafo * vol_trafo; | ||||
|         trafo.set_offset(trafo.get_offset() + Vec3d(0., 0., sel_info->get_sla_shift())); | ||||
|  |  | |||
|  | @ -437,6 +437,19 @@ void GLGizmosManager::render_current_gizmo() const | |||
|     m_gizmos[m_current]->render(); | ||||
| } | ||||
| 
 | ||||
| void GLGizmosManager::render_painter_gizmo() const | ||||
| { | ||||
|     // This function shall only be called when current gizmo is
 | ||||
|     // derived from GLGizmoPainterBase.
 | ||||
| 
 | ||||
|     if (!m_enabled || m_current == Undefined) | ||||
|         return; | ||||
| 
 | ||||
|     auto* gizmo = dynamic_cast<GLGizmoPainterBase*>(get_current()); | ||||
|     assert(gizmo); // check the precondition
 | ||||
|     gizmo->render_painter_gizmo(); | ||||
| } | ||||
| 
 | ||||
| void GLGizmosManager::render_current_gizmo_for_picking_pass() const | ||||
| { | ||||
|     if (! m_enabled || m_current == Undefined) | ||||
|  |  | |||
|  | @ -212,6 +212,7 @@ public: | |||
| 
 | ||||
|     void render_current_gizmo() const; | ||||
|     void render_current_gizmo_for_picking_pass() const; | ||||
|     void render_painter_gizmo() const; | ||||
| 
 | ||||
|     void render_overlay() const; | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lukas Matena
						Lukas Matena