mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 01:31:14 -06:00 
			
		
		
		
	Merge remote-tracking branch 'origin/master' into ys_unsaved_changes
This commit is contained in:
		
						commit
						15545bbd90
					
				
					 12 changed files with 313 additions and 23 deletions
				
			
		|  | @ -192,6 +192,20 @@ inline BoundingBox3 scaled(const BoundingBoxf3 &bb) { return {scaled(bb.min), sc | |||
| inline BoundingBoxf unscaled(const BoundingBox &bb) { return {unscaled(bb.min), unscaled(bb.max)}; } | ||||
| inline BoundingBoxf3 unscaled(const BoundingBox3 &bb) { return {unscaled(bb.min), unscaled(bb.max)}; } | ||||
| 
 | ||||
| template<class Tout, class Tin> | ||||
| auto cast(const BoundingBoxBase<Tin> &b) | ||||
| { | ||||
|     return BoundingBoxBase<Vec<3, Tout>>{b.min.template cast<Tout>(), | ||||
|                                          b.max.template cast<Tout>()}; | ||||
| } | ||||
| 
 | ||||
| template<class Tout, class Tin> | ||||
| auto cast(const BoundingBox3Base<Tin> &b) | ||||
| { | ||||
|     return BoundingBox3Base<Vec<3, Tout>>{b.min.template cast<Tout>(), | ||||
|                                           b.max.template cast<Tout>()}; | ||||
| } | ||||
| 
 | ||||
| } // namespace Slic3r
 | ||||
| 
 | ||||
| // Serialization through the Cereal library
 | ||||
|  |  | |||
|  | @ -33,24 +33,6 @@ bool Line::intersection_infinite(const Line &other, Point* point) const | |||
|     return true; | ||||
| } | ||||
| 
 | ||||
| // Distance to the closest point of line.
 | ||||
| double Line::distance_to_squared(const Point &point, const Point &a, const Point &b) | ||||
| { | ||||
|     const Vec2d   v  = (b - a).cast<double>(); | ||||
|     const Vec2d   va = (point  - a).cast<double>(); | ||||
|     const double  l2 = v.squaredNorm();  // avoid a sqrt
 | ||||
|     if (l2 == 0.0)  | ||||
|         // a == b case
 | ||||
|         return va.squaredNorm(); | ||||
|     // Consider the line extending the segment, parameterized as a + t (b - a).
 | ||||
|     // We find projection of this point onto the line. 
 | ||||
|     // It falls where t = [(this-a) . (b-a)] / |b-a|^2
 | ||||
|     const double t = va.dot(v) / l2; | ||||
|     if (t < 0.0)      return va.squaredNorm();  // beyond the 'a' end of the segment
 | ||||
|     else if (t > 1.0) return (point - b).cast<double>().squaredNorm();  // beyond the 'b' end of the segment
 | ||||
|     return (t * v - va).squaredNorm(); | ||||
| } | ||||
| 
 | ||||
