mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	Merge branch 'master' of https://github.com/prusa3d/PrusaSlicer into et_custom_gcode_detection
This commit is contained in:
		
						commit
						28d01542ed
					
				
					 70 changed files with 1913 additions and 2229 deletions
				
			
		|  | @ -1595,13 +1595,15 @@ void GCodeViewer::load_toolpaths(const GCodeProcessor::Result& gcode_result) | |||
| #if ENABLE_REDUCED_TOOLPATHS_SEGMENT_CAPS | ||||
|             const std::array<IBufferType, 8> first_seg_v_offsets = convert_vertices_offset(vbuffer_size, { 0, 1, 2, 3, 4, 5, 6, 7 }); | ||||
|             const std::array<IBufferType, 8> non_first_seg_v_offsets = convert_vertices_offset(vbuffer_size, { -4, 0, -2, 1, 2, 3, 4, 5 }); | ||||
| #endif // ENABLE_REDUCED_TOOLPATHS_SEGMENT_CAPS
 | ||||
| 
 | ||||
|             bool is_first_segment = (last_path.vertices_count() == 1); | ||||
|             if (is_first_segment || vbuffer_size == 0) { | ||||
| #else | ||||
|             if (last_path.vertices_count() == 1 || vbuffer_size == 0) { | ||||
| #endif // ENABLE_REDUCED_TOOLPATHS_SEGMENT_CAPS
 | ||||
|                 // 1st segment or restart into a new vertex buffer
 | ||||
|                 // ===============================================
 | ||||
| #if ENABLE_REDUCED_TOOLPATHS_SEGMENT_CAPS | ||||
|                 if (last_path.vertices_count() == 1) | ||||
|                 if (is_first_segment) | ||||
|                     // starting cap triangles
 | ||||
|                     append_starting_cap_triangles(indices, first_seg_v_offsets); | ||||
| #endif // ENABLE_REDUCED_TOOLPATHS_SEGMENT_CAPS
 | ||||
|  | @ -1679,7 +1681,7 @@ void GCodeViewer::load_toolpaths(const GCodeProcessor::Result& gcode_result) | |||
| #if ENABLE_REDUCED_TOOLPATHS_SEGMENT_CAPS | ||||
|             if (next != nullptr && (curr.type != next->type || !last_path.matches(*next))) | ||||
|                 // ending cap triangles
 | ||||
|                 append_ending_cap_triangles(indices, non_first_seg_v_offsets); | ||||
|                 append_ending_cap_triangles(indices, is_first_segment ? first_seg_v_offsets : non_first_seg_v_offsets); | ||||
| #endif // ENABLE_REDUCED_TOOLPATHS_SEGMENT_CAPS
 | ||||
| 
 | ||||
|             last_path.sub_paths.back().last = { ibuffer_id, indices.size() - 1, move_id, curr.position }; | ||||
|  |  | |||
|  | @ -1,7 +1,6 @@ | |||
| #include "libslic3r/libslic3r.h" | ||||
| #include "GLCanvas3D.hpp" | ||||
| 
 | ||||
| #include "admesh/stl.h" | ||||
| #include "libslic3r/ClipperUtils.hpp" | ||||
| #include "libslic3r/PrintConfig.hpp" | ||||
| #include "libslic3r/GCode/ThumbnailData.hpp" | ||||
|  | @ -1682,8 +1681,10 @@ void GLCanvas3D::render() | |||
|     if (m_picking_enabled) | ||||
|         m_mouse.scene_position = _mouse_to_3d(m_mouse.position.cast<coord_t>()); | ||||
| 
 | ||||
|     _render_current_gizmo(); | ||||
|     // sidebar hints need to be rendered before the gizmos because the depth buffer
 | ||||
|     // could be invalidated by the following gizmo render methods
 | ||||
|     _render_selection_sidebar_hints(); | ||||
|     _render_current_gizmo(); | ||||
| #if ENABLE_RENDER_PICKING_PASS | ||||
|     } | ||||
| #endif // ENABLE_RENDER_PICKING_PASS
 | ||||
|  |  | |||
|  | @ -235,7 +235,7 @@ bool Preview::init(wxWindow* parent, Model* model) | |||
|         _L("Ironing") + "|1|" + | ||||
|         _L("Bridge infill") + "|1|" + | ||||
|         _L("Gap fill") + "|1|" + | ||||
|         _L("Skirt") + "|1|" + | ||||
|         _L("Skirt/Brim") + "|1|" + | ||||
|         _L("Support material") + "|1|" + | ||||
|         _L("Support material interface") + "|1|" + | ||||
|         _L("Wipe tower") + "|1|" + | ||||
|  |  | |||
|  | @ -1483,10 +1483,10 @@ void MainFrame::repair_stl() | |||
|         output_file = dlg.GetPath(); | ||||
|     } | ||||
| 
 | ||||
