2013-07-16 09:49:34 +02:00
|
|
|
package Slic3r::ExPolygon;
|
2011-10-15 11:36:05 +02:00
|
|
|
use strict;
|
|
|
|
use warnings;
|
|
|
|
|
|
|
|
# an ExPolygon is a polygon with holes
|
|
|
|
|
2013-03-14 14:27:08 +01:00
|
|
|
use List::Util qw(first);
|
2013-11-06 19:38:10 +01:00
|
|
|
use Slic3r::Geometry qw(X Y A B point_in_polygon epsilon scaled_epsilon);
|
2013-11-21 14:15:38 +01:00
|
|
|
use Slic3r::Geometry::Clipper qw(union_ex diff_pl);
|
2013-07-07 15:17:09 +02:00
|
|
|
|
2013-01-28 00:02:34 +01:00
|
|
|
sub wkt {
|
|
|
|
my $self = shift;
|
|
|
|
return sprintf "POLYGON(%s)",
|
|
|
|
join ',', map "($_)", map { join ',', map "$_->[0] $_->[1]", @$_ } @$self;
|
|
|
|
}
|
|
|
|
|
2013-07-29 13:36:22 +02:00
|
|
|
sub dump_perl {
|
|
|
|
my $self = shift;
|
|
|
|
return sprintf "[%s]",
|
|
|
|
join ',', map "[$_]", map { join ',', map "[$_->[0],$_->[1]]", @$_ } @$self;
|
|
|
|
}
|
|
|
|
|
2011-10-15 11:36:05 +02:00
|
|
|
sub offset {
|
|
|
|
my $self = shift;
|
2013-07-17 00:48:29 +02:00
|
|
|
return Slic3r::Geometry::Clipper::offset(\@$self, @_);
|
2012-08-25 20:04:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
sub offset_ex {
|
|
|
|
my $self = shift;
|
2013-07-16 20:09:53 +02:00
|
|
|
return Slic3r::Geometry::Clipper::offset_ex(\@$self, @_);
|
2011-11-16 16:35:20 +01:00
|
|
|
}
|
|
|
|
|
2012-08-25 14:23:46 +02:00
|
|
|
sub noncollapsing_offset_ex {
|
|
|
|
my $self = shift;
|
|
|
|
my ($distance, @params) = @_;
|
|
|
|
|
|
|
|
return $self->offset_ex($distance + 1, @params);
|
|
|
|
}
|
|
|
|
|
2011-11-13 18:14:02 +01:00
|
|
|
sub bounding_box {
|
|
|
|
my $self = shift;
|
2013-06-16 12:21:25 +02:00
|
|
|
return $self->contour->bounding_box;
|
2012-02-25 14:46:21 +01:00
|
|
|
}
|
|
|
|
|
2012-11-24 00:13:04 +01:00
|
|
|
package Slic3r::ExPolygon::Collection;
|
|
|
|
use Slic3r::Geometry qw(X1 Y1);
|
|
|
|
|
|
|
|
sub size {
|
|
|
|
my $self = shift;
|
2013-07-14 00:38:01 +02:00
|
|
|
return [ Slic3r::Geometry::size_2D([ map @$_, map @$_, @$self ]) ];
|
2012-11-24 00:13:04 +01:00
|
|
|
}
|
|
|
|
|
2011-10-15 11:36:05 +02:00
|
|
|
1;
|