Fixes to complete_objects to make t/gcode.t pass
This commit is contained in:
parent
c5ead0f2a6
commit
7ddf4f3ddf
5 changed files with 15 additions and 11 deletions
|
@ -166,7 +166,8 @@ sub duplicate {
|
||||||
# note that this will leave the object count unaltered
|
# note that this will leave the object count unaltered
|
||||||
|
|
||||||
foreach my $object (@{$self->objects}) {
|
foreach my $object (@{$self->objects}) {
|
||||||
foreach my $instance (@{$object->instances}) {
|
my @instances = @{$object->instances}; # store separately to avoid recursion from add_instance() below
|
||||||
|
foreach my $instance (@instances) {
|
||||||
foreach my $pos (@positions) {
|
foreach my $pos (@positions) {
|
||||||
### $object->add_instance($instance->clone); if we had clone()
|
### $object->add_instance($instance->clone); if we had clone()
|
||||||
$object->add_instance(
|
$object->add_instance(
|
||||||
|
|
|
@ -191,6 +191,7 @@ sub validate {
|
||||||
# now we need that no instance of $convex_hull does not intersect any of the previously checked object instances
|
# now we need that no instance of $convex_hull does not intersect any of the previously checked object instances
|
||||||
for my $copy (@{$object->_shifted_copies}) {
|
for my $copy (@{$object->_shifted_copies}) {
|
||||||
my $p = $convex_hull->clone;
|
my $p = $convex_hull->clone;
|
||||||
|
|
||||||
$p->translate(@$copy);
|
$p->translate(@$copy);
|
||||||
if (@{ intersection(\@a, [$p]) }) {
|
if (@{ intersection(\@a, [$p]) }) {
|
||||||
die "Some objects are too close; your extruder will collide with them.\n";
|
die "Some objects are too close; your extruder will collide with them.\n";
|
||||||
|
@ -837,14 +838,13 @@ sub write_gcode {
|
||||||
|
|
||||||
# do all objects for each layer
|
# do all objects for each layer
|
||||||
if ($Slic3r::Config->complete_objects) {
|
if ($Slic3r::Config->complete_objects) {
|
||||||
|
|
||||||
# print objects from the smallest to the tallest to avoid collisions
|
# print objects from the smallest to the tallest to avoid collisions
|
||||||
# when moving onto next object starting point
|
# when moving onto next object starting point
|
||||||
my @obj_idx = sort { $self->objects->[$a]->size->[Z] <=> $self->objects->[$b]->size->[Z] } 0..$#{$self->objects};
|
my @obj_idx = sort { $self->objects->[$a]->size->[Z] <=> $self->objects->[$b]->size->[Z] } 0..$#{$self->objects};
|
||||||
|
|
||||||
my $finished_objects = 0;
|
my $finished_objects = 0;
|
||||||
for my $obj_idx (@obj_idx) {
|
for my $obj_idx (@obj_idx) {
|
||||||
for my $copy (@{ $self->objects->[$obj_idx]->copies }) {
|
for my $copy (@{ $self->objects->[$obj_idx]->_shifted_copies }) {
|
||||||
# move to the origin position for the copy we're going to print.
|
# move to the origin position for the copy we're going to print.
|
||||||
# this happens before Z goes down to layer 0 again, so that
|
# this happens before Z goes down to layer 0 again, so that
|
||||||
# no collision happens hopefully.
|
# no collision happens hopefully.
|
||||||
|
@ -929,8 +929,7 @@ sub write_gcode {
|
||||||
# append full config
|
# append full config
|
||||||
print $fh "\n";
|
print $fh "\n";
|
||||||
foreach my $opt_key (sort @{$self->config->get_keys}) {
|
foreach my $opt_key (sort @{$self->config->get_keys}) {
|
||||||
next if $Slic3r::Config::Options->{$opt_key}{shortcut};
|
next if @{$Slic3r::Config::Options->{$opt_key}{shortcut}};
|
||||||
next if $Slic3r::Config::Options->{$opt_key}{gui_only};
|
|
||||||
printf $fh "; %s = %s\n", $opt_key, $self->config->serialize($opt_key);
|
printf $fh "; %s = %s\n", $opt_key, $self->config->serialize($opt_key);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -90,7 +90,7 @@ sub model {
|
||||||
my $object = $model->add_object;
|
my $object = $model->add_object;
|
||||||
$object->add_volume(mesh => $mesh);
|
$object->add_volume(mesh => $mesh);
|
||||||
$object->add_instance(
|
$object->add_instance(
|
||||||
offset => Slic3r::Point->new(0,0),
|
offset => [0,0],
|
||||||
rotation => $params{rotation} // 0,
|
rotation => $params{rotation} // 0,
|
||||||
);
|
);
|
||||||
return $model;
|
return $model;
|
||||||
|
@ -108,6 +108,9 @@ sub init_print {
|
||||||
$model_name = [$model_name] if ref($model_name) ne 'ARRAY';
|
$model_name = [$model_name] if ref($model_name) ne 'ARRAY';
|
||||||
for my $model (map model($_, %params), @$model_name) {
|
for my $model (map model($_, %params), @$model_name) {
|
||||||
die "Unknown model in test" if !defined $model;
|
die "Unknown model in test" if !defined $model;
|
||||||
|
if (defined $params{duplicate} && $params{duplicate} > 1) {
|
||||||
|
$model->duplicate($params{duplicate} // 1, $config->min_object_distance);
|
||||||
|
}
|
||||||
$model->arrange_objects($config->min_object_distance);
|
$model->arrange_objects($config->min_object_distance);
|
||||||
$model->center_instances_around_point($config->print_center);
|
$model->center_instances_around_point($config->print_center);
|
||||||
$print->add_model_object($_) for @{$model->objects};
|
$print->add_model_object($_) for @{$model->objects};
|
||||||
|
|
|
@ -48,13 +48,13 @@ use Slic3r::Test;
|
||||||
# - no hard-coded "E" are generated
|
# - no hard-coded "E" are generated
|
||||||
# - Z moves are correctly generated for both objects
|
# - Z moves are correctly generated for both objects
|
||||||
my $config = Slic3r::Config->new_from_defaults;
|
my $config = Slic3r::Config->new_from_defaults;
|
||||||
|
$config->set('gcode_comments', 1);
|
||||||
$config->set('complete_objects', 1);
|
$config->set('complete_objects', 1);
|
||||||
$config->set('duplicate', 2);
|
|
||||||
$config->set('extrusion_axis', 'A');
|
$config->set('extrusion_axis', 'A');
|
||||||
$config->set('start_gcode', ''); # prevent any default extra Z move
|
$config->set('start_gcode', ''); # prevent any default extra Z move
|
||||||
$config->set('layer_height', 0.4);
|
$config->set('layer_height', 0.4);
|
||||||
$config->set('first_layer_height', 0.4);
|
$config->set('first_layer_height', 0.4);
|
||||||
my $print = Slic3r::Test::init_print('20mm_cube', config => $config);
|
my $print = Slic3r::Test::init_print('20mm_cube', config => $config, duplicate => 2);
|
||||||
ok my $gcode = Slic3r::Test::gcode($print), "complete_objects";
|
ok my $gcode = Slic3r::Test::gcode($print), "complete_objects";
|
||||||
my @z_moves = ();
|
my @z_moves = ();
|
||||||
Slic3r::GCode::Reader->new->parse($gcode, sub {
|
Slic3r::GCode::Reader->new->parse($gcode, sub {
|
||||||
|
|
|
@ -11,12 +11,13 @@ use Slic3r;
|
||||||
use Slic3r::Test qw(_eq);
|
use Slic3r::Test qw(_eq);
|
||||||
|
|
||||||
my $config = Slic3r::Config->new_from_defaults;
|
my $config = Slic3r::Config->new_from_defaults;
|
||||||
|
my $duplicate = 1;
|
||||||
|
|
||||||
my $test = sub {
|
my $test = sub {
|
||||||
my ($conf) = @_;
|
my ($conf) = @_;
|
||||||
$conf ||= $config;
|
$conf ||= $config;
|
||||||
|
|
||||||
my $print = Slic3r::Test::init_print('20mm_cube', config => $conf);
|
my $print = Slic3r::Test::init_print('20mm_cube', config => $conf, duplicate => $duplicate);
|
||||||
|
|
||||||
my $tool = 0;
|
my $tool = 0;
|
||||||
my @toolchange_count = (); # track first usages so that we don't expect retract_length_toolchange when extruders are used for the first time
|
my @toolchange_count = (); # track first usages so that we don't expect retract_length_toolchange when extruders are used for the first time
|
||||||
|
@ -115,13 +116,13 @@ my $retract_tests = sub {
|
||||||
|
|
||||||
$retract_tests->('');
|
$retract_tests->('');
|
||||||
|
|
||||||
$config->set('duplicate', 2);
|
$duplicate = 2;
|
||||||
$retract_tests->(' (duplicate)');
|
$retract_tests->(' (duplicate)');
|
||||||
|
|
||||||
$config->set('g0', 1);
|
$config->set('g0', 1);
|
||||||
$retract_tests->(' (G0 and duplicate)');
|
$retract_tests->(' (G0 and duplicate)');
|
||||||
|
|
||||||
$config->set('duplicate', 1);
|
$duplicate = 1;
|
||||||
$config->set('g0', 0);
|
$config->set('g0', 0);
|
||||||
$config->set('infill_extruder', 2);
|
$config->set('infill_extruder', 2);
|
||||||
$config->set('skirts', 4);
|
$config->set('skirts', 4);
|
||||||
|
|
Loading…
Reference in a new issue