|     auto tmesh = new Slic3r::TriangleMesh(); | ||||
|     tmesh->ReadSTLFile(input_file.ToUTF8().data()); | ||||
|     tmesh->repair(); | ||||
|     tmesh->WriteOBJFile(output_file.ToUTF8().data()); | ||||
|     Slic3r::TriangleMesh tmesh; | ||||
|     tmesh.ReadSTLFile(input_file.ToUTF8().data()); | ||||
|     tmesh.repair(); | ||||
|     tmesh.WriteOBJFile(output_file.ToUTF8().data()); | ||||
|     Slic3r::GUI::show_info(this, L("Your file was repaired."), L("Repair")); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -5085,6 +5085,30 @@ void Plater::export_stl(bool extended, bool selection_only) | |||
|     if (selection_only && (obj_idx == -1 || selection.is_wipe_tower())) | ||||
|         return; | ||||
| 
 | ||||
|     // Following lambda generates a combined mesh for export with normals pointing outwards.
 | ||||
|     auto mesh_to_export = [](const ModelObject* mo, bool instances) -> TriangleMesh { | ||||
|         TriangleMesh mesh; | ||||
|         for (const ModelVolume *v : mo->volumes) | ||||
|             if (v->is_model_part()) { | ||||
|                 TriangleMesh vol_mesh(v->mesh()); | ||||
|                 vol_mesh.repair(); | ||||
|                 vol_mesh.transform(v->get_matrix(), true); | ||||
|                 mesh.merge(vol_mesh); | ||||
|             } | ||||
|         mesh.repair(); | ||||
|         if (instances) { | ||||
|             TriangleMesh vols_mesh(mesh); | ||||
|             mesh = TriangleMesh(); | ||||
|             for (const ModelInstance *i : mo->instances) { | ||||
|                 TriangleMesh m = vols_mesh; | ||||
|                 m.transform(i->get_matrix(), true); | ||||
|                 mesh.merge(m); | ||||
|             } | ||||
|         } | ||||
|         mesh.repair(); | ||||
|         return mesh; | ||||
|     }; | ||||
| 
 | ||||
|     TriangleMesh mesh; | ||||
|     if (p->printer_technology == ptFFF) { | ||||
|         if (selection_only) { | ||||
|  | @ -5092,20 +5116,21 @@ void Plater::export_stl(bool extended, bool selection_only) | |||
|             if (selection.get_mode() == Selection::Instance) | ||||
|             { | ||||
|                 if (selection.is_single_full_object()) | ||||
|                     mesh = model_object->mesh(); | ||||
|                     mesh = mesh_to_export(model_object, true); | ||||
|                 else | ||||
|                     mesh = model_object->full_raw_mesh(); | ||||
|                     mesh = mesh_to_export(model_object, false); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 const GLVolume* volume = selection.get_volume(*selection.get_volume_idxs().begin()); | ||||
|                 mesh = model_object->volumes[volume->volume_idx()]->mesh(); | ||||
|                 mesh.transform(volume->get_volume_transformation().get_matrix()); | ||||
|                 mesh.transform(volume->get_volume_transformation().get_matrix(), true); | ||||
|                 mesh.translate(-model_object->origin_translation.cast<float>()); | ||||
|             } | ||||
|         } | ||||
|         else { | ||||
|             mesh = p->model.mesh(); | ||||
|             for (const ModelObject *o : p->model.objects) | ||||
|                 mesh.merge(mesh_to_export(o, true)); | ||||
|         } | ||||
|     } | ||||
|     else | ||||
|  |  | |||
|  | @ -1217,7 +1217,7 @@ void Selection::render_center(bool gizmo_is_dragging) const | |||
|     if (!m_valid || is_empty() || m_quadric == nullptr) | ||||
|         return; | ||||
| 
 | ||||
