1234567891011121314151617181920212223242526272829303132333435363738394041424344 |
- #!/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__
|