mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-07-08 15:37:30 -06:00
Overhang improvement max vol speed
This commit is contained in:
parent
f2da5b39a1
commit
0b3dfa3f45
1 changed files with 26 additions and 19 deletions
|
@ -4530,28 +4530,35 @@ std::string GCode::_extrude(const ExtrusionPath &path, std::string description,
|
|||
|
||||
if (m_config.enable_overhang_speed && !m_config.overhang_speed_classic && !this->on_first_layer() &&
|
||||
(is_bridge(path.role()) || is_perimeter(path.role()))) {
|
||||
ConfigOptionPercents overhang_overlap_levels({75, 50, 25, 13,12.99,0});
|
||||
double out_wall_ref_speed = m_config.get_abs_value("outer_wall_speed");
|
||||
ConfigOptionPercents overhang_overlap_levels({75, 50, 25, 13, 12.99, 0});
|
||||
ConfigOptionFloatsOrPercents dynamic_overhang_speeds(
|
||||
{(m_config.get_abs_value("overhang_1_4_speed") < 0.5)
|
||||
? FloatOrPercent{100, true}
|
||||
: FloatOrPercent{m_config.get_abs_value("overhang_1_4_speed"), false},
|
||||
(m_config.get_abs_value("overhang_2_4_speed") < 0.5)
|
||||
? FloatOrPercent{100, true}
|
||||
: FloatOrPercent{m_config.get_abs_value("overhang_2_4_speed"), false},
|
||||
(m_config.get_abs_value("overhang_3_4_speed") < 0.5)
|
||||
? FloatOrPercent{100, true}
|
||||
: FloatOrPercent{m_config.get_abs_value("overhang_3_4_speed"), false},
|
||||
(m_config.get_abs_value("overhang_4_4_speed") < 0.5)
|
||||
? FloatOrPercent{100, true}
|
||||
: FloatOrPercent{m_config.get_abs_value("overhang_4_4_speed"), false},
|
||||
FloatOrPercent{m_config.get_abs_value("bridge_speed"), false},
|
||||
FloatOrPercent{m_config.get_abs_value("bridge_speed"), false}});
|
||||
{(m_config.get_abs_value("overhang_1_4_speed") < 0.5) ?
|
||||
FloatOrPercent{100, true} :
|
||||
FloatOrPercent{m_config.get_abs_value("overhang_1_4_speed") * 100 / out_wall_ref_speed, true},
|
||||
(m_config.get_abs_value("overhang_2_4_speed") < 0.5) ?
|
||||
FloatOrPercent{100, true} :
|
||||
FloatOrPercent{m_config.get_abs_value("overhang_2_4_speed") * 100 / out_wall_ref_speed, true},
|
||||
(m_config.get_abs_value("overhang_3_4_speed") < 0.5) ?
|
||||
FloatOrPercent{100, true} :
|
||||
FloatOrPercent{m_config.get_abs_value("overhang_3_4_speed") * 100 / out_wall_ref_speed, true},
|
||||
(m_config.get_abs_value("overhang_4_4_speed") < 0.5) ?
|
||||
FloatOrPercent{100, true} :
|
||||
FloatOrPercent{m_config.get_abs_value("overhang_4_4_speed") * 100 / out_wall_ref_speed, true},
|
||||
FloatOrPercent{m_config.get_abs_value("bridge_speed") * 100 / out_wall_ref_speed, true},
|
||||
FloatOrPercent{m_config.get_abs_value("bridge_speed") * 100 / out_wall_ref_speed, true}});
|
||||
|
||||
new_points = m_extrusion_quality_estimator.estimate_extrusion_quality(
|
||||
path, overhang_overlap_levels, dynamic_overhang_speeds, m_config.get_abs_value("outer_wall_speed"), speed);
|
||||
if (out_wall_ref_speed == 0)
|
||||
out_wall_ref_speed = EXTRUDER_CONFIG(filament_max_volumetric_speed) / _mm3_per_mm;
|
||||
|
||||
variable_speed = std::any_of(new_points.begin(), new_points.end(),
|
||||
[speed](const ProcessedPoint &p) { return p.speed != speed; });
|
||||
if (EXTRUDER_CONFIG(filament_max_volumetric_speed) > 0) {
|
||||
out_wall_ref_speed = std::min(out_wall_ref_speed, EXTRUDER_CONFIG(filament_max_volumetric_speed) / path.mm3_per_mm);
|
||||
}
|
||||
|
||||
new_points = m_extrusion_quality_estimator.estimate_extrusion_quality(path, overhang_overlap_levels, dynamic_overhang_speeds,
|
||||
out_wall_ref_speed, speed);
|
||||
|
||||
variable_speed = std::any_of(new_points.begin(), new_points.end(), [speed](const ProcessedPoint &p) { return p.speed != speed; });
|
||||
}
|
||||
|
||||
double F = speed * 60; // convert mm/sec to mm/min
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue