mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-23 16:51:21 -06:00
First naive prototype of seam painter
This commit is contained in:
parent
60cf002e94
commit
7844ca12fa
2 changed files with 77 additions and 0 deletions
|
@ -175,6 +175,32 @@ namespace Slic3r {
|
||||||
return islands;
|
return islands;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int CustomSeam::get_point_status(const Point& pt, size_t layer_id) const
|
||||||
|
{
|
||||||
|
// TEMPORARY - WILL BE IMPROVED
|
||||||
|
// - quadratic algorithm
|
||||||
|
// - does not support variable layer height
|
||||||
|
|
||||||
|
if (! enforcers.empty()) {
|
||||||
|
assert(layer_id < enforcers.size());
|
||||||
|
for (const ExPolygon& explg : enforcers[layer_id]) {
|
||||||
|
if (explg.contains(pt))
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (! blockers.empty()) {
|
||||||
|
assert(layer_id < blockers.size());
|
||||||
|
for (const ExPolygon& explg : blockers[layer_id]) {
|
||||||
|
if (explg.contains(pt))
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
std::string OozePrevention::pre_toolchange(GCode& gcodegen)
|
std::string OozePrevention::pre_toolchange(GCode& gcodegen)
|
||||||
{
|
{
|
||||||
std::string gcode;
|
std::string gcode;
|
||||||
|
@ -984,6 +1010,22 @@ namespace DoExport {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void collect_custom_seam(const Print& print, CustomSeam& custom_seam)
|
||||||
|
{
|
||||||
|
custom_seam = CustomSeam();
|
||||||
|
for (const PrintObject* po : print.objects()) {
|
||||||
|
po->project_and_append_custom_facets(true, EnforcerBlockerType::ENFORCER, custom_seam.enforcers);
|
||||||
|
po->project_and_append_custom_facets(true, EnforcerBlockerType::BLOCKER, custom_seam.blockers);
|
||||||
|
}
|
||||||
|
for (ExPolygons& explgs : custom_seam.enforcers) {
|
||||||
|
explgs = Slic3r::offset_ex(explgs, scale_(0.5));
|
||||||
|
}
|
||||||
|
for (ExPolygons& explgs : custom_seam.blockers) {
|
||||||
|
explgs = Slic3r::offset_ex(explgs, scale_(0.5));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static void init_ooze_prevention(const Print &print, OozePrevention &ooze_prevention)
|
static void init_ooze_prevention(const Print &print, OozePrevention &ooze_prevention)
|
||||||
{
|
{
|
||||||
// Calculate wiping points if needed
|
// Calculate wiping points if needed
|
||||||
|
@ -1437,6 +1479,9 @@ void GCode::_do_export(Print& print, FILE* file, ThumbnailsGeneratorCallback thu
|
||||||
DoExport::init_ooze_prevention(print, m_ooze_prevention);
|
DoExport::init_ooze_prevention(print, m_ooze_prevention);
|
||||||
print.throw_if_canceled();
|
print.throw_if_canceled();
|
||||||
|
|
||||||
|
// Collect custom seam data from all objects.
|
||||||
|
DoExport::collect_custom_seam(print, m_custom_seam);
|
||||||
|
|
||||||
if (! (has_wipe_tower && print.config().single_extruder_multi_material_priming)) {
|
if (! (has_wipe_tower && print.config().single_extruder_multi_material_priming)) {
|
||||||
// Set initial extruder only after custom start G-code.
|
// Set initial extruder only after custom start G-code.
|
||||||
// Ugly hack: Do not set the initial extruder if the extruder is primed using the MMU priming towers at the edge of the print bed.
|
// Ugly hack: Do not set the initial extruder if the extruder is primed using the MMU priming towers at the edge of the print bed.
|
||||||
|
@ -2841,6 +2886,13 @@ std::string GCode::extrude_loop(ExtrusionLoop loop, std::string description, dou
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Penalty according to custom seam selection. This one is huge compared to
|
||||||
|
// the others so that points outside enforcers/inside blockers never win.
|
||||||
|
for (size_t i = 0; i < polygon.points.size(); ++ i) {
|
||||||
|
const Point &p = polygon.points[i];
|
||||||
|
penalties[i] -= float(100000 * m_custom_seam.get_point_status(p, m_layer->id()));
|
||||||
|
}
|
||||||
|
|
||||||
// Find a point with a minimum penalty.
|
// Find a point with a minimum penalty.
|
||||||
size_t idx_min = std::min_element(penalties.begin(), penalties.end()) - penalties.begin();
|
size_t idx_min = std::min_element(penalties.begin(), penalties.end()) - penalties.begin();
|
||||||
|
|
||||||
|
@ -2862,6 +2914,19 @@ std::string GCode::extrude_loop(ExtrusionLoop loop, std::string description, dou
|
||||||
m_seam_position[m_layer->object()] = polygon.points[idx_min];
|
m_seam_position[m_layer->object()] = polygon.points[idx_min];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//////////////////////
|
||||||
|
// int layer_id = m_layer->id();
|
||||||
|
// std::ostringstream os;
|
||||||
|
// os << std::setw(3) << std::setfill('0') << layer_id;
|
||||||
|
// int a = scale_(15.);
|
||||||
|
// SVG svg("custom_seam" + os.str() + ".svg", BoundingBox(Point(-a, -a), Point(a, a)));
|
||||||
|
// if (! m_custom_seam.enforcers.empty())
|
||||||
|
// svg.draw(m_custom_seam.enforcers[layer_id], "blue");
|
||||||
|
// if (! m_custom_seam.blockers.empty())
|
||||||
|
// svg.draw(m_custom_seam.blockers[layer_id], "red");
|
||||||
|
// svg.draw(polygon.points, "black");
|
||||||
|
////////////////////
|
||||||
|
|
||||||
|
|
||||||
// Export the contour into a SVG file.
|
// Export the contour into a SVG file.
|
||||||
#if 0
|
#if 0
|
||||||
|
|
|
@ -70,6 +70,15 @@ private:
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
struct CustomSeam {
|
||||||
|
std::vector<ExPolygons> enforcers;
|
||||||
|
std::vector<ExPolygons> blockers;
|
||||||
|
|
||||||
|
// Finds whether the point is inside an enforcer/blockers.
|
||||||
|
// Returns +1, 0 or -1.
|
||||||
|
int get_point_status(const Point& pt, size_t layer_id) const;
|
||||||
|
};
|
||||||
|
|
||||||
class OozePrevention {
|
class OozePrevention {
|
||||||
public:
|
public:
|
||||||
bool enable;
|
bool enable;
|
||||||
|
@ -339,6 +348,9 @@ private:
|
||||||
std::string unretract() { return m_writer.unlift() + m_writer.unretract(); }
|
std::string unretract() { return m_writer.unlift() + m_writer.unretract(); }
|
||||||
std::string set_extruder(unsigned int extruder_id, double print_z);
|
std::string set_extruder(unsigned int extruder_id, double print_z);
|
||||||
|
|
||||||
|
// Cache for custom seam enforcers/blockers for each layer.
|
||||||
|
CustomSeam m_custom_seam;
|
||||||
|
|
||||||
/* Origin of print coordinates expressed in unscaled G-code coordinates.
|
/* Origin of print coordinates expressed in unscaled G-code coordinates.
|
||||||
This affects the input arguments supplied to the extrude*() and travel_to()
|
This affects the input arguments supplied to the extrude*() and travel_to()
|
||||||
methods. */
|
methods. */
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue