mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-23 16:51:21 -06:00
Fixed regression in --infill-only-where-needed. Includes a minimal test suite for such feature. #1871
This commit is contained in:
parent
859bf46401
commit
a0133ba093
3 changed files with 55 additions and 8 deletions
|
@ -411,7 +411,7 @@ sub clip_fill_surfaces {
|
||||||
# We only want infill under ceilings; this is almost like an
|
# We only want infill under ceilings; this is almost like an
|
||||||
# internal support material.
|
# internal support material.
|
||||||
|
|
||||||
my $additional_margin = scale 3;
|
my $additional_margin = scale 3*0;
|
||||||
|
|
||||||
my $overhangs = []; # arrayref of polygons
|
my $overhangs = []; # arrayref of polygons
|
||||||
for my $layer_id (reverse 0..$#{$self->layers}) {
|
for my $layer_id (reverse 0..$#{$self->layers}) {
|
||||||
|
@ -450,10 +450,11 @@ sub clip_fill_surfaces {
|
||||||
# (thus we also consider perimeters)
|
# (thus we also consider perimeters)
|
||||||
if ($layer_id > 0) {
|
if ($layer_id > 0) {
|
||||||
my $solid = diff(
|
my $solid = diff(
|
||||||
[ map @$_, @{$layer->slices} ],
|
[ map $_->p, map @{$_->fill_surfaces}, @{$layer->regions} ],
|
||||||
[ map $_->p, @layer_internal ],
|
[ map $_->p, @layer_internal ],
|
||||||
);
|
);
|
||||||
$overhangs = offset($solid, +$additional_margin);
|
$overhangs = offset($solid, +$additional_margin);
|
||||||
|
|
||||||
push @$overhangs, map $_->p, @new_internal; # propagate upper overhangs
|
push @$overhangs, map $_->p, @new_internal; # propagate upper overhangs
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
File diff suppressed because one or more lines are too long
51
t/fill.t
51
t/fill.t
|
@ -2,18 +2,18 @@ use Test::More;
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
|
|
||||||
plan tests => 42;
|
plan tests => 43;
|
||||||
|
|
||||||
BEGIN {
|
BEGIN {
|
||||||
use FindBin;
|
use FindBin;
|
||||||
use lib "$FindBin::Bin/../lib";
|
use lib "$FindBin::Bin/../lib";
|
||||||
}
|
}
|
||||||
|
|
||||||
use List::Util qw(first);
|
use List::Util qw(first sum);
|
||||||
use Math::ConvexHull::MonotoneChain qw(convex_hull);
|
use Math::ConvexHull::MonotoneChain qw(convex_hull);
|
||||||
use Slic3r;
|
use Slic3r;
|
||||||
use Slic3r::Geometry qw(scale X Y);
|
use Slic3r::Geometry qw(scale unscale X Y);
|
||||||
use Slic3r::Geometry::Clipper qw(union diff_ex);
|
use Slic3r::Geometry::Clipper qw(union diff_ex offset);
|
||||||
use Slic3r::Surface qw(:types);
|
use Slic3r::Surface qw(:types);
|
||||||
use Slic3r::Test;
|
use Slic3r::Test;
|
||||||
|
|
||||||
|
@ -190,8 +190,47 @@ for my $pattern (qw(rectilinear honeycomb hilbertcurve concentric)) {
|
||||||
{
|
{
|
||||||
my $config = Slic3r::Config->new_from_defaults;
|
my $config = Slic3r::Config->new_from_defaults;
|
||||||
$config->set('infill_only_where_needed', 1);
|
$config->set('infill_only_where_needed', 1);
|
||||||
my $print = Slic3r::Test::init_print('20mm_cube', config => $config);
|
$config->set('bottom_solid_layers', 0);
|
||||||
ok my $gcode = Slic3r::Test::gcode($print), "successful G-code generation when infill_only_where_needed is set";
|
$config->set('infill_extruder', 2);
|
||||||
|
$config->set('infill_extrusion_width', 0.5);
|
||||||
|
$config->set('cooling', 0); # for preventing speeds from being altered
|
||||||
|
$config->set('first_layer_speed', '100%'); # for preventing speeds from being altered
|
||||||
|
|
||||||
|
my $test = sub {
|
||||||
|
my $print = Slic3r::Test::init_print('pyramid', config => $config);
|
||||||
|
|
||||||
|
my $tool = undef;
|
||||||
|
my @infill_extrusions = (); # array of polylines
|
||||||
|
Slic3r::GCode::Reader->new->parse(Slic3r::Test::gcode($print), sub {
|
||||||
|
my ($self, $cmd, $args, $info) = @_;
|
||||||
|
|
||||||
|
if ($cmd =~ /^T(\d+)/) {
|
||||||
|
$tool = $1;
|
||||||
|
} elsif ($cmd eq 'G1' && $info->{extruding} && $info->{dist_XY} > 0) {
|
||||||
|
if ($tool == $config->infill_extruder-1) {
|
||||||
|
push @infill_extrusions, Slic3r::Line->new_scale(
|
||||||
|
[ $self->X, $self->Y ],
|
||||||
|
[ $info->{new_X}, $info->{new_Y} ],
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return 0 if !@infill_extrusions; # prevent calling convex_hull() with no points
|
||||||
|
|
||||||
|
my $convex_hull = Slic3r::Polygon->new(@{convex_hull([ map $_->pp, map @$_, @infill_extrusions ])});
|
||||||
|
|
||||||
|
return unscale unscale sum(map $_->area, @{offset([$convex_hull], scale(+$config->infill_extrusion_width/2))});
|
||||||
|
};
|
||||||
|
|
||||||
|
my $tolerance = 5; # mm^2
|
||||||
|
|
||||||
|
$config->set('solid_infill_below_area', 0);
|
||||||
|
ok $test->() < $tolerance,
|
||||||
|
'no infill is generated when using infill_only_where_needed on a pyramid';
|
||||||
|
|
||||||
|
$config->set('solid_infill_below_area', 70);
|
||||||
|
ok abs($test->() - $config->solid_infill_below_area) < $tolerance,
|
||||||
|
'infill is only generated under the forced solid shells';
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue