mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-23 16:51:21 -06:00
Merge remote-tracking branch 'remotes/origin/lm_brimskirt'
This commit is contained in:
commit
bb896b4c13
2 changed files with 67 additions and 9 deletions
|
@ -1853,8 +1853,9 @@ void GCode::process_layer(
|
|||
if (! m_brim_done) {
|
||||
this->set_origin(0., 0.);
|
||||
m_avoid_crossing_perimeters.use_external_mp = true;
|
||||
for (const ExtrusionEntity *ee : print.brim().entities)
|
||||
gcode += this->extrude_loop(*dynamic_cast<const ExtrusionLoop*>(ee), "brim", m_config.support_material_speed.value);
|
||||
for (const ExtrusionEntity *ee : print.brim().entities) {
|
||||
gcode += this->extrude_entity(*ee, "brim", m_config.support_material_speed.value);
|
||||
}
|
||||
m_brim_done = true;
|
||||
m_avoid_crossing_perimeters.use_external_mp = false;
|
||||
// Allow a straight travel move to the first object point.
|
||||
|
@ -2520,10 +2521,9 @@ std::string GCode::extrude_entity(const ExtrusionEntity &entity, std::string des
|
|||
return this->extrude_multi_path(*multipath, description, speed);
|
||||
else if (const ExtrusionLoop* loop = dynamic_cast<const ExtrusionLoop*>(&entity))
|
||||
return this->extrude_loop(*loop, description, speed, lower_layer_edge_grid);
|
||||
else {
|
||||
else
|
||||
throw std::invalid_argument("Invalid argument supplied to extrude()");
|
||||
return "";
|
||||
}
|
||||
return "";
|
||||
}
|
||||
|
||||
std::string GCode::extrude_path(ExtrusionPath path, std::string description, double speed)
|
||||
|
|
|
@ -1628,9 +1628,7 @@ void Print::_make_skirt()
|
|||
|
||||
// Initial offset of the brim inner edge from the object (possible with a support & raft).
|
||||
// The skirt will touch the brim if the brim is extruded.
|
||||
Flow brim_flow = this->brim_flow();
|
||||
double actual_brim_width = brim_flow.spacing() * floor(m_config.brim_width.value / brim_flow.spacing());
|
||||
auto distance = float(scale_(std::max(m_config.skirt_distance.value, actual_brim_width) - spacing/2.));
|
||||
auto distance = float(scale_(m_config.skirt_distance.value) - spacing/2.);
|
||||
// Draw outlines from outside to inside.
|
||||
// Loop while we have less skirts than required or any extruder hasn't reached the min length if any.
|
||||
std::vector<coordf_t> extruded_length(extruders.size(), 0.);
|
||||
|
@ -1712,11 +1710,71 @@ void Print::_make_brim()
|
|||
}
|
||||
polygons_append(loops, offset(islands, -0.5f * float(flow.scaled_spacing())));
|
||||
}
|
||||
|
||||
loops = union_pt_chained(loops, false);
|
||||
// The function above produces ordering well suited for concentric infill (from outside to inside).
|
||||
// For Brim, the ordering should be reversed (from inside to outside).
|
||||
std::reverse(loops.begin(), loops.end());
|
||||
|
||||
// If there is a possibility that brim intersects skirt, go through loops and split those extrusions
|
||||
// The result is either the original Polygon or a list of Polylines
|
||||
if (! m_skirt.empty() && m_config.skirt_distance.value < m_config.brim_width)
|
||||
{
|
||||
// Find the bounding polygons of the skirt
|
||||
const Polygons skirt_inners = offset(dynamic_cast<ExtrusionLoop*>(m_skirt.entities.back())->polygon(),
|
||||
-float(scale_(this->skirt_flow().spacing()))/2.f,
|
||||
ClipperLib::jtRound,
|
||||
float(scale_(0.1)));
|
||||
const Polygons skirt_outers = offset(dynamic_cast<ExtrusionLoop*>(m_skirt.entities.front())->polygon(),
|
||||
float(scale_(this->skirt_flow().spacing()))/2.f,
|
||||
ClipperLib::jtRound,
|
||||
float(scale_(0.1)));
|
||||
|
||||
const Polygon& skirt_inner = skirt_inners.front();
|
||||
const Polygon& skirt_outer = skirt_outers.front();
|
||||
|
||||
for (size_t i=0; i<loops.size(); ++i) {
|
||||
Polylines lines;
|
||||
lines.push_back(Polyline());
|
||||
bool del = false;
|
||||
const Polygon& poly = loops[i];
|
||||
// Check all points of the polygon, consider the first to also be at the end so the loop is closed
|
||||
for (int pt_idx=0; pt_idx <= (int)poly.points.size(); ++pt_idx) {
|
||||
const Point* pt = (pt_idx == (int)poly.points.size() ? &poly.points[0] : &poly.points[pt_idx]);
|
||||
const Point* last_pt = (pt_idx == 0 ? nullptr : &poly.points[pt_idx-1]);
|
||||
bool valid_point = skirt_inner.contains(*pt) || ! skirt_outer.contains(*pt);
|
||||
Points intersections(2); // inner and outer intersection
|
||||
|
||||
if (pt_idx > 0) {
|
||||
Line line(*last_pt, *pt);
|
||||
bool inner = skirt_inner.first_intersection(line, &intersections[0]);
|
||||
bool outer = skirt_outer.first_intersection(line, &intersections[1]);
|
||||
del = del || inner || outer;
|
||||
if (inner != outer) {// there is exactly one intersection
|
||||
lines.back().append(inner ? intersections[0] : intersections[1]);
|
||||
}
|
||||
if (inner && outer) {
|
||||
int nearest_idx = pt->nearest_point_index(intersections);
|
||||
lines.back().append(intersections[! nearest_idx]);
|
||||
lines.push_back(Polyline());
|
||||
lines.back().append(intersections[nearest_idx]);
|
||||
}
|
||||
}
|
||||
if (valid_point)
|
||||
lines.back().append(*pt);
|
||||
else {
|
||||
del = true;
|
||||
lines.push_back(Polyline());
|
||||
}
|
||||
}
|
||||
// If we found a single intersection, we should erase the respective ExtrusionLoop
|
||||
// and append the polylines that we created.
|
||||
if (del) {
|
||||
loops.erase(loops.begin() + (i--));
|
||||
extrusion_entities_append_paths(m_brim.entities, std::move(lines), erSkirt, float(flow.mm3_per_mm()), float(flow.width), float(this->skirt_first_layer_height()));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
extrusion_entities_append_loops(m_brim.entities, std::move(loops), erSkirt, float(flow.mm3_per_mm()), float(flow.width), float(this->skirt_first_layer_height()));
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue