2011-09-01 19:06:28 +00:00
|
|
|
package Slic3r::Surface;
|
2012-05-01 09:32:22 +00:00
|
|
|
use strict;
|
|
|
|
use warnings;
|
2011-09-01 19:06:28 +00:00
|
|
|
|
2012-05-19 14:04:33 +00:00
|
|
|
require Exporter;
|
|
|
|
our @ISA = qw(Exporter);
|
2013-02-23 20:39:13 +00:00
|
|
|
our @EXPORT_OK = qw(S_TYPE_TOP S_TYPE_BOTTOM S_TYPE_INTERNAL S_TYPE_INTERNALSOLID S_TYPE_INTERNALBRIDGE);
|
2012-05-19 14:04:33 +00:00
|
|
|
our %EXPORT_TAGS = (types => \@EXPORT_OK);
|
|
|
|
|
2012-05-01 09:32:22 +00:00
|
|
|
use constant S_EXPOLYGON => 0;
|
|
|
|
use constant S_SURFACE_TYPE => 1;
|
|
|
|
use constant S_DEPTH_LAYERS => 2;
|
|
|
|
use constant S_BRIDGE_ANGLE => 3;
|
2012-05-05 14:36:10 +00:00
|
|
|
use constant S_ADDITIONAL_INNER_PERIMETERS => 4;
|
2011-09-01 19:06:28 +00:00
|
|
|
|
2012-05-19 14:04:33 +00:00
|
|
|
use constant S_TYPE_TOP => 0;
|
|
|
|
use constant S_TYPE_BOTTOM => 1;
|
|
|
|
use constant S_TYPE_INTERNAL => 2;
|
|
|
|
use constant S_TYPE_INTERNALSOLID => 3;
|
2013-02-23 20:39:13 +00:00
|
|
|
use constant S_TYPE_INTERNALBRIDGE => 4;
|
2012-05-19 14:04:33 +00:00
|
|
|
|
2012-05-01 09:32:22 +00:00
|
|
|
sub new {
|
|
|
|
my $class = shift;
|
|
|
|
my %args = @_;
|
|
|
|
|
|
|
|
my $self = [
|
2012-05-05 14:36:10 +00:00
|
|
|
map delete $args{$_}, qw(expolygon surface_type depth_layers bridge_angle additional_inner_perimeters),
|
2012-05-01 09:32:22 +00:00
|
|
|
];
|
|
|
|
$self->[S_DEPTH_LAYERS] //= 1; #/
|
|
|
|
|
|
|
|
bless $self, $class;
|
|
|
|
$self;
|
|
|
|
}
|
2011-09-01 19:06:28 +00:00
|
|
|
|
2012-05-01 09:32:22 +00:00
|
|
|
sub expolygon { $_[0][S_EXPOLYGON] }
|
2012-05-19 14:04:33 +00:00
|
|
|
sub surface_type { $_[0][S_SURFACE_TYPE] = $_[1] if defined $_[1]; $_[0][S_SURFACE_TYPE] }
|
2012-05-01 09:32:22 +00:00
|
|
|
sub depth_layers { $_[0][S_DEPTH_LAYERS] } # this integer represents the thickness of the surface expressed in layers
|
2013-03-07 14:47:32 +00:00
|
|
|
sub bridge_angle { $_[0][S_BRIDGE_ANGLE] = $_[1] if defined $_[1]; $_[0][S_BRIDGE_ANGLE] }
|
|
|
|
sub additional_inner_perimeters { $_[0][S_ADDITIONAL_INNER_PERIMETERS] = $_[1] if defined $_[1]; $_[0][S_ADDITIONAL_INNER_PERIMETERS] }
|
2011-10-18 13:57:53 +00:00
|
|
|
|
2012-05-01 09:32:22 +00:00
|
|
|
# delegate handles
|
|
|
|
sub encloses_point { $_[0]->expolygon->encloses_point }
|
|
|
|
sub lines { $_[0]->expolygon->lines }
|
|
|
|
sub contour { $_[0]->expolygon->contour }
|
|
|
|
sub holes { $_[0]->expolygon->holes }
|
2011-11-23 08:49:39 +00:00
|
|
|
|
2011-11-26 14:21:15 +00:00
|
|
|
# static method to group surfaces having same surface_type, bridge_angle and depth_layers
|
2011-11-23 08:49:39 +00:00
|
|
|
sub group {
|
|
|
|
my $class = shift;
|
2011-11-23 11:29:27 +00:00
|
|
|
my $params = ref $_[0] eq 'HASH' ? shift(@_) : {};
|
2011-11-23 08:49:39 +00:00
|
|
|
my (@surfaces) = @_;
|
|
|
|
|
2011-11-29 10:36:52 +00:00
|
|
|
my %unique_types = ();
|
2011-11-23 08:49:39 +00:00
|
|
|
foreach my $surface (@surfaces) {
|
2013-02-23 20:39:13 +00:00
|
|
|
my $type = ($params->{merge_solid} && $surface->is_solid)
|
2011-11-29 10:36:52 +00:00
|
|
|
? 'solid'
|
|
|
|
: $surface->surface_type;
|
2011-12-03 17:31:31 +00:00
|
|
|
$type .= "_" . ($surface->bridge_angle // ''); #/
|
2011-11-30 19:32:28 +00:00
|
|
|
$type .= "_" . $surface->depth_layers;
|
2011-11-29 10:36:52 +00:00
|
|
|
$unique_types{$type} ||= [];
|
|
|
|
push @{ $unique_types{$type} }, $surface;
|
2011-11-23 08:49:39 +00:00
|
|
|
}
|
|
|
|
|
2011-11-29 10:36:52 +00:00
|
|
|
return values %unique_types;
|
2011-11-23 08:49:39 +00:00
|
|
|
}
|
|
|
|
|
2012-02-10 13:42:54 +00:00
|
|
|
sub offset {
|
|
|
|
my $self = shift;
|
2012-02-13 17:02:54 +00:00
|
|
|
return map {
|
|
|
|
(ref $self)->new(
|
|
|
|
expolygon => $_,
|
|
|
|
map { $_ => $self->$_ } qw(surface_type depth_layers bridge_angle),
|
|
|
|
)
|
|
|
|
} $self->expolygon->offset_ex(@_);
|
2012-02-10 13:42:54 +00:00
|
|
|
}
|
|
|
|
|
2011-09-18 17:28:12 +00:00
|
|
|
sub clipper_polygon {
|
|
|
|
my $self = shift;
|
|
|
|
|
|
|
|
return {
|
|
|
|
outer => $self->contour->p,
|
|
|
|
holes => [
|
|
|
|
map $_->p, @{$self->holes}
|
|
|
|
],
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2011-09-25 20:11:56 +00:00
|
|
|
sub p {
|
2012-01-12 21:05:35 +00:00
|
|
|
my $self = shift;
|
2011-12-30 18:59:51 +00:00
|
|
|
return @{$self->expolygon};
|
2011-09-05 10:21:27 +00:00
|
|
|
}
|
|
|
|
|
2013-02-23 20:39:13 +00:00
|
|
|
sub is_solid {
|
|
|
|
my $self = shift;
|
|
|
|
my $type = $self->surface_type;
|
2013-02-27 00:30:32 +00:00
|
|
|
# S_TYPE_INTERNALBRIDGE is not solid because we can't merge it with other solid types
|
2013-02-23 20:39:13 +00:00
|
|
|
return $type == S_TYPE_TOP
|
|
|
|
|| $type == S_TYPE_BOTTOM
|
2013-02-27 00:30:32 +00:00
|
|
|
|| $type == S_TYPE_INTERNALSOLID;
|
2013-02-23 20:39:13 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
sub is_internal {
|
|
|
|
my $self = shift;
|
|
|
|
my $type = $self->surface_type;
|
|
|
|
return $type == S_TYPE_INTERNAL
|
|
|
|
|| $type == S_TYPE_INTERNALSOLID
|
|
|
|
|| $type == S_TYPE_INTERNALBRIDGE;
|
|
|
|
}
|
|
|
|
|
|
|
|
sub is_bridge {
|
|
|
|
my $self = shift;
|
|
|
|
my $type = $self->surface_type;
|
|
|
|
return $type == S_TYPE_BOTTOM
|
|
|
|
|| $type == S_TYPE_INTERNALBRIDGE;
|
|
|
|
}
|
|
|
|
|
2011-09-01 19:06:28 +00:00
|
|
|
1;
|