mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-01 09:49:45 +00:00
Added path_pos_from_start(), path_pos_from_end(), path_trim_start(), path_trim_end()
This commit is contained in:
parent
f740051ad1
commit
cee46b1721
2 changed files with 107 additions and 1 deletions
106
paths.scad
106
paths.scad
|
@ -52,6 +52,112 @@ function path_length(path,closed=false) =
|
||||||
sum([for (i = [0:1:len(path)-2]) norm(path[i+1]-path[i])])+(closed?norm(path[len(path)-1]-path[0]):0);
|
sum([for (i = [0:1:len(path)-2]) norm(path[i+1]-path[i])])+(closed?norm(path[len(path)-1]-path[0]):0);
|
||||||
|
|
||||||
|
|
||||||
|
// Function: path_pos_from_start()
|
||||||
|
// Usage:
|
||||||
|
// pos = path_pos_from_start(path,length,[closed]);
|
||||||
|
// Description:
|
||||||
|
// Finds the segment and relative position along that segment that is `length` distance from the
|
||||||
|
// front of the given `path`. Returned as [SEGNUM, U] where SEGNUM is the segment number, and U is
|
||||||
|
// the relative distance along that segment, a number from 0 to 1. If the path is shorter than the
|
||||||
|
// asked for length, this returns `undef`.
|
||||||
|
// Arguments:
|
||||||
|
// path = The path to find the position on.
|
||||||
|
// length = The length from the start of the path to find the segment and position of.
|
||||||
|
// Example(2D):
|
||||||
|
// path = circle(d=50,$fn=18);
|
||||||
|
// pos = path_pos_from_start(path,20,closed=false);
|
||||||
|
// stroke(path,width=1,endcaps=false);
|
||||||
|
// pt = lerp(path[pos[0]], path[(pos[0]+1)%len(path)], pos[1]);
|
||||||
|
// color("red") translate(pt) circle(d=2,$fn=12);
|
||||||
|
function path_pos_from_start(path,length,closed=false,_d=0,_i=0) =
|
||||||
|
let (lp = len(path))
|
||||||
|
_i >= lp - (closed?0:1)? undef :
|
||||||
|
let (l = norm(path[(_i+1)%lp]-path[_i]))
|
||||||
|
_d+l <= length? path_pos_from_start(path,length,closed,_d+l,_i+1) :
|
||||||
|
[_i, (length-_d)/l];
|
||||||
|
|
||||||
|
|
||||||
|
// Function: path_pos_from_end()
|
||||||
|
// Usage:
|
||||||
|
// pos = path_pos_from_end(path,length,[closed]);
|
||||||
|
// Description:
|
||||||
|
// Finds the segment and relative position along that segment that is `length` distance from the
|
||||||
|
// end of the given `path`. Returned as [SEGNUM, U] where SEGNUM is the segment number, and U is
|
||||||
|
// the relative distance along that segment, a number from 0 to 1. If the path is shorter than the
|
||||||
|
// asked for length, this returns `undef`.
|
||||||
|
// Arguments:
|
||||||
|
// path = The path to find the position on.
|
||||||
|
// length = The length from the end of the path to find the segment and position of.
|
||||||
|
// Example(2D):
|
||||||
|
// path = circle(d=50,$fn=18);
|
||||||
|
// pos = path_pos_from_end(path,20,closed=false);
|
||||||
|
// stroke(path,width=1,endcaps=false);
|
||||||
|
// pt = lerp(path[pos[0]], path[(pos[0]+1)%len(path)], pos[1]);
|
||||||
|
// color("red") translate(pt) circle(d=2,$fn=12);
|
||||||
|
function path_pos_from_end(path,length,closed=false,_d=0,_i=undef) =
|
||||||
|
let (
|
||||||
|
lp = len(path),
|
||||||
|
_i = _i!=undef? _i : lp - (closed?1:2)
|
||||||
|
)
|
||||||
|
_i < 0? undef :
|
||||||
|
let (l = norm(path[(_i+1)%lp]-path[_i]))
|
||||||
|
_d+l <= length? path_pos_from_end(path,length,closed,_d+l,_i-1) :
|
||||||
|
[_i, 1-(length-_d)/l];
|
||||||
|
|
||||||
|
|
||||||
|
// Function: path_trim_start()
|
||||||
|
// Usage:
|
||||||
|
// path_trim_start(path,trim);
|
||||||
|
// Description:
|
||||||
|
// Returns the `path`, with the start shortened by the length `trim`.
|
||||||
|
// Arguments:
|
||||||
|
// path = The path to trim.
|
||||||
|
// trim = The length to trim from the start.
|
||||||
|
// Example(2D):
|
||||||
|
// path = circle(d=50,$fn=18);
|
||||||
|
// path2 = path_trim_start(path,5);
|
||||||
|
// path3 = path_trim_start(path,20);
|
||||||
|
// color("blue") stroke(path3,width=5,endcaps=false);
|
||||||
|
// color("cyan") stroke(path2,width=3,endcaps=false);
|
||||||
|
// color("red") stroke(path,width=1,endcaps=false);
|
||||||
|
function path_trim_start(path,trim,_d=0,_i=0) =
|
||||||
|
_i >= len(path)-1? [] :
|
||||||
|
let (l = norm(path[_i+1]-path[_i]))
|
||||||
|
_d+l <= trim? path_trim_start(path,trim,_d+l,_i+1) :
|
||||||
|
let (v = normalize(path[_i+1]-path[_i]))
|
||||||
|
concat(
|
||||||
|
[path[_i+1]-v*(l-(trim-_d))],
|
||||||
|
[for (i=[_i+1:1:len(path)-1]) path[i]]
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
// Function: path_trim_end()
|
||||||
|
// Usage:
|
||||||
|
// path_trim_end(path,trim);
|
||||||
|
// Description:
|
||||||
|
// Returns the `path`, with the end shortened by the length `trim`.
|
||||||
|
// Arguments:
|
||||||
|
// path = The path to trim.
|
||||||
|
// trim = The length to trim from the end.
|
||||||
|
// Example(2D):
|
||||||
|
// path = circle(d=50,$fn=18);
|
||||||
|
// path2 = path_trim_end(path,5);
|
||||||
|
// path3 = path_trim_end(path,20);
|
||||||
|
// color("blue") stroke(path3,width=5,endcaps=false);
|
||||||
|
// color("cyan") stroke(path2,width=3,endcaps=false);
|
||||||
|
// color("red") stroke(path,width=1,endcaps=false);
|
||||||
|
function path_trim_end(path,trim,_d=0,_i=undef) =
|
||||||
|
let (_i = _i!=undef? _i : len(path)-1)
|
||||||
|
_i <= 0? [] :
|
||||||
|
let (l = norm(path[_i]-path[_i-1]))
|
||||||
|
_d+l <= trim? path_trim_end(path,trim,_d+l,_i-1) :
|
||||||
|
let (v = normalize(path[_i]-path[_i-1]))
|
||||||
|
concat(
|
||||||
|
[for (i=[0:1:_i-1]) path[i]],
|
||||||
|
[path[_i-1]+v*(l-(trim-_d))]
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
// Function: path_closest_point()
|
// Function: path_closest_point()
|
||||||
// Usage:
|
// Usage:
|
||||||
// path_closest_point(path, pt);
|
// path_closest_point(path, pt);
|
||||||
|
|
|
@ -8,7 +8,7 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
BOSL_VERSION = [2,0,97];
|
BOSL_VERSION = [2,0,98];
|
||||||
|
|
||||||
|
|
||||||
// Section: BOSL Library Version Functions
|
// Section: BOSL Library Version Functions
|
||||||
|
|
Loading…
Reference in a new issue