mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-24 09:11:23 -06:00
This commit is contained in:
parent
4250ebf644
commit
e024b08762
3 changed files with 21 additions and 19 deletions
24
t/geometry.t
24
t/geometry.t
|
@ -69,25 +69,25 @@ isnt Slic3r::Geometry::line_intersection($line1, $line2, 1), undef, 'line_inters
|
||||||
|
|
||||||
my $polygons = [
|
my $polygons = [
|
||||||
Slic3r::Polygon->new( # contour, ccw
|
Slic3r::Polygon->new( # contour, ccw
|
||||||
[459190000, 5152739000], [147261000, 4612464000], [147261000, 3487535000], [339887000, 3153898000],
|
[45919000, 515273900], [14726100, 461246400], [14726100, 348753500], [33988700, 315389800],
|
||||||
[437497000, 3438430000], [454223000, 3522515000], [523621000, 3626378000], [627484000, 3695776000],
|
[43749700, 343843000], [45422300, 352251500], [52362100, 362637800], [62748400, 369577600],
|
||||||
[750000000, 3720147000], [872515000, 3695776000], [976378000, 3626378000], [1045776000, 3522515000],
|
[75000000, 372014700], [87251500, 369577600], [97637800, 362637800], [104577600, 352251500],
|
||||||
[1070147000, 3400000000], [1045776000, 3277484000], [976378000, 3173621000], [872515000, 3104223000],
|
[107014700, 340000000], [104577600, 327748400], [97637800, 317362100], [87251500, 310422300],
|
||||||
[827892000, 3095347000], [698461000, 2947261000], [2540810000, 2947261000], [2852739000, 3487535000],
|
[82789200, 309534700], [69846100, 294726100], [254081000, 294726100], [285273900, 348753500],
|
||||||
[2852739000, 4612464000], [2540810000, 5152739000],
|
[285273900, 461246400], [254081000, 515273900],
|
||||||
|
|
||||||
),
|
),
|
||||||
Slic3r::Polygon->new( # hole, cw
|
Slic3r::Polygon->new( # hole, cw
|
||||||
[750000000, 5020147000], [872515000, 4995776000], [976378000, 4926378000], [1045776000, 4822515000],
|
[75000000, 502014700], [87251500, 499577600], [97637800, 492637800], [104577600, 482251500],
|
||||||
[1070147000, 4700000000], [1045776000, 4577484000], [976378000, 4473621000], [872515000, 4404223000],
|
[107014700, 470000000], [104577600, 457748400], [97637800, 447362100], [87251500, 440422300],
|
||||||
[750000000, 4379853000], [627484000, 4404223000], [523621000, 4473621000], [454223000, 4577484000],
|
[75000000, 437985300], [62748400, 440422300], [52362100, 447362100], [45422300, 457748400],
|
||||||
[429853000, 4700000000], [454223000, 4822515000], [523621000, 4926378000], [627484000, 4995776000],
|
[42985300, 470000000], [45422300, 482251500], [52362100, 492637800], [62748400, 499577600],
|
||||||
),
|
),
|
||||||
];
|
];
|
||||||
|
|
||||||
my $points = [
|
my $points = [
|
||||||
Slic3r::Point->new(736310778.185108, 3717423926.892399788),
|
Slic3r::Point->new(73631077, 371742392),
|
||||||
Slic3r::Point->new(736310778.185108, 5017423926.8924),
|
Slic3r::Point->new(73631077, 501742392),
|
||||||
];
|
];
|
||||||
|
|
||||||
is Slic3r::Geometry::can_connect_points(@$points, $polygons), 0, 'can_connect_points';
|
is Slic3r::Geometry::can_connect_points(@$points, $polygons), 0, 'can_connect_points';
|
||||||
|
|
10
t/polyclip.t
10
t/polyclip.t
|
@ -114,7 +114,7 @@ is_deeply $intersection, [ [120, 120], [180, 160] ], 'internal lines are preserv
|
||||||
#==========================================================
|
#==========================================================
|
||||||
|
|
||||||
{
|
{
|
||||||
my $large_circle = Slic3r::Polygon->new( # ccw
|
my $large_circle = Slic3r::Polygon->new_scale( # ccw
|
||||||
[151.8639,288.1192], [133.2778,284.6011], [115.0091,279.6997], [98.2859,270.8606], [82.2734,260.7933],
|
[151.8639,288.1192], [133.2778,284.6011], [115.0091,279.6997], [98.2859,270.8606], [82.2734,260.7933],
|
||||||
[68.8974,247.4181], [56.5622,233.0777], [47.7228,216.3558], [40.1617,199.0172], [36.6431,180.4328],
|
[68.8974,247.4181], [56.5622,233.0777], [47.7228,216.3558], [40.1617,199.0172], [36.6431,180.4328],
|
||||||
[34.932,165.2312], [37.5567,165.1101], [41.0547,142.9903], [36.9056,141.4295], [40.199,124.1277],
|
[34.932,165.2312], [37.5567,165.1101], [41.0547,142.9903], [36.9056,141.4295], [40.199,124.1277],
|
||||||
|
@ -127,7 +127,7 @@ is_deeply $intersection, [ [120, 120], [180, 160] ], 'internal lines are preserv
|
||||||
);
|
);
|
||||||
ok $large_circle->is_counter_clockwise, "contour is counter-clockwise";
|
ok $large_circle->is_counter_clockwise, "contour is counter-clockwise";
|
||||||
|
|
||||||
my $small_circle = Slic3r::Polygon->new( # cw
|
my $small_circle = Slic3r::Polygon->new_scale( # cw
|
||||||
[158.227,215.9007], [164.5136,215.9007], [175.15,214.5007], [184.5576,210.6044], [190.2268,207.8743],
|
[158.227,215.9007], [164.5136,215.9007], [175.15,214.5007], [184.5576,210.6044], [190.2268,207.8743],
|
||||||
[199.1462,201.0306], [209.0146,188.346], [213.5135,177.4829], [214.6979,168.4866], [216.1025,162.3325],
|
[199.1462,201.0306], [209.0146,188.346], [213.5135,177.4829], [214.6979,168.4866], [216.1025,162.3325],
|
||||||
[214.6463,151.2703], [213.2471,145.1399], [209.0146,134.9203], [199.1462,122.2357], [189.8944,115.1366],
|
[214.6463,151.2703], [213.2471,145.1399], [209.0146,134.9203], [199.1462,122.2357], [189.8944,115.1366],
|
||||||
|
@ -139,12 +139,12 @@ is_deeply $intersection, [ [120, 120], [180, 160] ], 'internal lines are preserv
|
||||||
ok $small_circle->is_clockwise, "hole is clockwise";
|
ok $small_circle->is_clockwise, "hole is clockwise";
|
||||||
|
|
||||||
my $expolygon = Slic3r::ExPolygon->new($large_circle, $small_circle);
|
my $expolygon = Slic3r::ExPolygon->new($large_circle, $small_circle);
|
||||||
$line = Slic3r::Line->new([152.742,288.086671142818], [152.742,34.166466971035]);
|
$line = Slic3r::Line->new_scale([152.742,288.086671142818], [152.742,34.166466971035]);
|
||||||
|
|
||||||
my $intersections = $expolygon->clip_line($line);
|
my $intersections = $expolygon->clip_line($line);
|
||||||
is_deeply [ map $_->pp, @$intersections ], [
|
is_deeply [ map $_->pp, @$intersections ], [
|
||||||
[ [152, 287], [152, 214], ],
|
[ [152742000, 288086661], [152742000, 215178843], ],
|
||||||
[ [152, 107], [152, 35] ],
|
[ [152742000, 108087507], [152742000, 35166477] ],
|
||||||
], 'line is clipped to square with hole';
|
], 'line is clipped to square with hole';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -112,8 +112,10 @@ void
|
||||||
Point::from_SV(SV* point_sv)
|
Point::from_SV(SV* point_sv)
|
||||||
{
|
{
|
||||||
AV* point_av = (AV*)SvRV(point_sv);
|
AV* point_av = (AV*)SvRV(point_sv);
|
||||||
this->x = (long)SvIV(*av_fetch(point_av, 0, 0));
|
// get a double from Perl and round it, otherwise
|
||||||
this->y = (long)SvIV(*av_fetch(point_av, 1, 0));
|
// it would get truncated
|
||||||
|
this->x = lrint(SvNV(*av_fetch(point_av, 0, 0)));
|
||||||
|
this->y = lrint(SvNV(*av_fetch(point_av, 1, 0)));
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue