mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-24 09:11:23 -06:00

Removed GCode.pm Removed the Perl bindigns for AvoidCrossingPerimeters, OozePrevention, SpiralVase, Wipe Changed the std::set of extruder IDs to vector of IDs. Removed some MSVC compiler warnings, removed obnoxious compiler warnings when compiling the Perl bindings.
319 lines
7.7 KiB
Perl
319 lines
7.7 KiB
Perl
package Slic3r::XS;
|
|
use warnings;
|
|
use strict;
|
|
|
|
our $VERSION = '0.01';
|
|
|
|
# We have to load these modules in order to have Wx.pm find the correct paths
|
|
# for wxWidgets dlls on MSW.
|
|
# We avoid loading these on OS X because Wx::Load() initializes a Wx App
|
|
# automatically and it steals focus even when we're not running Slic3r in GUI mode.
|
|
# TODO: only load these when compiling with GUI support
|
|
BEGIN {
|
|
if ($^O eq 'MSWin32') {
|
|
eval "use Wx";
|
|
# eval "use Wx::Html";
|
|
eval "use Wx::Print"; # because of some Wx bug, thread creation fails if we don't have this (looks like Wx::Printout is hard-coded in some thread cleanup code)
|
|
}
|
|
}
|
|
|
|
use Carp qw();
|
|
use XSLoader;
|
|
XSLoader::load(__PACKAGE__, $VERSION);
|
|
|
|
package Slic3r::Line;
|
|
use overload
|
|
'@{}' => sub { $_[0]->arrayref },
|
|
'fallback' => 1;
|
|
|
|
package Slic3r::Point;
|
|
use overload
|
|
'@{}' => sub { $_[0]->arrayref },
|
|
'fallback' => 1;
|
|
|
|
package Slic3r::Point3;
|
|
use overload
|
|
'@{}' => sub { [ $_[0]->x, $_[0]->y, $_[0]->z ] }, #,
|
|
'fallback' => 1;
|
|
|
|
sub pp {
|
|
my ($self) = @_;
|
|
return [ @$self ];
|
|
}
|
|
|
|
package Slic3r::Pointf;
|
|
use overload
|
|
'@{}' => sub { $_[0]->arrayref },
|
|
'fallback' => 1;
|
|
|
|
package Slic3r::Pointf3;
|
|
use overload
|
|
'@{}' => sub { [ $_[0]->x, $_[0]->y, $_[0]->z ] }, #,
|
|
'fallback' => 1;
|
|
|
|
sub pp {
|
|
my ($self) = @_;
|
|
return [ @$self ];
|
|
}
|
|
|
|
package Slic3r::ExPolygon;
|
|
use overload
|
|
'@{}' => sub { $_[0]->arrayref },
|
|
'fallback' => 1;
|
|
|
|
package Slic3r::Polyline;
|
|
use overload
|
|
'@{}' => sub { $_[0]->arrayref },
|
|
'fallback' => 1;
|
|
|
|
package Slic3r::Polyline::Collection;
|
|
use overload
|
|
'@{}' => sub { $_[0]->arrayref },
|
|
'fallback' => 1;
|
|
|
|
package Slic3r::Polygon;
|
|
use overload
|
|
'@{}' => sub { $_[0]->arrayref },
|
|
'fallback' => 1;
|
|
|
|
package Slic3r::ExPolygon::Collection;
|
|
use overload
|
|
'@{}' => sub { $_[0]->arrayref },
|
|
'fallback' => 1;
|
|
|
|
package Slic3r::ExtrusionPath::Collection;
|
|
use overload
|
|
'@{}' => sub { $_[0]->arrayref },
|
|
'fallback' => 1;
|
|
|
|
sub new {
|
|
my ($class, @paths) = @_;
|
|
|
|
my $self = $class->_new;
|
|
$self->append(@paths);
|
|
return $self;
|
|
}
|
|
|
|
package Slic3r::ExtrusionLoop;
|
|
use overload
|
|
'@{}' => sub { $_[0]->arrayref },
|
|
'fallback' => 1;
|
|
|
|
sub new_from_paths {
|
|
my ($class, @paths) = @_;
|
|
|
|
my $loop = $class->new;
|
|
$loop->append($_) for @paths;
|
|
return $loop;
|
|
}
|
|
|
|
package Slic3r::ExtrusionMultiPath;
|
|
use overload
|
|
'@{}' => sub { $_[0]->arrayref },
|
|
'fallback' => 1;
|
|
|
|
package Slic3r::ExtrusionPath;
|
|
use overload
|
|
'@{}' => sub { $_[0]->arrayref },
|
|
'fallback' => 1;
|
|
|
|
sub new {
|
|
my ($class, %args) = @_;
|
|
|
|
return $class->_new(
|
|
$args{polyline}, # required
|
|
$args{role}, # required
|
|
$args{mm3_per_mm} // die("Missing required mm3_per_mm in ExtrusionPath constructor"),
|
|
$args{width} // -1,
|
|
$args{height} // -1,
|
|
);
|
|
}
|
|
|
|
sub clone {
|
|
my ($self, %args) = @_;
|
|
|
|
return __PACKAGE__->_new(
|
|
$args{polyline} // $self->polyline,
|
|
$args{role} // $self->role,
|
|
$args{mm3_per_mm} // $self->mm3_per_mm,
|
|
$args{width} // $self->width,
|
|
$args{height} // $self->height,
|
|
);
|
|
}
|
|
|
|
package Slic3r::ExtrusionSimulator;
|
|
|
|
sub new {
|
|
my ($class, %args) = @_;
|
|
return $class->_new();
|
|
}
|
|
|
|
package Slic3r::Filler;
|
|
|
|
sub fill_surface {
|
|
my ($self, $surface, %args) = @_;
|
|
$self->set_density($args{density}) if defined($args{density});
|
|
$self->set_dont_connect($args{dont_connect}) if defined($args{dont_connect});
|
|
$self->set_dont_adjust($args{dont_adjust}) if defined($args{dont_adjust});
|
|
$self->set_complete($args{complete}) if defined($args{complete});
|
|
return $self->_fill_surface($surface);
|
|
}
|
|
|
|
package Slic3r::Flow;
|
|
|
|
sub new {
|
|
my ($class, %args) = @_;
|
|
|
|
my $self = $class->_new(
|
|
@args{qw(width height nozzle_diameter)},
|
|
);
|
|
$self->set_bridge($args{bridge} // 0);
|
|
return $self;
|
|
}
|
|
|
|
sub new_from_width {
|
|
my ($class, %args) = @_;
|
|
|
|
return $class->_new_from_width(
|
|
@args{qw(role width nozzle_diameter layer_height bridge_flow_ratio)},
|
|
);
|
|
}
|
|
|
|
sub new_from_spacing {
|
|
my ($class, %args) = @_;
|
|
|
|
return $class->_new_from_spacing(
|
|
@args{qw(spacing nozzle_diameter layer_height bridge)},
|
|
);
|
|
}
|
|
|
|
package Slic3r::Surface;
|
|
|
|
sub new {
|
|
my ($class, %args) = @_;
|
|
|
|
# defensive programming: make sure no negative bridge_angle is supplied
|
|
die "Error: invalid negative bridge_angle\n"
|
|
if defined $args{bridge_angle} && $args{bridge_angle} < 0;
|
|
|
|
return $class->_new(
|
|
$args{expolygon} // (die "Missing required expolygon\n"),
|
|
$args{surface_type} // (die "Missing required surface_type\n"),
|
|
$args{thickness} // -1,
|
|
$args{thickness_layers} // 1,
|
|
$args{bridge_angle} // -1,
|
|
$args{extra_perimeters} // 0,
|
|
);
|
|
}
|
|
|
|
sub clone {
|
|
my ($self, %args) = @_;
|
|
|
|
return (ref $self)->_new(
|
|
delete $args{expolygon} // $self->expolygon,
|
|
delete $args{surface_type} // $self->surface_type,
|
|
delete $args{thickness} // $self->thickness,
|
|
delete $args{thickness_layers} // $self->thickness_layers,
|
|
delete $args{bridge_angle} // $self->bridge_angle,
|
|
delete $args{extra_perimeters} // $self->extra_perimeters,
|
|
);
|
|
}
|
|
|
|
package Slic3r::Surface::Collection;
|
|
use overload
|
|
'@{}' => sub { $_[0]->arrayref },
|
|
'fallback' => 1;
|
|
|
|
sub new {
|
|
my ($class, @surfaces) = @_;
|
|
|
|
my $self = $class->_new;
|
|
$self->append($_) for @surfaces;
|
|
return $self;
|
|
}
|
|
|
|
package Slic3r::Print::SupportMaterial2;
|
|
|
|
sub new {
|
|
my ($class, %args) = @_;
|
|
|
|
return $class->_new(
|
|
$args{print_config}, # required
|
|
$args{object_config}, # required
|
|
$args{first_layer_flow}, # required
|
|
$args{flow}, # required
|
|
$args{interface_flow}, # required
|
|
$args{soluble_interface} // 0
|
|
);
|
|
}
|
|
|
|
package Slic3r::GUI::_3DScene::GLShader;
|
|
sub CLONE_SKIP { 1 }
|
|
|
|
package Slic3r::GUI::_3DScene::GLVolume::Collection;
|
|
use overload
|
|
'@{}' => sub { $_[0]->arrayref },
|
|
'fallback' => 1;
|
|
|
|
sub CLONE_SKIP { 1 }
|
|
|
|
package main;
|
|
for my $class (qw(
|
|
Slic3r::BridgeDetector
|
|
Slic3r::Config
|
|
Slic3r::Config::Full
|
|
Slic3r::Config::GCode
|
|
Slic3r::Config::Print
|
|
Slic3r::Config::PrintObject
|
|
Slic3r::Config::PrintRegion
|
|
Slic3r::Config::Static
|
|
Slic3r::ExPolygon
|
|
Slic3r::ExPolygon::Collection
|
|
Slic3r::Extruder
|
|
Slic3r::ExtrusionLoop
|
|
Slic3r::ExtrusionMultiPath
|
|
Slic3r::ExtrusionPath
|
|
Slic3r::ExtrusionPath::Collection
|
|
Slic3r::ExtrusionSimulator
|
|
Slic3r::Filler
|
|
Slic3r::Flow
|
|
Slic3r::GCode
|
|
Slic3r::GCode::PlaceholderParser
|
|
Slic3r::GCode::Writer
|
|
Slic3r::Geometry::BoundingBox
|
|
Slic3r::Geometry::BoundingBoxf
|
|
Slic3r::Geometry::BoundingBoxf3
|
|
Slic3r::GUI::_3DScene::GLVolume
|
|
Slic3r::Layer
|
|
Slic3r::Layer::Region
|
|
Slic3r::Layer::Support
|
|
Slic3r::Line
|
|
Slic3r::Linef3
|
|
Slic3r::Model
|
|
Slic3r::Model::Instance
|
|
Slic3r::Model::Material
|
|
Slic3r::Model::Object
|
|
Slic3r::Model::Volume
|
|
Slic3r::Point
|
|
Slic3r::Point3
|
|
Slic3r::Pointf
|
|
Slic3r::Pointf3
|
|
Slic3r::Polygon
|
|
Slic3r::Polyline
|
|
Slic3r::Polyline::Collection
|
|
Slic3r::Print
|
|
Slic3r::Print::Object
|
|
Slic3r::Print::Region
|
|
Slic3r::Print::State
|
|
Slic3r::Surface
|
|
Slic3r::Surface::Collection
|
|
Slic3r::Print::SupportMaterial2
|
|
Slic3r::TriangleMesh
|
|
))
|
|
{
|
|
no strict 'refs';
|
|
my $ref_class = $class . "::Ref";
|
|
eval "package $ref_class; our \@ISA = '$class'; sub DESTROY {};";
|
|
}
|
|
|
|
1;
|