mirror of
https://git.mirrors.martin98.com/https://github.com/prusa3d/PrusaSlicer.git
synced 2025-08-02 02:50:37 +08:00
38 lines
1.1 KiB
C++
38 lines
1.1 KiB
C++
///|/ Copyright (c) Prusa Research 2022 Vojtěch Bubník @bubnikv
|
|
///|/
|
|
///|/ PrusaSlicer is released under the terms of the AGPLv3 or higher
|
|
///|/
|
|
#ifndef slic3r_RetractWhenCrossingPerimeters_hpp_
|
|
#define slic3r_RetractWhenCrossingPerimeters_hpp_
|
|
|
|
#include <vector>
|
|
|
|
#include "../AABBTreeIndirect.hpp"
|
|
#include "libslic3r/libslic3r.h"
|
|
|
|
namespace Slic3r {
|
|
|
|
// Forward declarations.
|
|
class ExPolygon;
|
|
class Layer;
|
|
class Polyline;
|
|
|
|
class RetractWhenCrossingPerimeters
|
|
{
|
|
public:
|
|
bool travel_inside_internal_regions(const Layer &layer, const Polyline &travel);
|
|
|
|
private:
|
|
// Last object layer visited, for which a cache of internal islands was created.
|
|
const Layer *m_layer;
|
|
// Internal islands only, referencing data owned by m_layer->regions()->surfaces().
|
|
std::vector<const ExPolygon*> m_internal_islands;
|
|
// Search structure over internal islands.
|
|
using AABBTree = AABBTreeIndirect::Tree<2, coord_t>;
|
|
AABBTree m_aabbtree_internal_islands;
|
|
};
|
|
|
|
} // namespace Slic3r
|
|
|
|
#endif // slic3r_RetractWhenCrossingPerimeters_hpp_
|