06_polygon.t 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. #!/usr/bin/perl
  2. use strict;
  3. use warnings;
  4. use Slic3r::XS;
  5. use Test::More tests => 10;
  6. my $square = [ # ccw
  7. [100, 100],
  8. [200, 100],
  9. [200, 200],
  10. [100, 200],
  11. ];
  12. my $polygon = Slic3r::Polygon->new(@$square);
  13. is_deeply $polygon->pp, $square, 'polygon roundtrip';
  14. is ref($polygon->arrayref), 'ARRAY', 'polygon arrayref is unblessed';
  15. isa_ok $polygon->[0], 'Slic3r::Point', 'polygon point is blessed';
  16. my $lines = $polygon->lines;
  17. is_deeply [ map $_->pp, @$lines ], [
  18. [ [100, 100], [200, 100] ],
  19. [ [200, 100], [200, 200] ],
  20. [ [200, 200], [100, 200] ],
  21. [ [100, 200], [100, 100] ],
  22. ], 'polygon lines';
  23. is_deeply $polygon->split_at_first_point->pp, [ @$square[0,1,2,3,0] ], 'split_at_first_point';
  24. is_deeply $polygon->split_at_index(2)->pp, [ @$square[2,3,0,1,2] ], 'split_at_index';
  25. ok $polygon->is_counter_clockwise, 'is_counter_clockwise';
  26. {
  27. my $clone = $polygon->clone;
  28. $clone->reverse;
  29. ok !$clone->is_counter_clockwise, 'is_counter_clockwise';
  30. $clone->make_counter_clockwise;
  31. ok $clone->is_counter_clockwise, 'make_counter_clockwise';
  32. $clone->make_counter_clockwise;
  33. ok $clone->is_counter_clockwise, 'make_counter_clockwise';
  34. }
  35. __END__