#ifndef slic3r_ShortestPath_hpp_ #define slic3r_ShortestPath_hpp_ #include "libslic3r.h" #include "ExtrusionEntity.hpp" #include "Point.hpp" #include #include namespace ClipperLib { class PolyNode; } namespace Slic3r { std::vector chain_points(const Points &points, Point *start_near = nullptr); std::vector chain_expolygons(const ExPolygons &input_exploy); std::vector> chain_extrusion_entities(std::vector &entities, const Point *start_near = nullptr); void reorder_extrusion_entities(std::vector &entities, const std::vector> &chain); void chain_and_reorder_extrusion_entities(std::vector &entities, const Point *start_near = nullptr); std::vector> chain_extrusion_paths(std::vector &extrusion_paths, const Point *start_near = nullptr); void reorder_extrusion_paths(std::vector &extrusion_paths, std::vector> &chain); void chain_and_reorder_extrusion_paths(std::vector &extrusion_paths, const Point *start_near = nullptr); Polylines chain_polylines(Polylines &&src, const Point *start_near = nullptr); inline Polylines chain_polylines(const Polylines& src, const Point* start_near = nullptr) { Polylines tmp(src); return chain_polylines(std::move(tmp), start_near); } template inline void reorder_by_shortest_traverse(std::vector &polylines_out) { Points start_point; start_point.reserve(polylines_out.size()); for (const T contour : polylines_out) start_point.push_back(contour.points.front()); std::vector order = chain_points(start_point); std::vector Temp = polylines_out; polylines_out.erase(polylines_out.begin(), polylines_out.end()); for (size_t i:order) polylines_out.emplace_back(std::move(Temp[i])); } std::vector chain_clipper_polynodes(const Points &points, const std::vector &items); // Chain instances of print objects by an approximate shortest path. // Returns pairs of PrintObject idx and instance of that PrintObject. class Print; struct PrintInstance; // BBS class PrintObject; std::vector chain_print_object_instances(const std::vector& print_objects, const Point* start_near); std::vector chain_print_object_instances(const Print &print); // Chain lines into polylines. Polylines chain_lines(const std::vector &lines, const double point_distance_epsilon); } // namespace Slic3r #endif /* slic3r_ShortestPath_hpp_ */