9
use lib "$FindBin::Bin/../lib";
13
use Slic3r::Geometry qw(PI polygon_is_convex
14
chained_path_from epsilon scale);
17
# this test was failing on Windows (GH #1950)
18
my $polygon = Slic3r::Polygon->new(
19
[207802834,-57084522],[196528149,-37556190],[173626821,-25420928],[171285751,-21366123],
20
[118673592,-21366123],[116332562,-25420928],[93431208,-37556191],[82156517,-57084523],
21
[129714478,-84542120],[160244873,-84542120],
23
my $point = Slic3r::Point->new(95706562, -57294774);
24
ok $polygon->contains_point($point), 'contains_point';
27
#==========================================================
29
my $line1 = [ [5, 15], [30, 15] ];
30
my $line2 = [ [10, 20], [10, 10] ];
31
is_deeply Slic3r::Geometry::line_intersection($line1, $line2, 1)->arrayref, [10, 15], 'line_intersection';
33
#==========================================================
35
$line1 = [ [73.6310778185108/0.0000001, 371.74239268924/0.0000001], [73.6310778185108/0.0000001, 501.74239268924/0.0000001] ];
36
$line2 = [ [75/0.0000001, 437.9853/0.0000001], [62.7484/0.0000001, 440.4223/0.0000001] ];
37
isnt Slic3r::Geometry::line_intersection($line1, $line2, 1), undef, 'line_intersection';
39
#==========================================================
42
my $polygon = Slic3r::Polygon->new(
43
[45919000, 515273900], [14726100, 461246400], [14726100, 348753500], [33988700, 315389800],
44
[43749700, 343843000], [45422300, 352251500], [52362100, 362637800], [62748400, 369577600],
45
[75000000, 372014700], [87251500, 369577600], [97637800, 362637800], [104577600, 352251500],
46
[107014700, 340000000], [104577600, 327748400], [97637800, 317362100], [87251500, 310422300],
47
[82789200, 309534700], [69846100, 294726100], [254081000, 294726100], [285273900, 348753500],
48
[285273900, 461246400], [254081000, 515273900],
51
# this points belongs to $polyline
52
# note: it's actually a vertex, while we should better check an intermediate point
53
my $point = Slic3r::Point->new(104577600, 327748400);
55
local $Slic3r::Geometry::epsilon = 1E-5;
56
is_deeply Slic3r::Geometry::polygon_segment_having_point($polygon, $point)->pp,
57
[ [107014700, 340000000], [104577600, 327748400] ],
58
'polygon_segment_having_point';
61
#==========================================================
64
my $point = Slic3r::Point->new(736310778.185108, 5017423926.8924);
65
my $line = Slic3r::Line->new([627484000, 3695776000], [750000000, 3720147000]);
66
is Slic3r::Geometry::point_in_segment($point, $line), 0, 'point_in_segment';
69
#==========================================================
72
my $point = Slic3r::Point->new(736310778.185108, 5017423926.8924);
73
my $line = Slic3r::Line->new([627484000, 3695776000], [750000000, 3720147000]);
74
is Slic3r::Geometry::point_in_segment($point, $line), 0, 'point_in_segment';
77
#==========================================================
80
Slic3r::Polygon->new( # contour, ccw
81
[45919000, 515273900], [14726100, 461246400], [14726100, 348753500], [33988700, 315389800],
82
[43749700, 343843000], [45422300, 352251500], [52362100, 362637800], [62748400, 369577600],
83
[75000000, 372014700], [87251500, 369577600], [97637800, 362637800], [104577600, 352251500],
84
[107014700, 340000000], [104577600, 327748400], [97637800, 317362100], [87251500, 310422300],
85
[82789200, 309534700], [69846100, 294726100], [254081000, 294726100], [285273900, 348753500],
86
[285273900, 461246400], [254081000, 515273900],
89
Slic3r::Polygon->new( # hole, cw
90
[75000000, 502014700], [87251500, 499577600], [97637800, 492637800], [104577600, 482251500],
91
[107014700, 470000000], [104577600, 457748400], [97637800, 447362100], [87251500, 440422300],
92
[75000000, 437985300], [62748400, 440422300], [52362100, 447362100], [45422300, 457748400],
93
[42985300, 470000000], [45422300, 482251500], [52362100, 492637800], [62748400, 499577600],
97
#==========================================================
106
is Slic3r::Geometry::angle3points($p2, $p3, $p1), PI(), 'angle3points';
107
is Slic3r::Geometry::angle3points($p2, $p1, $p3), PI(), 'angle3points';
108
is Slic3r::Geometry::angle3points($p2, $p3, $p4), PI()/2*3, 'angle3points';
109
is Slic3r::Geometry::angle3points($p2, $p4, $p3), PI()/2, 'angle3points';
110
is Slic3r::Geometry::angle3points($p2, $p1, $p4), PI()/2, 'angle3points';
111
is Slic3r::Geometry::angle3points($p2, $p1, $p5), PI()/2*3, 'angle3points';
120
is Slic3r::Geometry::angle3points($p2, $p1, $p3), PI(), 'angle3points';
121
is Slic3r::Geometry::angle3points($p2, $p1, $p4), PI()/2*3, 'angle3points';
122
is Slic3r::Geometry::angle3points($p2, $p1, $p1), 2*PI(), 'angle3points';
125
#==========================================================
128
my $cw_square = [ [0,0], [0,10], [10,10], [10,0] ];
129
is polygon_is_convex($cw_square), 0, 'cw square is not convex';
130
is polygon_is_convex([ reverse @$cw_square ]), 1, 'ccw square is convex';
132
my $convex1 = [ [0,0], [10,0], [10,10], [0,10], [0,6], [4,6], [4,4], [0,4] ];
133
is polygon_is_convex($convex1), 0, 'concave polygon';
136
#==========================================================
139
my $polyline = Slic3r::Polyline->new([0, 0], [10, 0], [20, 0]);
140
is_deeply [ map $_->pp, @{$polyline->lines} ], [
142
[ [10, 0], [20, 0] ],
146
#==========================================================
149
my $polygon = Slic3r::Polygon->new([0, 0], [10, 0], [5, 5]);
150
my $result = $polygon->split_at_index(1);
151
is ref($result), 'Slic3r::Polyline', 'split_at_index returns polyline';
152
is_deeply $result->pp, [ [10, 0], [5, 5], [0, 0], [10, 0] ], 'split_at_index';
155
#==========================================================
158
my $bb = Slic3r::Geometry::BoundingBox->new_from_points([ map Slic3r::Point->new(@$_), [0, 1], [10, 2], [20, 2] ]);
160
is_deeply [ $bb->min_point->pp, $bb->max_point->pp ], [ [0,2], [40,4] ], 'bounding box is scaled correctly';
163
#==========================================================
166
my $line = Slic3r::Line->new([10,10], [20,10]);
167
is $line->grow(5)->[0]->area, Slic3r::Polygon->new([10,5], [20,5], [20,15], [10,15])->area, 'grow line';
170
#==========================================================
173
# if chained_path() works correctly, these points should be joined with no diagonal paths
174
# (thus 26 units long)
175
my @points = map Slic3r::Point->new_scale(@$_), [26,26],[52,26],[0,26],[26,52],[26,0],[0,52],[52,52],[52,0];
176
my @ordered = @points[@{chained_path_from(\@points, $points[0])}];
177
ok !(grep { abs($ordered[$_]->distance_to($ordered[$_+1]) - scale 26) > epsilon } 0..$#ordered-1), 'chained_path';
180
#==========================================================
183
my $line = Slic3r::Line->new([0, 0], [20, 0]);
184
is +Slic3r::Point->new(10, 10)->distance_to_line($line), 10, 'distance_to';
185
is +Slic3r::Point->new(50, 10)->distance_to_line($line), 10, 'distance_to';
186
is +Slic3r::Point->new(0, 0)->distance_to_line($line), 0, 'distance_to';
187
is +Slic3r::Point->new(20, 0)->distance_to_line($line), 0, 'distance_to';
188
is +Slic3r::Point->new(10, 0)->distance_to_line($line), 0, 'distance_to';
191
#==========================================================
194
my $square = Slic3r::Polygon->new(
201
is scalar(@{$square->concave_points(PI*4/3)}), 0, 'no concave vertices detected in convex polygon';
202
is scalar(@{$square->convex_points(PI*2/3)}), 4, 'four convex vertices detected in square';
206
my $square = Slic3r::Polygon->new(
213
is scalar(@{$square->concave_points(PI*4/3)}), 0, 'no concave vertices detected in convex polygon';
214
is scalar(@{$square->convex_points(PI*2/3)}), 4, 'four convex vertices detected in square';