| double Line::perp_distance_to(const Point &point) const | ||||
| { | ||||
|     const Line  &line = *this; | ||||
|  |  | |||
|  | @ -18,6 +18,35 @@ typedef std::vector<ThickLine> ThickLines; | |||
| 
 | ||||
| Linef3 transform(const Linef3& line, const Transform3d& t); | ||||
| 
 | ||||
| namespace line_alg { | ||||
| 
 | ||||
| // Distance to the closest point of line.
 | ||||
| template<class L, class T, int N> | ||||
| double distance_to_squared(const L &line, const Vec<N, T> &point) | ||||
| { | ||||
|     const Vec<N, double>  v  = line.vector().template cast<double>(); | ||||
|     const Vec<N, double>  va = (point  - line.a).template cast<double>(); | ||||
|     const double  l2 = v.squaredNorm();  // avoid a sqrt
 | ||||
|     if (l2 == 0.0) | ||||
|         // a == b case
 | ||||
|         return va.squaredNorm(); | ||||
|     // Consider the line extending the segment, parameterized as a + t (b - a).
 | ||||
|     // We find projection of this point onto the line.
 | ||||
|     // It falls where t = [(this-a) . (b-a)] / |b-a|^2
 | ||||
|     const double t = va.dot(v) / l2; | ||||
|     if (t < 0.0)      return va.squaredNorm();  // beyond the 'a' end of the segment
 | ||||
|     else if (t > 1.0) return (point - line.b).template cast<double>().squaredNorm();  // beyond the 'b' end of the segment
 | ||||
|     return (t * v - va).squaredNorm(); | ||||
| } | ||||
| 
 | ||||
| template<class L, class T, int N> | ||||
| double distance_to(const L &line, const Vec<N, T> &point) | ||||
| { | ||||
|     return std::sqrt(distance_to_squared(line, point)); | ||||
| } | ||||
| 
 | ||||
| } // namespace line_alg
 | ||||
| 
 | ||||
| class Line | ||||
| { | ||||
| public: | ||||
|  | @ -47,7 +76,7 @@ public: | |||
|     // Clip a line with a bounding box. Returns false if the line is completely outside of the bounding box.
 | ||||
| 	bool   clip_with_bbox(const BoundingBox &bbox); | ||||
| 
 | ||||
|     static double distance_to_squared(const Point &point, const Point &a, const Point &b); | ||||
|     static inline double distance_to_squared(const Point &point, const Point &a, const Point &b) { return line_alg::distance_to_squared(Line{a, b}, Vec<2, coord_t>{point}); } | ||||
|     static double distance_to(const Point &point, const Point &a, const Point &b) { return sqrt(distance_to_squared(point, a, b)); } | ||||
| 
 | ||||
|     Point a; | ||||
|  |  | |||
|  | @ -88,6 +88,8 @@ inline std::string to_string(const Vec3d   &pt) { return std::string("[") + std: | |||
| std::vector<Vec3f> transform(const std::vector<Vec3f>& points, const Transform3f& t); | ||||
| Pointf3s transform(const Pointf3s& points, const Transform3d& t); | ||||
| 
 | ||||
| template<int N, class T> using Vec = Eigen::Matrix<T,  N, 1, Eigen::DontAlign, N, 1>; | ||||
| 
 | ||||
| class Point : public Vec2crd | ||||
| { | ||||
| public: | ||||
|  |  | |||
|  | @ -273,4 +273,13 @@ void cut_drainholes(std::vector<ExPolygons> & obj_slices, | |||
|         obj_slices[i] = diff_ex(obj_slices[i], hole_slices[i]); | ||||
| } | ||||
| 
 | ||||
| void hollow_mesh(TriangleMesh &mesh, const HollowingConfig &cfg) | ||||
| { | ||||
|     std::unique_ptr<Slic3r::TriangleMesh> inter_ptr = | ||||
|             Slic3r::sla::generate_interior(mesh); | ||||
| 
 | ||||
|     if (inter_ptr) mesh.merge(*inter_ptr); | ||||
|     mesh.require_shared_vertices(); | ||||
| } | ||||
| 
 | ||||
| }} // namespace Slic3r::sla
 | ||||
|  |  | |||
|  | @ -62,6 +62,8 @@ std::unique_ptr<TriangleMesh> generate_interior(const TriangleMesh &mesh, | |||
|                                                 const HollowingConfig &  = {}, | ||||
|                                                 const JobController &ctl = {}); | ||||
| 
 | ||||
| void hollow_mesh(TriangleMesh &mesh, const HollowingConfig &cfg); | ||||
| 
 | ||||
| void cut_drainholes(std::vector<ExPolygons> & obj_slices, | ||||
|                     const std::vector<float> &slicegrid, | ||||
|                     float                     closing_radius, | ||||
|  |  | |||
|  | @ -362,7 +362,7 @@ bool ImGuiWrapper::checkbox(const wxString &label, bool &value) | |||
| 
 | ||||
| void ImGuiWrapper::text(const char *label) | ||||
| { | ||||
|     ImGui::Text(label, NULL); | ||||
|     ImGui::Text("%s", label); | ||||
| } | ||||
| 
 | ||||
| void ImGuiWrapper::text(const std::string &label) | ||||
|  | @ -378,7 +378,7 @@ void ImGuiWrapper::text(const wxString &label) | |||
| 
 | ||||
| void ImGuiWrapper::text_colored(const ImVec4& color, const char* label) | ||||
| { | ||||
|     ImGui::TextColored(color, label); | ||||
|     ImGui::TextColored(color, "%s", label); | ||||
| } | ||||
| 
 | ||||
| void ImGuiWrapper::text_colored(const ImVec4& color, const std::string& label) | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 YuSanka
						YuSanka