polyclip.t 838 B

12345678910111213141516171819202122232425262728293031
  1. use Test::More;
  2. plan tests => 4;
  3. BEGIN {
  4. use FindBin;
  5. use lib "$FindBin::Bin/../lib";
  6. }
  7. use Slic3r;
  8. my $square = [
  9. [10, 10],
  10. [20, 10],
  11. [20, 20],
  12. [10, 20],
  13. ];
  14. my $line = [ [5, 15], [30, 15] ];
  15. my $intersection = Slic3r::Geometry::clip_segment_polygon($line, $square);
  16. is_deeply $intersection, [ [10, 15], [20, 15] ], 'line is clipped to square';
  17. $intersection = Slic3r::Geometry::clip_segment_polygon([ [0, 15], [8, 15] ], $square);
  18. is $intersection, undef, 'external lines are ignored 1';
  19. $intersection = Slic3r::Geometry::clip_segment_polygon([ [30, 15], [40, 15] ], $square);
  20. is $intersection, undef, 'external lines are ignored 2';
  21. $intersection = Slic3r::Geometry::clip_segment_polygon([ [12, 12], [18, 16] ], $square);
  22. is_deeply $intersection, [ [12, 12], [18, 16] ], 'internal lines are preserved';