45 lines
1.2 KiB
Perl
45 lines
1.2 KiB
Perl
#!/usr/bin/perl
|
|
|
|
use strict;
|
|
use warnings;
|
|
|
|
use Slic3r::XS;
|
|
use Test::More tests => 10;
|
|
|
|
my $square = [ # ccw
|
|
[100, 100],
|
|
[200, 100],
|
|
[200, 200],
|
|
[100, 200],
|
|
];
|
|
|
|
my $polygon = Slic3r::Polygon->new(@$square);
|
|
is_deeply $polygon->pp, $square, 'polygon roundtrip';
|
|
|
|
is ref($polygon->arrayref), 'ARRAY', 'polygon arrayref is unblessed';
|
|
isa_ok $polygon->[0], 'Slic3r::Point', 'polygon point is blessed';
|
|
|
|
my $lines = $polygon->lines;
|
|
is_deeply [ map $_->pp, @$lines ], [
|
|
[ [100, 100], [200, 100] ],
|
|
[ [200, 100], [200, 200] ],
|
|
[ [200, 200], [100, 200] ],
|
|
[ [100, 200], [100, 100] ],
|
|
], 'polygon lines';
|
|
|
|
is_deeply $polygon->split_at_first_point->pp, [ @$square[0,1,2,3,0] ], 'split_at_first_point';
|
|
is_deeply $polygon->split_at_index(2)->pp, [ @$square[2,3,0,1,2] ], 'split_at_index';
|
|
|
|
ok $polygon->is_counter_clockwise, 'is_counter_clockwise';
|
|
{
|
|
my $clone = $polygon->clone;
|
|
$clone->reverse;
|
|
ok !$clone->is_counter_clockwise, 'is_counter_clockwise';
|
|
$clone->make_counter_clockwise;
|
|
ok $clone->is_counter_clockwise, 'make_counter_clockwise';
|
|
$clone->make_counter_clockwise;
|
|
ok $clone->is_counter_clockwise, 'make_counter_clockwise';
|
|
}
|
|
|
|
__END__
|