PrusaSlicer-NonPlainar/lib/Slic3r/Surface.pm

97 lines
1.9 KiB
Perl
Raw Normal View History

2011-09-01 19:06:28 +00:00
package Slic3r::Surface;
use Moo;
2011-09-01 19:06:28 +00:00
has 'contour' => (
is => 'ro',
#isa => 'Slic3r::Polyline::Closed',
2011-09-01 19:06:28 +00:00
required => 1,
);
has 'holes' => (
traits => ['Array'],
is => 'rw',
#isa => 'ArrayRef[Slic3r::Polyline::Closed]',
2011-09-01 19:06:28 +00:00
default => sub { [] },
);
has 'surface_type' => (
is => 'rw',
#isa => enum([qw(internal internal-solid bottom top)]),
2011-09-01 19:06:28 +00:00
);
sub cast_from_polygon {
my $class = shift;
my ($polygon, %args) = @_;
return $class->new(
contour => Slic3r::Polyline::Closed->cast($polygon),
%args,
);
}
sub cast_from_expolygon {
my $class = shift;
my ($expolygon, %args) = @_;
if (ref $expolygon ne 'HASH') {
$expolygon = $expolygon->clipper_expolygon;
}
return $class->new(
contour => Slic3r::Polyline::Closed->cast($expolygon->{outer}),
holes => [
map Slic3r::Polyline::Closed->cast($_), @{$expolygon->{holes}}
],
%args,
);
}
sub add_hole {
2011-09-01 19:06:28 +00:00
my $self = shift;
my ($hole) = @_;
push @{ $self->holes }, $hole;
2011-09-01 19:06:28 +00:00
}
sub id {
my $self = shift;
return $self->contour->id;
}
sub encloses_point {
my $self = shift;
my ($point) = @_;
return 0 if !$self->contour->encloses_point($point);
return 0 if grep $_->encloses_point($point), @{ $self->holes };
return 1;
}
sub clipper_polygon {
my $self = shift;
return {
outer => $self->contour->p,
holes => [
map $_->p, @{$self->holes}
],
};
}
sub p {
my $self = shift;
return ($self->contour->p, map $_->p, @{$self->holes});
}
sub expolygon {
my $self = shift;
return Slic3r::ExPolygon->new($self->contour->p, map $_->p, @{$self->holes});
}
2011-09-05 10:21:27 +00:00
sub lines {
my $self = shift;
return @{ $self->contour->lines }, map @{ $_->lines }, @{ $self->holes };
}
2011-09-01 19:06:28 +00:00
1;