mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-01 09:49:45 +00:00
Fixed typo in find_circle_3points()
This commit is contained in:
parent
1e0ca09182
commit
0843bf7362
1 changed files with 33 additions and 3 deletions
|
@ -107,10 +107,18 @@ function distance_from_line(line, pt) =
|
||||||
// Usage:
|
// Usage:
|
||||||
// line_normal([P1,P2])
|
// line_normal([P1,P2])
|
||||||
// line_normal(p1,p2)
|
// line_normal(p1,p2)
|
||||||
// Description: Returns the 2D normal vector to the given 2D line.
|
// Description:
|
||||||
|
// Returns the 2D normal vector to the given 2D line. This is otherwise known as the perpendicular vector counter-clockwise to the given ray.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// p1 = First point on 2D line.
|
// p1 = First point on 2D line.
|
||||||
// p2 = Second point on 2D line.
|
// p2 = Second point on 2D line.
|
||||||
|
// Example(2D):
|
||||||
|
// p1 = [10,10];
|
||||||
|
// p2 = [50,30];
|
||||||
|
// n = line_normal(p1,p2);
|
||||||
|
// stroke([p1,p2], endcap2="arrow2");
|
||||||
|
// color("green") stroke([p1,p1+10*n], endcap2="arrow2");
|
||||||
|
// color("blue") place_copies([p1,p2]) circle(d=2, $fn=12);
|
||||||
function line_normal(p1,p2) =
|
function line_normal(p1,p2) =
|
||||||
is_undef(p2)? line_normal(p1[0],p1[1]) :
|
is_undef(p2)? line_normal(p1[0],p1[1]) :
|
||||||
normalize([p1.y-p2.y,p2.x-p1.x]);
|
normalize([p1.y-p2.y,p2.x-p1.x]);
|
||||||
|
@ -191,6 +199,22 @@ function line_segment_intersection(line,segment,eps=EPSILON) =
|
||||||
// pt3 = A point that the second ray passes though.
|
// pt3 = A point that the second ray passes though.
|
||||||
// r = The radius of the circle to find.
|
// r = The radius of the circle to find.
|
||||||
// d = The diameter of the circle to find.
|
// d = The diameter of the circle to find.
|
||||||
|
// Example(2D):
|
||||||
|
// pts = [[60,40], [10,10], [65,5]];
|
||||||
|
// rad = 10;
|
||||||
|
// stroke([pts[1],pts[0]], endcap2="arrow2");
|
||||||
|
// stroke([pts[1],pts[2]], endcap2="arrow2");
|
||||||
|
// circ = find_circle_2tangents(pt1=pts[0], pt2=pts[1], pt3=pts[2], r=rad);
|
||||||
|
// translate(circ[0]) {
|
||||||
|
// color("green") {
|
||||||
|
// stroke(circle(r=rad),closed=true);
|
||||||
|
// stroke([[0,0],rad*[cos(315),sin(315)]]);
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// place_copies(pts) color("blue") circle(d=2, $fn=12);
|
||||||
|
// translate(circ[0]) color("red") circle(d=2, $fn=12);
|
||||||
|
// labels = [[pts[0], "pt1"], [pts[1],"pt2"], [pts[2],"pt3"], [circ[0], "CP"], [circ[0]+[cos(315),sin(315)]*rad*0.7, "r"]];
|
||||||
|
// for(l=labels) translate(l[0]+[0,2]) color("black") text(text=l[1], size=2.5, halign="center");
|
||||||
function find_circle_2tangents(pt1, pt2, pt3, r=undef, d=undef) =
|
function find_circle_2tangents(pt1, pt2, pt3, r=undef, d=undef) =
|
||||||
let(
|
let(
|
||||||
r = get_radius(r=r, d=d, dflt=undef),
|
r = get_radius(r=r, d=d, dflt=undef),
|
||||||
|
@ -221,6 +245,12 @@ function find_circle_2tangents(pt1, pt2, pt3, r=undef, d=undef) =
|
||||||
// pt1 = The first point.
|
// pt1 = The first point.
|
||||||
// pt2 = The second point.
|
// pt2 = The second point.
|
||||||
// pt3 = The third point.
|
// pt3 = The third point.
|
||||||
|
// Example(2D):
|
||||||
|
// pts = [[60,40], [10,10], [65,5]];
|
||||||
|
// circ = find_circle_3points(pts[0], pts[1], pts[2]);
|
||||||
|
// translate(circ[0]) color("green") stroke(circle(r=circ[1]),closed=true,$fn=72);
|
||||||
|
// translate(circ[0]) color("red") circle(d=3, $fn=12);
|
||||||
|
// place_copies(pts) color("blue") circle(d=3, $fn=12);
|
||||||
function find_circle_3points(pt1, pt2, pt3) =
|
function find_circle_3points(pt1, pt2, pt3) =
|
||||||
collinear(pt1,pt2,pt3)? [undef,undef,undef] :
|
collinear(pt1,pt2,pt3)? [undef,undef,undef] :
|
||||||
let(
|
let(
|
||||||
|
@ -247,7 +277,7 @@ function find_circle_3points(pt1, pt2, pt3) =
|
||||||
l2 = [mp2, mp2+mpv2],
|
l2 = [mp2, mp2+mpv2],
|
||||||
isect = line_intersection(l1,l2)
|
isect = line_intersection(l1,l2)
|
||||||
) is_undef(isect)? [undef,undef,undef] : let(
|
) is_undef(isect)? [undef,undef,undef] : let(
|
||||||
r = norm(p2-isect)
|
r = norm(pt2-isect)
|
||||||
) [isect, r, n2];
|
) [isect, r, n2];
|
||||||
|
|
||||||
|
|
||||||
|
@ -663,7 +693,7 @@ function point_in_region(point, region, eps=EPSILON, _i=0, _cnt=0) =
|
||||||
// pointlist_bounds(pts);
|
// pointlist_bounds(pts);
|
||||||
// Description:
|
// Description:
|
||||||
// Finds the bounds containing all the 2D or 3D points in `pts`.
|
// Finds the bounds containing all the 2D or 3D points in `pts`.
|
||||||
// Returns [[minx, miny, minz], [maxx, maxy, maxz]]
|
// Returns `[[MINX, MINY, MINZ], [MAXX, MAXY, MAXZ]]`
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// pts = List of points.
|
// pts = List of points.
|
||||||
function pointlist_bounds(pts) = [
|
function pointlist_bounds(pts) = [
|
||||||
|
|
Loading…
Reference in a new issue