mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 09:11:23 -06:00 
			
		
		
		
	Move rotation from building octree to infill generating
This commit is contained in:
		
							parent
							
								
									ea9a8b7e93
								
							
						
					
					
						commit
						70cb67430c
					
				
					 3 changed files with 23 additions and 15 deletions
				
			
		|  | @ -97,11 +97,14 @@ void FillAdaptive::_fill_surface_single( | ||||||
|     ExPolygon                       &expolygon,  |     ExPolygon                       &expolygon,  | ||||||
|     Polylines                       &polylines_out) |     Polylines                       &polylines_out) | ||||||
| { | { | ||||||
|  |     Vec3d rotation = Vec3d((5.0 * M_PI) / 4.0, Geometry::deg2rad(215.264), M_PI / 6.0); | ||||||
|  |     Transform3d rotation_matrix = Geometry::assemble_transform(Vec3d::Zero(), rotation, Vec3d::Ones(), Vec3d::Ones()); | ||||||
|  | 
 | ||||||
|     // Store grouped lines by its direction (multiple of 120°)
 |     // Store grouped lines by its direction (multiple of 120°)
 | ||||||
|     std::vector<Lines> infill_lines_dir(3); |     std::vector<Lines> infill_lines_dir(3); | ||||||
|     this->generate_infill_lines(this->adapt_fill_octree->root_cube.get(), |     this->generate_infill_lines(this->adapt_fill_octree->root_cube.get(), | ||||||
|                                 this->z, this->adapt_fill_octree->origin,infill_lines_dir, |                                 this->z, this->adapt_fill_octree->origin, rotation_matrix, | ||||||
|                                 this->adapt_fill_octree->cubes_properties, |                                 infill_lines_dir, this->adapt_fill_octree->cubes_properties, | ||||||
|                                 int(this->adapt_fill_octree->cubes_properties.size()) - 1); |                                 int(this->adapt_fill_octree->cubes_properties.size()) - 1); | ||||||
| 
 | 
 | ||||||
|     Polylines all_polylines; |     Polylines all_polylines; | ||||||
|  | @ -186,6 +189,7 @@ void FillAdaptive::generate_infill_lines( | ||||||
|         FillAdaptive_Internal::Cube *cube, |         FillAdaptive_Internal::Cube *cube, | ||||||
|         double z_position, |         double z_position, | ||||||
|         const Vec3d &origin, |         const Vec3d &origin, | ||||||
|  |         const Transform3d &rotation_matrix, | ||||||
|         std::vector<Lines> &dir_lines_out, |         std::vector<Lines> &dir_lines_out, | ||||||
|         const std::vector<FillAdaptive_Internal::CubeProperties> &cubes_properties, |         const std::vector<FillAdaptive_Internal::CubeProperties> &cubes_properties, | ||||||
|         int depth) |         int depth) | ||||||
|  | @ -197,7 +201,8 @@ void FillAdaptive::generate_infill_lines( | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     double z_diff = std::abs(z_position - cube->center.z()); |     Vec3d cube_center_tranformed = rotation_matrix * cube->center; | ||||||
|  |     double z_diff = std::abs(z_position - cube_center_tranformed.z()); | ||||||
| 
 | 
 | ||||||
|     if (z_diff > cubes_properties[depth].height / 2) |     if (z_diff > cubes_properties[depth].height / 2) | ||||||
|     { |     { | ||||||
|  | @ -208,14 +213,14 @@ void FillAdaptive::generate_infill_lines( | ||||||
|     { |     { | ||||||
|         Point from( |         Point from( | ||||||
|                 scale_((cubes_properties[depth].diagonal_length / 2) * (cubes_properties[depth].line_z_distance - z_diff) / cubes_properties[depth].line_z_distance), |                 scale_((cubes_properties[depth].diagonal_length / 2) * (cubes_properties[depth].line_z_distance - z_diff) / cubes_properties[depth].line_z_distance), | ||||||
|                 scale_(cubes_properties[depth].line_xy_distance - ((z_position - (cube->center.z() - cubes_properties[depth].line_z_distance)) / sqrt(2)))); |                 scale_(cubes_properties[depth].line_xy_distance - ((z_position - (cube_center_tranformed.z() - cubes_properties[depth].line_z_distance)) / sqrt(2)))); | ||||||
|         Point to(-from.x(), from.y()); |         Point to(-from.x(), from.y()); | ||||||
|         // Relative to cube center
 |         // Relative to cube center
 | ||||||
| 
 | 
 | ||||||
|         double rotation_angle = (2.0 * M_PI) / 3.0; |         double rotation_angle = (2.0 * M_PI) / 3.0; | ||||||
|         for (Lines &lines : dir_lines_out) |         for (Lines &lines : dir_lines_out) | ||||||
|         { |         { | ||||||
|             Vec3d offset = cube->center - origin; |             Vec3d offset = cube_center_tranformed - (rotation_matrix * origin); | ||||||
|             Point from_abs(from), to_abs(to); |             Point from_abs(from), to_abs(to); | ||||||
| 
 | 
 | ||||||
|             from_abs.x() += int(scale_(offset.x())); |             from_abs.x() += int(scale_(offset.x())); | ||||||
|  | @ -235,7 +240,7 @@ void FillAdaptive::generate_infill_lines( | ||||||
|     { |     { | ||||||
|         if(child != nullptr) |         if(child != nullptr) | ||||||
|         { |         { | ||||||
|             generate_infill_lines(child.get(), z_position, origin, dir_lines_out, cubes_properties, depth - 1); |             generate_infill_lines(child.get(), z_position, origin, rotation_matrix, dir_lines_out, cubes_properties, depth - 1); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | @ -301,14 +306,11 @@ std::unique_ptr<FillAdaptive_Internal::Octree> FillAdaptive::build_octree( | ||||||
|         triangle_mesh.require_shared_vertices(); |         triangle_mesh.require_shared_vertices(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     Vec3d rotation = Vec3d((5.0 * M_PI) / 4.0, Geometry::deg2rad(215.264), M_PI / 6.0); |  | ||||||
|     Transform3d rotation_matrix = Geometry::assemble_transform(Vec3d::Zero(), rotation, Vec3d::Ones(), Vec3d::Ones()); |  | ||||||
| 
 |  | ||||||
|     AABBTreeIndirect::Tree3f aabbTree = AABBTreeIndirect::build_aabb_tree_over_indexed_triangle_set( |     AABBTreeIndirect::Tree3f aabbTree = AABBTreeIndirect::build_aabb_tree_over_indexed_triangle_set( | ||||||
|             triangle_mesh.its.vertices, triangle_mesh.its.indices); |             triangle_mesh.its.vertices, triangle_mesh.its.indices); | ||||||
|     auto octree = std::make_unique<Octree>(std::make_unique<Cube>(cube_center), cube_center, cubes_properties); |     auto octree = std::make_unique<Octree>(std::make_unique<Cube>(cube_center), cube_center, cubes_properties); | ||||||
| 
 | 
 | ||||||
|     FillAdaptive::expand_cube(octree->root_cube.get(), cubes_properties, rotation_matrix, aabbTree, triangle_mesh, int(cubes_properties.size()) - 1); |     FillAdaptive::expand_cube(octree->root_cube.get(), cubes_properties, aabbTree, triangle_mesh, int(cubes_properties.size()) - 1); | ||||||
| 
 | 
 | ||||||
|     return octree; |     return octree; | ||||||
| } | } | ||||||
|  | @ -316,7 +318,6 @@ std::unique_ptr<FillAdaptive_Internal::Octree> FillAdaptive::build_octree( | ||||||
| void FillAdaptive::expand_cube( | void FillAdaptive::expand_cube( | ||||||
|     FillAdaptive_Internal::Cube *cube, |     FillAdaptive_Internal::Cube *cube, | ||||||
|     const std::vector<FillAdaptive_Internal::CubeProperties> &cubes_properties, |     const std::vector<FillAdaptive_Internal::CubeProperties> &cubes_properties, | ||||||
|     const Transform3d &rotation_matrix, |  | ||||||
|     const AABBTreeIndirect::Tree3f &distance_tree, |     const AABBTreeIndirect::Tree3f &distance_tree, | ||||||
|     const TriangleMesh &triangle_mesh, int depth) |     const TriangleMesh &triangle_mesh, int depth) | ||||||
| { | { | ||||||
|  | @ -337,13 +338,13 @@ void FillAdaptive::expand_cube( | ||||||
|     for (size_t i = 0; i < 8; ++i) |     for (size_t i = 0; i < 8; ++i) | ||||||
|     { |     { | ||||||
|         const Vec3d &child_center = child_centers[i]; |         const Vec3d &child_center = child_centers[i]; | ||||||
|         Vec3d child_center_transformed = cube->center + rotation_matrix * (child_center * (cubes_properties[depth].edge_length / 4)); |         Vec3d child_center_transformed = cube->center + (child_center * (cubes_properties[depth].edge_length / 4)); | ||||||
| 
 | 
 | ||||||
|         if(AABBTreeIndirect::is_any_triangle_in_radius(triangle_mesh.its.vertices, triangle_mesh.its.indices, |         if(AABBTreeIndirect::is_any_triangle_in_radius(triangle_mesh.its.vertices, triangle_mesh.its.indices, | ||||||
|             distance_tree, child_center_transformed, cube_radius_squared)) |             distance_tree, child_center_transformed, cube_radius_squared)) | ||||||
|         { |         { | ||||||
|             cube->children[i] = std::make_unique<Cube>(child_center_transformed); |             cube->children[i] = std::make_unique<Cube>(child_center_transformed); | ||||||
|             FillAdaptive::expand_cube(cube->children[i].get(), cubes_properties, rotation_matrix, distance_tree, triangle_mesh, depth - 1); |             FillAdaptive::expand_cube(cube->children[i].get(), cubes_properties, distance_tree, triangle_mesh, depth - 1); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -63,6 +63,7 @@ protected: | ||||||
|         FillAdaptive_Internal::Cube *cube, |         FillAdaptive_Internal::Cube *cube, | ||||||
|         double                       z_position, |         double                       z_position, | ||||||
|         const Vec3d &                origin, |         const Vec3d &                origin, | ||||||
|  |         const Transform3d &          rotation_matrix, | ||||||
|         std::vector<Lines> &         dir_lines_out, |         std::vector<Lines> &         dir_lines_out, | ||||||
|         const std::vector<FillAdaptive_Internal::CubeProperties> &cubes_properties, |         const std::vector<FillAdaptive_Internal::CubeProperties> &cubes_properties, | ||||||
|         int  depth); |         int  depth); | ||||||
|  | @ -78,7 +79,6 @@ public: | ||||||
|     static void expand_cube( |     static void expand_cube( | ||||||
|         FillAdaptive_Internal::Cube *cube, |         FillAdaptive_Internal::Cube *cube, | ||||||
|         const std::vector<FillAdaptive_Internal::CubeProperties> &cubes_properties, |         const std::vector<FillAdaptive_Internal::CubeProperties> &cubes_properties, | ||||||
|         const Transform3d &             rotation_matrix, |  | ||||||
|         const AABBTreeIndirect::Tree3f &distance_tree, |         const AABBTreeIndirect::Tree3f &distance_tree, | ||||||
|         const TriangleMesh &            triangle_mesh, |         const TriangleMesh &            triangle_mesh, | ||||||
|         int                             depth); |         int                             depth); | ||||||
|  |  | ||||||
|  | @ -444,7 +444,14 @@ std::unique_ptr<FillAdaptive_Internal::Octree> PrintObject::prepare_adaptive_inf | ||||||
|     mesh.translate(- unscale<float>(m_center_offset.x()), - unscale<float>(m_center_offset.y()), 0); |     mesh.translate(- unscale<float>(m_center_offset.x()), - unscale<float>(m_center_offset.y()), 0); | ||||||
|     // Center of the first cube in octree
 |     // Center of the first cube in octree
 | ||||||
|     Vec3d mesh_origin = mesh.bounding_box().center(); |     Vec3d mesh_origin = mesh.bounding_box().center(); | ||||||
|     return FillAdaptive::build_octree(mesh, adaptive_line_spacing, mesh_origin); | 
 | ||||||
|  |     Vec3d rotation = Vec3d((5.0 * M_PI) / 4.0, Geometry::deg2rad(215.264), M_PI / 6.0); | ||||||
|  |     Transform3d rotation_matrix = Geometry::assemble_transform(Vec3d::Zero(), rotation, Vec3d::Ones(), Vec3d::Ones()).inverse(); | ||||||
|  | 
 | ||||||
|  |     // Rotate mesh and build octree on it with axis-aligned (standart base) cubes
 | ||||||
|  |     mesh.transform(rotation_matrix); | ||||||
|  | 
 | ||||||
|  |     return FillAdaptive::build_octree(mesh, adaptive_line_spacing, rotation_matrix * mesh_origin); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void PrintObject::clear_layers() | void PrintObject::clear_layers() | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lukáš Hejl
						Lukáš Hejl