2011-09-26 08:52:58 +00:00
|
|
|
package Slic3r::ExtrusionPath::Collection;
|
|
|
|
use Moo;
|
|
|
|
|
2012-07-20 12:39:07 +00:00
|
|
|
has 'paths' => (is => 'rw', default => sub { [] });
|
2011-09-26 08:52:58 +00:00
|
|
|
|
2013-03-10 15:09:03 +00:00
|
|
|
# no-op
|
|
|
|
sub unpack { $_[0] }
|
|
|
|
|
|
|
|
sub first_point {
|
2011-09-26 08:52:58 +00:00
|
|
|
my $self = shift;
|
2013-03-10 15:09:03 +00:00
|
|
|
return $self->paths->[0]->unpack->polyline->[0];
|
2011-09-26 08:52:58 +00:00
|
|
|
}
|
|
|
|
|
2013-02-05 16:27:45 +00:00
|
|
|
sub chained_path {
|
2011-09-26 08:52:58 +00:00
|
|
|
my $self = shift;
|
|
|
|
my ($start_near) = @_;
|
|
|
|
|
2012-12-20 17:10:20 +00:00
|
|
|
# make sure we pass the same path objects to the Collection constructor
|
2013-02-05 16:27:45 +00:00
|
|
|
# and the ->chained_path() method because the latter will reverse the
|
2012-12-20 17:10:20 +00:00
|
|
|
# paths in-place when needed and we need to return them that way
|
|
|
|
my @paths = map $_->unpack, @{$self->paths};
|
2012-10-30 12:59:33 +00:00
|
|
|
my $collection = Slic3r::Polyline::Collection->new(
|
2012-12-20 17:10:20 +00:00
|
|
|
polylines => [ map $_->polyline, @paths ],
|
2012-10-30 12:59:33 +00:00
|
|
|
);
|
2012-07-20 12:39:07 +00:00
|
|
|
|
2013-02-05 16:27:45 +00:00
|
|
|
return $collection->chained_path($start_near, \@paths);
|
2011-09-26 08:52:58 +00:00
|
|
|
}
|
|
|
|
|
2011-10-01 12:26:54 +00:00
|
|
|
sub cleanup {
|
|
|
|
my $self = shift;
|
|
|
|
|
|
|
|
# split paths at angles that are too acute to be printed as they will cause blobs
|
|
|
|
@{$self->paths} = map $_->split_at_acute_angles, @{$self->paths};
|
|
|
|
}
|
|
|
|
|
2011-10-20 16:11:59 +00:00
|
|
|
sub detect_arcs {
|
|
|
|
my $self = shift;
|
2011-11-07 13:12:07 +00:00
|
|
|
@{$self->paths} = map $_->detect_arcs(@_), @{$self->paths};
|
2011-10-20 16:11:59 +00:00
|
|
|
}
|
|
|
|
|
2011-09-26 08:52:58 +00:00
|
|
|
1;
|