2014-08-03 17:28:40 +00:00
|
|
|
#include "Print.hpp"
|
|
|
|
|
|
|
|
namespace Slic3r {
|
|
|
|
|
2018-03-28 15:05:31 +00:00
|
|
|
Flow PrintRegion::flow(FlowRole role, double layer_height, bool bridge, bool first_layer, double width, const PrintObject &object) const
|
2014-08-03 17:28:40 +00:00
|
|
|
{
|
|
|
|
ConfigOptionFloatOrPercent config_width;
|
|
|
|
if (width != -1) {
|
|
|
|
// use the supplied custom width, if any
|
|
|
|
config_width.value = width;
|
|
|
|
config_width.percent = false;
|
|
|
|
} else {
|
|
|
|
// otherwise, get extrusion width from configuration
|
|
|
|
// (might be an absolute value, or a percent value, or zero for auto)
|
2018-09-11 12:04:47 +00:00
|
|
|
if (first_layer && m_print->config().first_layer_extrusion_width.value > 0) {
|
|
|
|
config_width = m_print->config().first_layer_extrusion_width;
|
2014-08-03 17:28:40 +00:00
|
|
|
} else if (role == frExternalPerimeter) {
|
2018-09-11 12:04:47 +00:00
|
|
|
config_width = m_config.external_perimeter_extrusion_width;
|
2014-08-03 17:28:40 +00:00
|
|
|
} else if (role == frPerimeter) {
|
2018-09-11 12:04:47 +00:00
|
|
|
config_width = m_config.perimeter_extrusion_width;
|
2014-08-03 17:28:40 +00:00
|
|
|
} else if (role == frInfill) {
|
2018-09-11 12:04:47 +00:00
|
|
|
config_width = m_config.infill_extrusion_width;
|
2014-08-03 17:28:40 +00:00
|
|
|
} else if (role == frSolidInfill) {
|
2018-09-11 12:04:47 +00:00
|
|
|
config_width = m_config.solid_infill_extrusion_width;
|
2014-08-03 17:28:40 +00:00
|
|
|
} else if (role == frTopSolidInfill) {
|
2018-09-11 12:04:47 +00:00
|
|
|
config_width = m_config.top_infill_extrusion_width;
|
2014-08-03 17:28:40 +00:00
|
|
|
} else {
|
2018-09-18 08:09:58 +00:00
|
|
|
throw std::invalid_argument("Unknown role");
|
2014-08-03 17:28:40 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if (config_width.value == 0) {
|
2018-09-11 12:04:47 +00:00
|
|
|
config_width = object.config().extrusion_width;
|
2014-08-03 17:28:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// get the configured nozzle_diameter for the extruder associated
|
|
|
|
// to the flow role requested
|
2015-08-23 19:18:44 +00:00
|
|
|
size_t extruder = 0; // 1-based
|
2014-08-03 17:28:40 +00:00
|
|
|
if (role == frPerimeter || role == frExternalPerimeter) {
|
2018-09-11 12:04:47 +00:00
|
|
|
extruder = m_config.perimeter_extruder;
|
2014-12-16 23:34:00 +00:00
|
|
|
} else if (role == frInfill) {
|
2018-09-11 12:04:47 +00:00
|
|
|
extruder = m_config.infill_extruder;
|
2014-12-16 23:34:00 +00:00
|
|
|
} else if (role == frSolidInfill || role == frTopSolidInfill) {
|
2018-09-11 12:04:47 +00:00
|
|
|
extruder = m_config.solid_infill_extruder;
|
2014-08-03 17:28:40 +00:00
|
|
|
} else {
|
2018-09-18 08:09:58 +00:00
|
|
|
throw std::invalid_argument("Unknown role");
|
2014-08-03 17:28:40 +00:00
|
|
|
}
|
2018-09-11 12:04:47 +00:00
|
|
|
double nozzle_diameter = m_print->config().nozzle_diameter.get_at(extruder-1);
|
2014-08-03 17:28:40 +00:00
|
|
|
|
2018-09-11 12:04:47 +00:00
|
|
|
return Flow::new_from_config_width(role, config_width, nozzle_diameter, layer_height, bridge ? (float)m_config.bridge_flow_ratio : 0.0);
|
2014-08-03 17:28:40 +00:00
|
|
|
}
|
|
|
|
|
2017-03-28 11:25:10 +00:00
|
|
|
coordf_t PrintRegion::nozzle_dmr_avg(const PrintConfig &print_config) const
|
|
|
|
{
|
2018-09-11 12:04:47 +00:00
|
|
|
return (print_config.nozzle_diameter.get_at(m_config.perimeter_extruder.value - 1) +
|
|
|
|
print_config.nozzle_diameter.get_at(m_config.infill_extruder.value - 1) +
|
|
|
|
print_config.nozzle_diameter.get_at(m_config.solid_infill_extruder.value - 1)) / 3.;
|
2017-03-28 11:25:10 +00:00
|
|
|
}
|
|
|
|
|
2018-09-17 13:12:13 +00:00
|
|
|
coordf_t PrintRegion::bridging_height_avg(const PrintConfig &print_config) const
|
|
|
|
{
|
|
|
|
return this->nozzle_dmr_avg(print_config) * sqrt(m_config.bridge_flow_ratio.value);
|
|
|
|
}
|
|
|
|
|
2019-01-21 09:06:51 +00:00
|
|
|
void PrintRegion::collect_object_printing_extruders(const PrintConfig &print_config, const PrintRegionConfig ®ion_config, std::vector<unsigned int> &object_extruders)
|
|
|
|
{
|
|
|
|
// These checks reflect the same logic used in the GUI for enabling/disabling extruder selection fields.
|
|
|
|
if (region_config.perimeters.value > 0 || print_config.brim_width.value > 0)
|
|
|
|
object_extruders.emplace_back(region_config.perimeter_extruder - 1);
|
|
|
|
if (region_config.fill_density.value > 0)
|
|
|
|
object_extruders.emplace_back(region_config.infill_extruder - 1);
|
|
|
|
if (region_config.top_solid_layers.value > 0 || region_config.bottom_solid_layers.value > 0)
|
|
|
|
object_extruders.emplace_back(region_config.solid_infill_extruder - 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
void PrintRegion::collect_object_printing_extruders(std::vector<unsigned int> &object_extruders) const
|
|
|
|
{
|
|
|
|
collect_object_printing_extruders(print()->config(), this->config(), object_extruders);
|
|
|
|
}
|
|
|
|
|
2014-08-03 17:28:40 +00:00
|
|
|
}
|