2013-07-15 21:23:35 +00:00
|
|
|
#!/usr/bin/perl
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
use warnings;
|
|
|
|
|
|
|
|
use Slic3r::XS;
|
2014-03-15 15:53:20 +00:00
|
|
|
use Test::More tests => 10;
|
2013-07-15 21:23:35 +00:00
|
|
|
|
|
|
|
my $points = [
|
|
|
|
[100, 100],
|
|
|
|
[200, 100],
|
|
|
|
[200, 200],
|
|
|
|
];
|
|
|
|
|
|
|
|
my $polyline = Slic3r::Polyline->new(@$points);
|
2013-09-03 17:26:58 +00:00
|
|
|
|
2013-07-15 21:23:35 +00:00
|
|
|
is_deeply $polyline->pp, $points, 'polyline roundtrip';
|
|
|
|
|
|
|
|
is ref($polyline->arrayref), 'ARRAY', 'polyline arrayref is unblessed';
|
2013-09-02 18:22:20 +00:00
|
|
|
isa_ok $polyline->[0], 'Slic3r::Point::Ref', 'polyline point is blessed';
|
2013-07-15 21:23:35 +00:00
|
|
|
|
|
|
|
my $lines = $polyline->lines;
|
|
|
|
is_deeply [ map $_->pp, @$lines ], [
|
|
|
|
[ [100, 100], [200, 100] ],
|
|
|
|
[ [200, 100], [200, 200] ],
|
|
|
|
], 'polyline lines';
|
|
|
|
|
2013-08-28 23:36:42 +00:00
|
|
|
$polyline->append_polyline($polyline->clone);
|
|
|
|
is_deeply $polyline->pp, [ @$points, @$points ], 'append_polyline';
|
|
|
|
|
2013-10-27 21:57:25 +00:00
|
|
|
{
|
|
|
|
my $len = $polyline->length;
|
|
|
|
$polyline->clip_end($len/3);
|
|
|
|
ok abs($polyline->length - ($len-($len/3))) < 1, 'clip_end';
|
|
|
|
}
|
|
|
|
|
2013-11-22 15:01:50 +00:00
|
|
|
{
|
|
|
|
my $polyline = Slic3r::Polyline->new(
|
|
|
|
[0,0], [50,50], [100,0], [125,-25], [150,50],
|
|
|
|
);
|
|
|
|
$polyline->simplify(25);
|
|
|
|
is_deeply $polyline->pp, [ [0, 0], [50, 50], [125, -25], [150, 50] ], 'Douglas-Peucker';
|
|
|
|
}
|
|
|
|
|
2014-03-15 15:53:20 +00:00
|
|
|
{
|
|
|
|
my $polyline = Slic3r::Polyline->new(@$points);
|
|
|
|
is $polyline->length, 100*2, 'length';
|
|
|
|
$polyline->extend_end(50);
|
|
|
|
is $polyline->length, 100*2 + 50, 'extend_end';
|
|
|
|
$polyline->extend_start(50);
|
|
|
|
is $polyline->length, 100*2 + 50 + 50, 'extend_start';
|
|
|
|
}
|
|
|
|
|
2013-07-15 21:23:35 +00:00
|
|
|
__END__
|