|     Vec3d center = gizmo_is_dragging ? m_cache.dragging_center : get_bounding_box().center(); | ||||
|     const Vec3d center = gizmo_is_dragging ? m_cache.dragging_center : get_bounding_box().center(); | ||||
| 
 | ||||
|     glsafe(::glDisable(GL_DEPTH_TEST)); | ||||
| 
 | ||||
|  | @ -1286,7 +1286,7 @@ void Selection::render_sidebar_hints(const std::string& sidebar_field) const | |||
|         } else { | ||||
|             glsafe(::glTranslated(center(0), center(1), center(2))); | ||||
|             if (requires_local_axes()) { | ||||
|                 Transform3d orient_matrix = (*m_volumes)[*m_list.begin()]->get_instance_transformation().get_matrix(true, false, true, true); | ||||
|                 const Transform3d orient_matrix = (*m_volumes)[*m_list.begin()]->get_instance_transformation().get_matrix(true, false, true, true); | ||||
|                 glsafe(::glMultMatrixd(orient_matrix.data())); | ||||
|             } | ||||
|         } | ||||
|  | @ -1976,7 +1976,7 @@ void Selection::render_sidebar_layers_hints(const std::string& sidebar_field) co | |||
|     if (pos == std::string::npos) | ||||
|         return; | ||||
| 
 | ||||
|     double min_z = std::stod(field.substr(pos + 1)); | ||||
|     const double min_z = std::stod(field.substr(pos + 1)); | ||||
| 
 | ||||
|     // extract type
 | ||||
|     field = field.substr(0, pos); | ||||
|  | @ -1984,7 +1984,7 @@ void Selection::render_sidebar_layers_hints(const std::string& sidebar_field) co | |||
|     if (pos == std::string::npos) | ||||
|         return; | ||||
| 
 | ||||
|     int type = std::stoi(field.substr(pos + 1)); | ||||
|     const int type = std::stoi(field.substr(pos + 1)); | ||||
| 
 | ||||
|     const BoundingBoxf3& box = get_bounding_box(); | ||||
| 
 | ||||
|  | @ -1995,8 +1995,8 @@ void Selection::render_sidebar_layers_hints(const std::string& sidebar_field) co | |||
| 
 | ||||
|     // view dependend order of rendering to keep correct transparency
 | ||||
|     bool camera_on_top = wxGetApp().plater()->get_camera().is_looking_downward(); | ||||
|     float z1 = camera_on_top ? min_z : max_z; | ||||
|     float z2 = camera_on_top ? max_z : min_z; | ||||
|     const float z1 = camera_on_top ? min_z : max_z; | ||||
|     const float z2 = camera_on_top ? max_z : min_z; | ||||
| 
 | ||||
|     glsafe(::glEnable(GL_DEPTH_TEST)); | ||||
|     glsafe(::glDisable(GL_CULL_FACE)); | ||||
|  | @ -2004,7 +2004,7 @@ void Selection::render_sidebar_layers_hints(const std::string& sidebar_field) co | |||
|     glsafe(::glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA)); | ||||
| 
 | ||||
|     ::glBegin(GL_QUADS); | ||||
|     if ((camera_on_top && (type == 1)) || (!camera_on_top && (type == 2))) | ||||
|     if ((camera_on_top && type == 1) || (!camera_on_top && type == 2)) | ||||
|         ::glColor4f(1.0f, 0.38f, 0.0f, 1.0f); | ||||
|     else | ||||
|         ::glColor4f(0.8f, 0.8f, 0.8f, 0.5f); | ||||
|  | @ -2015,7 +2015,7 @@ void Selection::render_sidebar_layers_hints(const std::string& sidebar_field) co | |||
|     glsafe(::glEnd()); | ||||
| 
 | ||||
|     ::glBegin(GL_QUADS); | ||||
|     if ((camera_on_top && (type == 2)) || (!camera_on_top && (type == 1))) | ||||
|     if ((camera_on_top && type == 2) || (!camera_on_top && type == 1)) | ||||
|         ::glColor4f(1.0f, 0.38f, 0.0f, 1.0f); | ||||
|     else | ||||
|         ::glColor4f(0.8f, 0.8f, 0.8f, 0.5f); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 enricoturri1966
						enricoturri1966