1
0
mirror of git://projects.qi-hardware.com/cae-tools.git synced 2025-01-03 20:20:15 +02:00

sl2/slicer.pl: complete basic processing structure (WIP)

This commit is contained in:
Werner Almesberger 2015-09-29 12:09:34 -03:00
parent 6800f025c1
commit 73c3a776a3

View File

@ -12,10 +12,19 @@
# #
$epsilon = 0.0001; $epsilon = 0.0001; # cutting offset
$height = 10; # height of workpiece
$margin = 5; # margin of workpiece box
$end = 0; # offset to add at the last layer
$flip = 1; # flip piece
$z0 = -35; # reference tool position
$z_step = 1;
$flip = 1;
#----- Read the STL mesh ------------------------------------------------------
$xmin = $xmax = $ymin = $ymax = $zmin = $zmax = undef;
$v_n = 0; $v_n = 0;
$e_n = 0; $e_n = 0;
@ -35,15 +44,33 @@ while (<>) {
if (/vertex\s+/) { if (/vertex\s+/) {
my @tmp = split(/\s+/, $'); my @tmp = split(/\s+/, $');
if ($flip) { ($tmp[0], $tmp[2]) = (-$tmp[0], -$tmp[2]) if $flip;
push(@f, -$tmp[0], $tmp[1], -$tmp[2]);
} else { $xmin = $tmp[0] unless defined $xmin && $xmin < $tmp[0];
$xmax = $tmp[0] unless defined $xmax && $xmax > $tmp[0];
$ymin = $tmp[1] unless defined $ymin && $ymin < $tmp[1];
$ymax = $tmp[1] unless defined $ymax && $ymax > $tmp[1];
$zmin = $tmp[2] unless defined $zmin && $zmin < $tmp[2];
$zmax = $tmp[2] unless defined $zmax && $zmax > $tmp[2];
push(@f, @tmp); push(@f, @tmp);
}
next; next;
} }
} }
print STDERR "bbox\t($xmin, $ymin, $zmin)\n\t($xmax, $ymax, $zmax)\n";
#----- Calculate Z offset -----------------------------------------------------
# align with bottom (zmin == 0), z_pos = height - zoff
$z_off = $z0 - $zmin - $height;
$z_pos = $height + $zmin;
#----- Perform the slicing ----------------------------------------------------
sub cut sub cut
{ {
@ -78,31 +105,55 @@ sub remove
} }
for $level (sort keys %z_level) { @z_levels = sort { $b <=> $a } keys %z_level;
my $z = $level + $epsilon; for $level (@z_levels) {
my $z_cut = $level + $epsilon;
# print STDERR "level = $level\n"; print STDERR "level $level (cut at $z_cut)\n";
undef %next;
undef %path;
for (@m) { for (@m) {
my @f = @{ $_ }; my @f = @{ $_ };
my @p = &cut($z, 0, 3, @f); my @p = &cut($z_cut, 0, 3, @f);
push(@p, &cut($z, 0, 6, @f)); push(@p, &cut($z_cut, 0, 6, @f));
push(@p, &cut($z, 3, 6, @f)); push(@p, &cut($z_cut, 3, 6, @f));
next if $#p < 1; next if $#p < 1;
die "BAD $#p" if $#p > 1; die "BAD $#p" if $#p > 1;
my $a = "$p[0][0] $p[0][1]"; my $a = "$p[0][0] $p[0][1]";
my $b = "$p[1][0] $p[1][1]"; my $b = "$p[1][0] $p[1][1]";
push(@{ $next{$a} }, $b); push(@{ $path{$a} }, $b);
push(@{ $next{$b} }, $a); push(@{ $path{$b} }, $a);
# print STDERR "$z: ($a) to ($b)\n"; # print STDERR "$z: ($a) to ($b)\n";
} }
while (1) {
if (defined $z_step) {
$z_pos = $z_pos - $z_step > $level ?
$z_pos - $z_step : $level;
} else {
$z_pos = $level;
}
my $z = $z_pos + $z_off;
$z += $end if $z_pos == $z_levels[$#z_levels];
print STDERR "\t$z_pos @ $z\n";
if (defined $margin) {
print $xmin - $margin, " ", $ymin - $margin, " $z\n";
print $xmax + $margin, " ", $ymin - $margin, " $z\n";
print $xmax + $margin, " ", $ymax + $margin, " $z\n";
print $xmin - $margin, " ", $ymax + $margin, " $z\n";
print $xmin - $margin, " ", $ymin - $margin, " $z\n\n";
}
%next = %path;
while (1) { while (1) {
my @k = keys %next; my @k = keys %next;
last if $#k == -1; last if $#k == -1;
my $p0 = $k[0]; my $p0 = $k[0];
$p = $p0; $p = $p0;
while (1) { while (1) {
@ -120,4 +171,7 @@ for $level (sort keys %z_level) {
print "$p0 $z\n"; print "$p0 $z\n";
print "\n"; print "\n";
} }
last if $z_pos == $level;
}
} }