mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-23 16:51:21 -06:00
Merge branch 'master' of https://github.com/prusa3d/PrusaSlicer into et_sequential_limits
This commit is contained in:
commit
858ea16b95
1 changed files with 30 additions and 6 deletions
|
@ -893,6 +893,30 @@ Polygon ModelObject::convex_hull_2d(const Transform3d &trafo_instance) const
|
||||||
Points pts;
|
Points pts;
|
||||||
for (const ModelVolume *v : this->volumes)
|
for (const ModelVolume *v : this->volumes)
|
||||||
if (v->is_model_part()) {
|
if (v->is_model_part()) {
|
||||||
|
#if ENABLE_ALLOW_NEGATIVE_Z
|
||||||
|
const Transform3d trafo = trafo_instance * v->get_matrix();
|
||||||
|
const TriangleMesh& hull_3d = v->get_convex_hull();
|
||||||
|
const indexed_triangle_set& its = hull_3d.its;
|
||||||
|
if (its.vertices.empty()) {
|
||||||
|
// Using the STL faces.
|
||||||
|
const stl_file& stl = hull_3d.stl;
|
||||||
|
for (const stl_facet& facet : stl.facet_start) {
|
||||||
|
for (size_t j = 0; j < 3; ++j) {
|
||||||
|
const Vec3d p = trafo * facet.vertex[j].cast<double>();
|
||||||
|
if (p.z() >= 0.0)
|
||||||
|
pts.emplace_back(coord_t(scale_(p.x())), coord_t(scale_(p.y())));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// Using the shared vertices should be a bit quicker than using the STL faces.
|
||||||
|
for (size_t i = 0; i < its.vertices.size(); ++i) {
|
||||||
|
const Vec3d p = trafo * its.vertices[i].cast<double>();
|
||||||
|
if (p.z() >= 0.0)
|
||||||
|
pts.emplace_back(coord_t(scale_(p.x())), coord_t(scale_(p.y())));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#else
|
||||||
Transform3d trafo = trafo_instance * v->get_matrix();
|
Transform3d trafo = trafo_instance * v->get_matrix();
|
||||||
const indexed_triangle_set &its = v->mesh().its;
|
const indexed_triangle_set &its = v->mesh().its;
|
||||||
if (its.vertices.empty()) {
|
if (its.vertices.empty()) {
|
||||||
|
@ -901,21 +925,16 @@ Polygon ModelObject::convex_hull_2d(const Transform3d &trafo_instance) const
|
||||||
for (const stl_facet &facet : stl.facet_start)
|
for (const stl_facet &facet : stl.facet_start)
|
||||||
for (size_t j = 0; j < 3; ++ j) {
|
for (size_t j = 0; j < 3; ++ j) {
|
||||||
Vec3d p = trafo * facet.vertex[j].cast<double>();
|
Vec3d p = trafo * facet.vertex[j].cast<double>();
|
||||||
#if ENABLE_ALLOW_NEGATIVE_Z
|
|
||||||
if (p.z() >= 0.0)
|
|
||||||
#endif // ENABLE_ALLOW_NEGATIVE_Z
|
|
||||||
pts.emplace_back(coord_t(scale_(p.x())), coord_t(scale_(p.y())));
|
pts.emplace_back(coord_t(scale_(p.x())), coord_t(scale_(p.y())));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// Using the shared vertices should be a bit quicker than using the STL faces.
|
// Using the shared vertices should be a bit quicker than using the STL faces.
|
||||||
for (size_t i = 0; i < its.vertices.size(); ++ i) {
|
for (size_t i = 0; i < its.vertices.size(); ++ i) {
|
||||||
Vec3d p = trafo * its.vertices[i].cast<double>();
|
Vec3d p = trafo * its.vertices[i].cast<double>();
|
||||||
#if ENABLE_ALLOW_NEGATIVE_Z
|
|
||||||
if (p.z() >= 0.0)
|
|
||||||
#endif // ENABLE_ALLOW_NEGATIVE_Z
|
|
||||||
pts.emplace_back(coord_t(scale_(p.x())), coord_t(scale_(p.y())));
|
pts.emplace_back(coord_t(scale_(p.x())), coord_t(scale_(p.y())));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif // ENABLE_ALLOW_NEGATIVE_Z
|
||||||
}
|
}
|
||||||
std::sort(pts.begin(), pts.end(), [](const Point& a, const Point& b) { return a(0) < b(0) || (a(0) == b(0) && a(1) < b(1)); });
|
std::sort(pts.begin(), pts.end(), [](const Point& a, const Point& b) { return a(0) < b(0) || (a(0) == b(0) && a(1) < b(1)); });
|
||||||
pts.erase(std::unique(pts.begin(), pts.end(), [](const Point& a, const Point& b) { return a(0) == b(0) && a(1) == b(1); }), pts.end());
|
pts.erase(std::unique(pts.begin(), pts.end(), [](const Point& a, const Point& b) { return a(0) == b(0) && a(1) == b(1); }), pts.end());
|
||||||
|
@ -1906,8 +1925,13 @@ arrangement::ArrangePolygon ModelInstance::get_arrange_polygon() const
|
||||||
Vec3d rotation = get_rotation();
|
Vec3d rotation = get_rotation();
|
||||||
rotation.z() = 0.;
|
rotation.z() = 0.;
|
||||||
Transform3d trafo_instance =
|
Transform3d trafo_instance =
|
||||||
|
#if ENABLE_ALLOW_NEGATIVE_Z
|
||||||
|
Geometry::assemble_transform(get_offset().z() * Vec3d::UnitZ(), rotation,
|
||||||
|
get_scaling_factor(), get_mirror());
|
||||||
|
#else
|
||||||
Geometry::assemble_transform(Vec3d::Zero(), rotation,
|
Geometry::assemble_transform(Vec3d::Zero(), rotation,
|
||||||
get_scaling_factor(), get_mirror());
|
get_scaling_factor(), get_mirror());
|
||||||
|
#endif // ENABLE_ALLOW_NEGATIVE_Z
|
||||||
|
|
||||||
Polygon p = get_object()->convex_hull_2d(trafo_instance);
|
Polygon p = get_object()->convex_hull_2d(trafo_instance);
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue