1
0
mirror of https://github.com/JustinSDK/dotSCAD.git synced 2025-10-03 01:32:03 +02:00
Files
dotSCAD/src/arc_path.scad
2020-01-28 20:49:08 +08:00

27 lines
854 B
OpenSCAD

/**
* arc_shape.scad
*
* @copyright Justin Lin, 2017
* @license https://opensource.org/licenses/lgpl-3.0.html
*
* @see https://openhome.cc/eGossip/OpenSCAD/lib2x-arc_path.html
*
**/
use <__comm__/__frags.scad>;
use <__comm__/__ra_to_xy.scad>;
use <__comm__/__edge_r.scad>;
function arc_path(radius, angle) =
let(
a_step = 360 / __frags(radius),
angles = is_num(angle) ? [0, angle] : angle,
m = floor(angles[0] / a_step) + 1,
n = floor(angles[1] / a_step),
points = concat([__ra_to_xy(__edge_r_begin(radius, angles[0], a_step, m), angles[0])],
m > n ? [] : [
for(i = m; i <= n; i = i + 1)
__ra_to_xy(radius, a_step * i)
],
angles[1] == a_step * n ? [] : [__ra_to_xy(__edge_r_end(radius, angles[1], a_step, n), angles[1])])
) points;