mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-19 19:09:36 +00:00
special case teardrop $fn=6
This commit is contained in:
parent
93230f2af2
commit
dbb20fa92a
1 changed files with 4 additions and 2 deletions
|
@ -1251,7 +1251,9 @@ function teardrop2d(r, ang=45, cap_h, d, circum=false, realign=false, anchor=CEN
|
||||||
fullcircle = ellipse(r=r, realign=realign, circum=circum,spin=90),
|
fullcircle = ellipse(r=r, realign=realign, circum=circum,spin=90),
|
||||||
|
|
||||||
// Chose the point on the circle that is lower than the cap but also creates a segment bigger than
|
// Chose the point on the circle that is lower than the cap but also creates a segment bigger than
|
||||||
// seglen/3 so we don't have a teeny tiny segment at the end of the cap
|
// seglen/skipfactor so we don't have a teeny tiny segment at the end of the cap, except for the hexagoin
|
||||||
|
// case which is treated specially
|
||||||
|
skipfactor = len(fullcircle)==6 ? 15 : 3,
|
||||||
path = !circum ?
|
path = !circum ?
|
||||||
let(seglen = norm(fullcircle[0]-fullcircle[1]))
|
let(seglen = norm(fullcircle[0]-fullcircle[1]))
|
||||||
[
|
[
|
||||||
|
@ -1259,7 +1261,7 @@ function teardrop2d(r, ang=45, cap_h, d, circum=false, realign=false, anchor=CEN
|
||||||
for (p=fullcircle)
|
for (p=fullcircle)
|
||||||
if (
|
if (
|
||||||
p.y<last(cap).y-EPSILON
|
p.y<last(cap).y-EPSILON
|
||||||
&& norm([abs(p.x)-last(cap).x,p.y-last(cap.y)])>seglen/3
|
&& norm([abs(p.x)-last(cap).x,p.y-last(cap.y)])>seglen/skipfactor
|
||||||
) p,
|
) p,
|
||||||
xflip(cap[1]),
|
xflip(cap[1]),
|
||||||
if (_extrapt || !pointycap) xflip(cap[0])
|
if (_extrapt || !pointycap) xflip(cap[0])
|
||||||
|
|
Loading…
Reference in a new issue