Reworked docs for primitives.scad and shapes2d.scad

This commit is contained in:
Garth Minette 2021-02-25 02:16:55 -08:00
parent ae586738a9
commit 1a7f7ef953
3 changed files with 291 additions and 107 deletions

View File

@ -1038,6 +1038,13 @@ module attach(from, to, overlap, norot=false)
// --- // ---
// d = Diameter of corner mask. // d = Diameter of corner mask.
// convexity = Max number of times a line could intersect the perimeter of the mask shape. Default: 10 // convexity = Max number of times a line could intersect the perimeter of the mask shape. Default: 10
// Side Effects:
// Sets `$tags = "mask"` for all children.
// Example:
// diff("mask")
// cube([50,60,70],center=true)
// face_profile(TOP,except=TOP+LEFT)
// mask2d_roundover(r=10, inset=2);
module face_profile(faces=[], r, d, convexity=10) { module face_profile(faces=[], r, d, convexity=10) {
faces = is_vector(faces)? [faces] : faces; faces = is_vector(faces)? [faces] : faces;
assert(all([for (face=faces) is_vector(face) && sum([for (x=face) x!=0? 1 : 0])==1]), "Vector in faces doesn't point at a face."); assert(all([for (face=faces) is_vector(face) && sum([for (x=face) x!=0? 1 : 0])==1]), "Vector in faces doesn't point at a face.");

View File

@ -11,14 +11,19 @@
// Function&Module: square() // Function&Module: square()
// Usage: // Topics: Shapes (2D), Path Generators (2D)
// square(size, [center]) // Usage: As a Built-in Module
// square(size, <center>);
// Usage: As a Function
// path = square(size, <center>);
// See Also: rect()
// Description: // Description:
// When called as the builtin module, creates a 2D square or rectangle of the given size. // When called as the builtin module, creates a 2D square or rectangle of the given size.
// When called as a function, returns a 2D path/list of points for a square/rectangle of the given size. // When called as a function, returns a 2D path/list of points for a square/rectangle of the given size.
// Arguments: // Arguments:
// size = The size of the square to create. If given as a scalar, both X and Y will be the same size. // size = The size of the square to create. If given as a scalar, both X and Y will be the same size.
// center = If given and true, overrides `anchor` to be `CENTER`. If given and false, overrides `anchor` to be `FRONT+LEFT`. // center = If given and true, overrides `anchor` to be `CENTER`. If given and false, overrides `anchor` to be `FRONT+LEFT`.
// ---
// anchor = (Function only) Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER` // anchor = (Function only) Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
// spin = (Function only) Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0` // spin = (Function only) Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0`
// Example(2D): // Example(2D):
@ -43,14 +48,19 @@ function square(size=1, center, anchor, spin=0) =
// Function&Module: circle() // Function&Module: circle()
// Usage: // Topics: Shapes (2D), Path Generators (2D)
// circle(r|d) // Usage: As a Built-in Module
// circle(r|d=, ...);
// Usage: As a Function
// path = circle(r|d=, ...);
// See Also: oval()
// Description: // Description:
// When called as the builtin module, creates a 2D polygon that approximates a circle of the given size. // When called as the builtin module, creates a 2D polygon that approximates a circle of the given size.
// When called as a function, returns a 2D list of points (path) for a polygon that approximates a circle of the given size. // When called as a function, returns a 2D list of points (path) for a polygon that approximates a circle of the given size.
// Arguments: // Arguments:
// r = The radius of the circle to create. // r = The radius of the circle to create.
// d = The diameter of the circle to create. // d = The diameter of the circle to create.
// ---
// anchor = (Function only) Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER` // anchor = (Function only) Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
// spin = (Function only) Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0` // spin = (Function only) Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0`
// Example(2D): By Radius // Example(2D): By Radius
@ -72,10 +82,14 @@ function circle(r, d, anchor=CENTER, spin=0) =
// Function&Module: cube() // Function&Module: cube()
// Topics: Shapes (3D), Attachable, VNF Generators
// Usage: As Module // Usage: As Module
// cube(size, [center]); // cube(size, <center>, ...);
// Usage: With Attachments
// cube(size, <center>, ...) { attachments }
// Usage: As Function // Usage: As Function
// vnf = cube(size, [center]); // vnf = cube(size, <center>, ...);
// See Also: cuboid(), prismoid()
// Description: // Description:
// Creates a 3D cubic object with support for anchoring and attachments. // Creates a 3D cubic object with support for anchoring and attachments.
// This can be used as a drop-in replacement for the built-in `cube()` module. // This can be used as a drop-in replacement for the built-in `cube()` module.
@ -83,6 +97,7 @@ function circle(r, d, anchor=CENTER, spin=0) =
// Arguments: // Arguments:
// size = The size of the cube. // size = The size of the cube.
// center = If given, overrides `anchor`. A true value sets `anchor=CENTER`, false sets `anchor=ALLNEG`. // center = If given, overrides `anchor`. A true value sets `anchor=CENTER`, false sets `anchor=ALLNEG`.
// ---
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER` // anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0` // spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0`
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#orient). Default: `UP` // orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#orient). Default: `UP`
@ -138,12 +153,16 @@ function cube(size=1, center, anchor, spin=0, orient=UP) =
// Function&Module: cylinder() // Function&Module: cylinder()
// Topics: Shapes (3D), Attachable, VNF Generators
// Usage: As Module // Usage: As Module
// cylinder(h, r|d, [center]); // cylinder(h, r=/d=, <center=>, ...);
// cylinder(h, r1/d1, r2/d2, [center]); // cylinder(h, r1/d1=, r2/d2=, <center=>, ...);
// Usage: With Attachments
// cylinder(h, r=/d=, <center=>) {attachments}
// Usage: As Function // Usage: As Function
// vnf = cylinder(h, r|d, [center]); // vnf = cylinder(h, r=/d=, <center=>, ...);
// vnf = cylinder(h, r1/d1, r2/d2, [center]); // vnf = cylinder(h, r1/d1=, r2/d2=, <center=>, ...);
// See Also: cyl()
// Description: // Description:
// Creates a 3D cylinder or conic object with support for anchoring and attachments. // Creates a 3D cylinder or conic object with support for anchoring and attachments.
// This can be used as a drop-in replacement for the built-in `cylinder()` module. // This can be used as a drop-in replacement for the built-in `cylinder()` module.
@ -153,6 +172,7 @@ function cube(size=1, center, anchor, spin=0, orient=UP) =
// r1 = The bottom radius of the cylinder. (Before orientation.) // r1 = The bottom radius of the cylinder. (Before orientation.)
// r2 = The top radius of the cylinder. (Before orientation.) // r2 = The top radius of the cylinder. (Before orientation.)
// center = If given, overrides `anchor`. A true value sets `anchor=CENTER`, false sets `anchor=BOTTOM`. // center = If given, overrides `anchor`. A true value sets `anchor=CENTER`, false sets `anchor=BOTTOM`.
// ---
// d1 = The bottom diameter of the cylinder. (Before orientation.) // d1 = The bottom diameter of the cylinder. (Before orientation.)
// d2 = The top diameter of the cylinder. (Before orientation.) // d2 = The top diameter of the cylinder. (Before orientation.)
// r = The radius of the cylinder. // r = The radius of the cylinder.
@ -230,16 +250,21 @@ function cylinder(h, r1, r2, center, l, r, d, d1, d2, anchor, spin=0, orient=UP)
// Function&Module: sphere() // Function&Module: sphere()
// Topics: Shapes (3D), Attachable, VNF Generators
// Usage: As Module // Usage: As Module
// sphere(r|d, [circum], [style]) // sphere(r|d=, <circum=>, <style=>, ...);
// Usage: With Attachments
// sphere(r|d=, ...) { attachments }
// Usage: As Function // Usage: As Function
// vnf = sphere(r|d, [circum], [style]) // vnf = sphere(r|d=, <circum=>, <style=>, ...);
// See Also: spheroid()
// Description: // Description:
// Creates a sphere object, with support for anchoring and attachments. // Creates a sphere object, with support for anchoring and attachments.
// This is a drop-in replacement for the built-in `sphere()` module. // This is a drop-in replacement for the built-in `sphere()` module.
// When called as a function, returns a [VNF](vnf.scad) for a sphere. // When called as a function, returns a [VNF](vnf.scad) for a sphere.
// Arguments: // Arguments:
// r = Radius of the sphere. // r = Radius of the sphere.
// ---
// d = Diameter of the sphere. // d = Diameter of the sphere.
// circum = If true, the sphere is made large enough to circumscribe the sphere of the ideal side. Otherwise inscribes. Default: false (inscribes) // circum = If true, the sphere is made large enough to circumscribe the sphere of the ideal side. Otherwise inscribes. Default: false (inscribes)
// style = The style of the sphere's construction. One of "orig", "aligned", "stagger", "octa", or "icosa". Default: "orig" // style = The style of the sphere's construction. One of "orig", "aligned", "stagger", "octa", or "icosa". Default: "orig"

View File

@ -10,8 +10,9 @@
// Module: stroke() // Module: stroke()
// Usage: // Usage:
// stroke(path, [width], [closed], [endcaps], [endcap_width], [endcap_length], [endcap_extent], [trim]); // stroke(path, <width>, <closed>, <endcaps>, <endcap_width>, <endcap_length>, <endcap_extent>, <trim>);
// stroke(path, [width], [closed], [endcap1], [endcap2], [endcap_width1], [endcap_width2], [endcap_length1], [endcap_length2], [endcap_extent1], [endcap_extent2], [trim1], [trim2]); // stroke(path, <width>, <closed>, <endcap1>, <endcap2>, <endcap_width1>, <endcap_width2>, <endcap_length1>, <endcap_length2>, <endcap_extent1>, <endcap_extent2>, <trim1>, <trim2>);
// Topics: Paths (2D), Paths (3D), Drawing Tools
// Description: // Description:
// Draws a 2D or 3D path with a given line width. Endcaps can be specified for each end individually. // Draws a 2D or 3D path with a given line width. Endcaps can be specified for each end individually.
// Figure(2D,Big): Endcap Types // Figure(2D,Big): Endcap Types
@ -330,25 +331,27 @@ module stroke(
// Function&Module: arc() // Function&Module: arc()
// Usage: 2D arc from 0º to `angle` degrees. // Usage: 2D arc from 0º to `angle` degrees.
// arc(N, r|d, angle); // arc(N, r|d=, angle);
// Usage: 2D arc from START to END degrees. // Usage: 2D arc from START to END degrees.
// arc(N, r|d, angle=[START,END]) // arc(N, r|d=, angle=[START,END])
// Usage: 2D arc from `start` to `start+angle` degrees. // Usage: 2D arc from `start` to `start+angle` degrees.
// arc(N, r|d, start, angle) // arc(N, r|d=, start=, angle=)
// Usage: 2D circle segment by `width` and `thickness`, starting and ending on the X axis. // Usage: 2D circle segment by `width` and `thickness`, starting and ending on the X axis.
// arc(N, width, thickness) // arc(N, width=, thickness=)
// Usage: Shortest 2D or 3D arc around centerpoint `cp`, starting at P0 and ending on the vector pointing from `cp` to `P1`. // Usage: Shortest 2D or 3D arc around centerpoint `cp`, starting at P0 and ending on the vector pointing from `cp` to `P1`.
// arc(N, cp, points=[P0,P1],[long],[cw],[ccw]) // arc(N, cp=, points=[P0,P1], <long=>, <cw=>, <ccw=>)
// Usage: 2D or 3D arc, starting at `P0`, passing through `P1` and ending at `P2`. // Usage: 2D or 3D arc, starting at `P0`, passing through `P1` and ending at `P2`.
// arc(N, points=[P0,P1,P2]) // arc(N, points=[P0,P1,P2])
// Topics: Paths (2D), Paths (3D), Shapes (2D), Path Generators
// Description: // Description:
// If called as a function, returns a 2D or 3D path forming an arc. // If called as a function, returns a 2D or 3D path forming an arc.
// If called as a module, creates a 2D arc polygon or pie slice shape. // If called as a module, creates a 2D arc polygon or pie slice shape.
// Arguments: // Arguments:
// N = Number of vertices to form the arc curve from. // N = Number of vertices to form the arc curve from.
// r = Radius of the arc. // r = Radius of the arc.
// d = Diameter of the arc.
// angle = If a scalar, specifies the end angle in degrees (relative to start parameter). If a vector of two scalars, specifies start and end angles. // angle = If a scalar, specifies the end angle in degrees (relative to start parameter). If a vector of two scalars, specifies start and end angles.
// ---
// d = Diameter of the arc.
// cp = Centerpoint of arc. // cp = Centerpoint of arc.
// points = Points on the arc. // points = Points on the arc.
// long = if given with cp and points takes the long arc instead of the default short arc. Default: false // long = if given with cp and points takes the long arc instead of the default short arc. Default: false
@ -475,7 +478,9 @@ function _normal_segment(p1,p2) =
// Function: turtle() // Function: turtle()
// Usage: // Usage:
// turtle(commands, [state], [full_state], [repeat], [endpoint]) // turtle(commands, <state>, <full_state=>, <repeat=>)
// Topics: Shapes (2D), Path Generators (2D), Mini-Language
// See Also: turtle3d()
// Description: // Description:
// Use a sequence of turtle graphics commands to generate a path. The parameter `commands` is a list of // Use a sequence of turtle graphics commands to generate a path. The parameter `commands` is a list of
// turtle commands and optional parameters for each command. The turtle state has a position, movement direction, // turtle commands and optional parameters for each command. The turtle state has a position, movement direction,
@ -516,6 +521,7 @@ function _normal_segment(p1,p2) =
// Arguments: // Arguments:
// commands = List of turtle commands // commands = List of turtle commands
// state = Starting turtle state (from previous call) or starting point. Default: start at the origin, pointing right. // state = Starting turtle state (from previous call) or starting point. Default: start at the origin, pointing right.
// ---
// full_state = If true return the full turtle state for continuing the path in subsequent turtle calls. Default: false // full_state = If true return the full turtle state for continuing the path in subsequent turtle calls. Default: false
// repeat = Number of times to repeat the command list. Default: 1 // repeat = Number of times to repeat the command list. Default: 1
// //
@ -733,8 +739,14 @@ function _turtle_command(command, parm, parm2, state, index) =
// Section: 2D Primitives // Section: 2D Primitives
// Function&Module: rect() // Function&Module: rect()
// Usage: // Usage: As Module
// rect(size, [center], [rounding], [chamfer], [anchor], [spin]) // rect(size, <center>, <rounding>, <chamfer>, ...);
// Usage: With Attachments
// rect(size, <center>, ...) { attachables }
// Usage: As Function
// path = rect(size, <center>, <rounding>, <chamfer>, ...);
// Topics: Shapes (2D), Paths (2D), Path Generators, Attachable
// See Also: square()
// Description: // Description:
// When called as a module, creates a 2D rectangle of the given size, with optional rounding or chamfering. // When called as a module, creates a 2D rectangle of the given size, with optional rounding or chamfering.
// When called as a function, returns a 2D path/list of points for a square/rectangle of the given size. // When called as a function, returns a 2D path/list of points for a square/rectangle of the given size.
@ -832,12 +844,15 @@ function rect(size=1, center, rounding=0, chamfer=0, anchor, spin=0) =
// Function&Module: oval() // Function&Module: oval()
// Usage: // Usage:
// oval(r|d, [realign], [circum]) // oval(r|d=, <realign=>, <circum=>)
// Topics: Shapes (2D), Paths (2D), Path Generators, Attachable
// See Also: circle()
// Description: // Description:
// When called as a module, creates a 2D polygon that approximates a circle of the given size. // When called as a module, creates a 2D polygon that approximates a circle of the given size.
// When called as a function, returns a 2D list of points (path) for a polygon that approximates a circle of the given size. // When called as a function, returns a 2D list of points (path) for a polygon that approximates a circle of the given size.
// Arguments: // Arguments:
// r = Radius of the circle/oval to create. Can be a scalar, or a list of sizes per axis. // r = Radius of the circle/oval to create. Can be a scalar, or a list of sizes per axis.
// ---
// d = Diameter of the circle/oval to create. Can be a scalar, or a list of sizes per axis. // d = Diameter of the circle/oval to create. Can be a scalar, or a list of sizes per axis.
// realign = If true, rotates the polygon that approximates the circle/oval by half of one size. // realign = If true, rotates the polygon that approximates the circle/oval by half of one size.
// circum = If true, the polygon that approximates the circle will be upsized slightly to circumscribe the theoretical circle. If false, it inscribes the theoretical circle. Default: false // circum = If true, the polygon that approximates the circle will be upsized slightly to circumscribe the theoretical circle. If false, it inscribes the theoretical circle. Default: false
@ -895,18 +910,19 @@ function oval(r, d, realign=false, circum=false, anchor=CENTER, spin=0) =
// Function&Module: regular_ngon() // Function&Module: regular_ngon()
// Usage: // Usage:
// regular_ngon(n, r|d|or|od, [realign]); // regular_ngon(n, r/d=/or=/od=, <realign=>);
// regular_ngon(n, ir|id, [realign]); // regular_ngon(n, ir=/id=, <realign=>);
// regular_ngon(n, side, [realign]); // regular_ngon(n, side=, <realign=>);
// Topics: Shapes (2D), Paths (2D), Path Generators, Attachable
// See Also: circle(), pentagon(), hexagon(), octagon(), oval(), star()
// Description: // Description:
// When called as a function, returns a 2D path for a regular N-sided polygon. // When called as a function, returns a 2D path for a regular N-sided polygon.
// When called as a module, creates a 2D regular N-sided polygon. // When called as a module, creates a 2D regular N-sided polygon.
// Arguments: // Arguments:
// n = The number of sides. // n = The number of sides.
// or = Outside radius, at points. // r/or = Outside radius, at points.
// r = Same as or // ---
// od = Outside diameter, at points. // d/od = Outside diameter, at points.
// d = Same as od
// ir = Inside radius, at center of sides. // ir = Inside radius, at center of sides.
// id = Inside diameter, at center of sides. // id = Inside diameter, at center of sides.
// side = Length of each side. // side = Length of each side.
@ -1030,17 +1046,18 @@ module regular_ngon(n=6, r, d, or, od, ir, id, side, rounding=0, realign=false,
// Function&Module: pentagon() // Function&Module: pentagon()
// Usage: // Usage:
// pentagon(or|od, [realign]); // pentagon(or|od=, <realign=>);
// pentagon(ir|id, [realign]); // pentagon(ir=|id=, <realign=>);
// pentagon(side, [realign]); // pentagon(side=, <realign=>);
// Topics: Shapes (2D), Paths (2D), Path Generators, Attachable
// See Also: circle(), regular_ngon(), hexagon(), octagon(), oval(), star()
// Description: // Description:
// When called as a function, returns a 2D path for a regular pentagon. // When called as a function, returns a 2D path for a regular pentagon.
// When called as a module, creates a 2D regular pentagon. // When called as a module, creates a 2D regular pentagon.
// Arguments: // Arguments:
// or = Outside radius, at points. // r/or = Outside radius, at points.
// r = Same as or. // ---
// od = Outside diameter, at points. // d/od = Outside diameter, at points.
// d = Same as od.
// ir = Inside radius, at center of sides. // ir = Inside radius, at center of sides.
// id = Inside diameter, at center of sides. // id = Inside diameter, at center of sides.
// side = Length of each side. // side = Length of each side.
@ -1084,16 +1101,27 @@ module pentagon(r, d, or, od, ir, id, side, rounding=0, realign=false, align_tip
// Function&Module: hexagon() // Function&Module: hexagon()
// Usage: // Usage: As Module
// hexagon(or, od, ir, id, side); // hexagon(r/or, <realign=>, <align_tip=|align_side=>, <rounding=>, ...);
// hexagon(d=/od=, ...);
// hexagon(ir=/id=, ...);
// hexagon(side=, ...);
// Usage: With Attachments
// hexagon(r/or, ...) { attachments }
// Usage: As Function
// path = hexagon(r/or, ...);
// path = hexagon(d=/od=, ...);
// path = hexagon(ir=/id=, ...);
// path = hexagon(side=, ...);
// Topics: Shapes (2D), Paths (2D), Path Generators, Attachable
// See Also: circle(), regular_ngon(), pentagon(), octagon(), oval(), star()
// Description: // Description:
// When called as a function, returns a 2D path for a regular hexagon. // When called as a function, returns a 2D path for a regular hexagon.
// When called as a module, creates a 2D regular hexagon. // When called as a module, creates a 2D regular hexagon.
// Arguments: // Arguments:
// or = Outside radius, at points. // r/or = Outside radius, at points.
// r = Same as or // ---
// od = Outside diameter, at points. // d/od = Outside diameter, at points.
// d = Same as od
// ir = Inside radius, at center of sides. // ir = Inside radius, at center of sides.
// id = Inside diameter, at center of sides. // id = Inside diameter, at center of sides.
// side = Length of each side. // side = Length of each side.
@ -1137,16 +1165,26 @@ module hexagon(r, d, or, od, ir, id, side, rounding=0, realign=false, align_tip,
// Function&Module: octagon() // Function&Module: octagon()
// Usage: // Usage: As Module
// octagon(or, od, ir, id, side); // octagon(r/or, <realign=>, <align_tip=|align_side=>, <rounding=>, ...);
// octagon(d=/od=, ...);
// octagon(ir=/id=, ...);
// octagon(side=, ...);
// Usage: With Attachments
// octagon(r/or, ...) { attachments }
// Usage: As Function
// path = octagon(r/or, ...);
// path = octagon(d=/od=, ...);
// path = octagon(ir=/id=, ...);
// path = octagon(side=, ...);
// Topics: Shapes (2D), Paths (2D), Path Generators, Attachable
// See Also: circle(), regular_ngon(), pentagon(), hexagon(), oval(), star()
// Description: // Description:
// When called as a function, returns a 2D path for a regular octagon. // When called as a function, returns a 2D path for a regular octagon.
// When called as a module, creates a 2D regular octagon. // When called as a module, creates a 2D regular octagon.
// Arguments: // Arguments:
// or = Outside radius, at points. // r/or = Outside radius, at points.
// r = Same as or // d/od = Outside diameter, at points.
// od = Outside diameter, at points.
// d = Same as od
// ir = Inside radius, at center of sides. // ir = Inside radius, at center of sides.
// id = Inside diameter, at center of sides. // id = Inside diameter, at center of sides.
// side = Length of each side. // side = Length of each side.
@ -1194,8 +1232,20 @@ module octagon(r, d, or, od, ir, id, side, rounding=0, realign=false, align_tip,
// Function&Module: trapezoid() // Function&Module: trapezoid()
// Usage: // Usage: As Module
// trapezoid(h, w1, w2); // trapezoid(h, w1, w2, <shift=>, <rounding=>, <chamfer=>, ...);
// trapezoid(h, w1, angle=, ...);
// trapezoid(h, w2, angle=, ...);
// trapezoid(w1, w2, angle=, ...);
// Usage: With Attachments
// trapezoid(h, w1, w2, ...) { attachments }
// Usage: As Function
// path = trapezoid(h, w1, w2, ...);
// path = trapezoid(h, w1, angle=, ...);
// path = trapezoid(h, w2=, angle=, ...);
// path = trapezoid(w1=, w2=, angle=, ...);
// Topics: Shapes (2D), Paths (2D), Path Generators, Attachable
// See Also: rect(), square()
// Description: // Description:
// When called as a function, returns a 2D path for a trapezoid with parallel front and back sides. // When called as a function, returns a 2D path for a trapezoid with parallel front and back sides.
// When called as a module, creates a 2D trapezoid with parallel front and back sides. // When called as a module, creates a 2D trapezoid with parallel front and back sides.
@ -1203,6 +1253,7 @@ module octagon(r, d, or, od, ir, id, side, rounding=0, realign=false, align_tip,
// h = The Y axis height of the trapezoid. // h = The Y axis height of the trapezoid.
// w1 = The X axis width of the front end of the trapezoid. // w1 = The X axis width of the front end of the trapezoid.
// w2 = The X axis width of the back end of the trapezoid. // w2 = The X axis width of the back end of the trapezoid.
// ---
// angle = If given in place of `h`, `w1`, or `w2`, then the missing value is calculated such that the right side has that angle away from the Y axis. // angle = If given in place of `h`, `w1`, or `w2`, then the missing value is calculated such that the right side has that angle away from the Y axis.
// shift = Scalar value to shift the back of the trapezoid along the X axis by. Default: 0 // shift = Scalar value to shift the back of the trapezoid along the X axis by. Default: 0
// rounding = The rounding radius for the corners. If given as a list of four numbers, gives individual radii for each corner, in the order [X+Y+,X-Y+,X-Y-,X+Y-]. Default: 0 (no rounding) // rounding = The rounding radius for the corners. If given as a list of four numbers, gives individual radii for each corner, in the order [X+Y+,X-Y+,X-Y-,X+Y-]. Default: 0 (no rounding)
@ -1290,14 +1341,23 @@ module trapezoid(h, w1, w2, angle, shift=0, chamfer=0, rounding=0, anchor=CENTER
// Description: // Description:
// Makes a 2D teardrop shape. Useful for extruding into 3D printable holes. // Makes a 2D teardrop shape. Useful for extruding into 3D printable holes.
// //
// Usage: // Usage: As Module
// teardrop2d(r|d, [ang], [cap_h]); // teardrop2d(r/d=, <ang>, <cap_h>);
// Usage: With Attachments
// teardrop2d(r/d=, <ang>, <cap_h>, ...) { attachments }
// Usage: As Function
// path = teardrop2d(r/d=, <ang>, <cap_h>);
//
// Topics: Shapes (2D), Paths (2D), Path Generators, Attachable
//
// See Also: teardrop(), onion()
// //
// Arguments: // Arguments:
// r = radius of circular part of teardrop. (Default: 1) // r = radius of circular part of teardrop. (Default: 1)
// d = diameter of spherical portion of bottom. (Use instead of r)
// ang = angle of hat walls from the Y axis. (Default: 45 degrees) // ang = angle of hat walls from the Y axis. (Default: 45 degrees)
// cap_h = if given, height above center where the shape will be truncated. // cap_h = if given, height above center where the shape will be truncated.
// ---
// d = diameter of spherical portion of bottom. (Use instead of r)
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER` // anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0` // spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0`
// //
@ -1307,7 +1367,7 @@ module trapezoid(h, w1, w2, angle, shift=0, chamfer=0, rounding=0, anchor=CENTER
// teardrop2d(r=30, ang=30, cap_h=40); // teardrop2d(r=30, ang=30, cap_h=40);
// Example(2D): Close Crop // Example(2D): Close Crop
// teardrop2d(r=30, ang=30, cap_h=20); // teardrop2d(r=30, ang=30, cap_h=20);
module teardrop2d(r, d, ang=45, cap_h, anchor=CENTER, spin=0) module teardrop2d(r, ang=45, cap_h, d, anchor=CENTER, spin=0)
{ {
path = teardrop2d(r=r, d=d, ang=ang, cap_h=cap_h); path = teardrop2d(r=r, d=d, ang=ang, cap_h=cap_h);
attachable(anchor,spin, two_d=true, path=path) { attachable(anchor,spin, two_d=true, path=path) {
@ -1317,7 +1377,7 @@ module teardrop2d(r, d, ang=45, cap_h, anchor=CENTER, spin=0)
} }
function teardrop2d(r, d, ang=45, cap_h, anchor=CENTER, spin=0) = function teardrop2d(r, ang=45, cap_h, d, anchor=CENTER, spin=0) =
let( let(
r = get_radius(r=r, d=d, dflt=1), r = get_radius(r=r, d=d, dflt=1),
tanpt = polar_to_xy(r, ang), tanpt = polar_to_xy(r, ang),
@ -1345,16 +1405,23 @@ function teardrop2d(r, d, ang=45, cap_h, anchor=CENTER, spin=0) =
// Function&Module: glued_circles() // Function&Module: glued_circles()
// Usage: // Usage: As Module
// glued_circles(r|d, spread, tangent); // glued_circles(r/d=, <spread=>, <tangent=>, ...);
// Usage: With Attachments
// glued_circles(r/d=, <spread=>, <tangent=>, ...) { attachments }
// Usage: As Function
// path = glued_circles(r/d=, <spread=>, <tangent=>, ...);
// Topics: Shapes (2D), Paths (2D), Path Generators, Attachable
// See Also: circle(), oval()
// Description: // Description:
// When called as a function, returns a 2D path forming a shape of two circles joined by curved waist. // When called as a function, returns a 2D path forming a shape of two circles joined by curved waist.
// When called as a module, creates a 2D shape of two circles joined by curved waist. // When called as a module, creates a 2D shape of two circles joined by curved waist.
// Arguments: // Arguments:
// r = The radius of the end circles. // r = The radius of the end circles.
// d = The diameter of the end circles.
// spread = The distance between the centers of the end circles. Default: 10 // spread = The distance between the centers of the end circles. Default: 10
// tangent = The angle in degrees of the tangent point for the joining arcs, measured away from the Y axis. Default: 30 // tangent = The angle in degrees of the tangent point for the joining arcs, measured away from the Y axis. Default: 30
// ---
// d = The diameter of the end circles.
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER` // anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0` // spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0`
// Examples(2D): // Examples(2D):
@ -1364,7 +1431,7 @@ function teardrop2d(r, d, ang=45, cap_h, anchor=CENTER, spin=0) =
// glued_circles(d=30, spread=30, tangent=-30); // glued_circles(d=30, spread=30, tangent=-30);
// Example(2D): Called as Function // Example(2D): Called as Function
// stroke(closed=true, glued_circles(r=15, spread=40, tangent=45)); // stroke(closed=true, glued_circles(r=15, spread=40, tangent=45));
function glued_circles(r, d, spread=10, tangent=30, anchor=CENTER, spin=0) = function glued_circles(r, spread=10, tangent=30, d, anchor=CENTER, spin=0) =
let( let(
r = get_radius(r=r, d=d, dflt=10), r = get_radius(r=r, d=d, dflt=10),
r2 = (spread/2 / sin(tangent)) - r, r2 = (spread/2 / sin(tangent)) - r,
@ -1391,7 +1458,7 @@ function glued_circles(r, d, spread=10, tangent=30, anchor=CENTER, spin=0) =
) reorient(anchor,spin, two_d=true, path=path2, extent=true, p=path2); ) reorient(anchor,spin, two_d=true, path=path2, extent=true, p=path2);
module glued_circles(r, d, spread=10, tangent=30, anchor=CENTER, spin=0) { module glued_circles(r, spread=10, tangent=30, d, anchor=CENTER, spin=0) {
path = glued_circles(r=r, d=d, spread=spread, tangent=tangent); path = glued_circles(r=r, d=d, spread=spread, tangent=tangent);
attachable(anchor,spin, two_d=true, path=path, extent=true) { attachable(anchor,spin, two_d=true, path=path, extent=true) {
polygon(path); polygon(path);
@ -1401,18 +1468,25 @@ module glued_circles(r, d, spread=10, tangent=30, anchor=CENTER, spin=0) {
// Function&Module: star() // Function&Module: star()
// Usage: // Usage: As Module
// star(n, r|d|or|od, ir|id|step, [realign]); // star(n, r/or, ir, <realign=>, <align_tip=>, <align_pit=>, ...);
// star(n, r/or, step=, ...);
// Usage: With Attachments
// star(n, r/or, ir, ...) { attachments }
// Usage: As Function
// path = star(n, r/or, ir, <realign=>, <align_tip=>, <align_pit=>, ...);
// path = star(n, r/or, step=, ...);
// Topics: Shapes (2D), Paths (2D), Path Generators, Attachable
// See Also: circle(), oval()
// Description: // Description:
// When called as a function, returns the path needed to create a star polygon with N points. // When called as a function, returns the path needed to create a star polygon with N points.
// When called as a module, creates a star polygon with N points. // When called as a module, creates a star polygon with N points.
// Arguments: // Arguments:
// n = The number of stellate tips on the star. // n = The number of stellate tips on the star.
// r = The radius to the tips of the star. // r/or = The radius to the tips of the star.
// or = Same as r
// d = The diameter to the tips of the star.
// od = Same as d
// ir = The radius to the inner corners of the star. // ir = The radius to the inner corners of the star.
// ---
// d/od = The diameter to the tips of the star.
// id = The diameter to the inner corners of the star. // id = The diameter to the inner corners of the star.
// step = Calculates the radius of the inner star corners by virtually drawing a straight line `step` tips around the star. 2 <= step < n/2 // step = Calculates the radius of the inner star corners by virtually drawing a straight line `step` tips around the star. 2 <= step < n/2
// realign = If false, a tip is aligned with the Y+ axis. If true, an inner corner is aligned with the Y+ axis. Default: false // realign = If false, a tip is aligned with the Y+ axis. If true, an inner corner is aligned with the Y+ axis. Default: false
@ -1441,7 +1515,7 @@ module glued_circles(r, d, spread=10, tangent=30, anchor=CENTER, spin=0) {
// stroke([[0,0],[0,7]], endcap2="arrow2"); // stroke([[0,0],[0,7]], endcap2="arrow2");
// Example(2D): Called as Function // Example(2D): Called as Function
// stroke(closed=true, star(n=5, r=50, ir=25)); // stroke(closed=true, star(n=5, r=50, ir=25));
function star(n, r, d, or, od, ir, id, step, realign=false, align_tip, align_pit, anchor=CENTER, spin=0, _mat, _anchs) = function star(n, r, ir, d, or, od, id, step, realign=false, align_tip, align_pit, anchor=CENTER, spin=0, _mat, _anchs) =
assert(is_undef(align_tip) || is_vector(align_tip)) assert(is_undef(align_tip) || is_vector(align_tip))
assert(is_undef(align_pit) || is_vector(align_pit)) assert(is_undef(align_pit) || is_vector(align_pit))
assert(is_undef(align_tip) || is_undef(align_pit), "Can only specify one of align_tip and align_pit") assert(is_undef(align_tip) || is_undef(align_pit), "Can only specify one of align_tip and align_pit")
@ -1484,7 +1558,7 @@ function star(n, r, d, or, od, ir, id, step, realign=false, align_tip, align_pit
) reorient(anchor,spin, two_d=true, path=path, p=path, anchors=anchors); ) reorient(anchor,spin, two_d=true, path=path, p=path, anchors=anchors);
module star(n, r, d, or, od, ir, id, step, realign=false, align_tip, align_pit, anchor=CENTER, spin=0) { module star(n, r, ir, d, or, od, id, step, realign=false, align_tip, align_pit, anchor=CENTER, spin=0) {
assert(is_undef(align_tip) || is_vector(align_tip)); assert(is_undef(align_tip) || is_vector(align_tip));
assert(is_undef(align_pit) || is_vector(align_pit)); assert(is_undef(align_pit) || is_vector(align_pit));
assert(is_undef(align_tip) || is_undef(align_pit), "Can only specify one of align_tip and align_pit"); assert(is_undef(align_tip) || is_undef(align_pit), "Can only specify one of align_tip and align_pit");
@ -1523,8 +1597,14 @@ function _superformula(theta,m1,m2,n1,n2=1,n3=1,a=1,b=1) =
pow(pow(abs(cos(m1*theta/4)/a),n2)+pow(abs(sin(m2*theta/4)/b),n3),-1/n1); pow(pow(abs(cos(m1*theta/4)/a),n2)+pow(abs(sin(m2*theta/4)/b),n3),-1/n1);
// Function&Module: supershape() // Function&Module: supershape()
// Usage: // Usage: As Module
// supershape(step,[m1],[m2],[n1],[n2],[n3],[a],[b],[r|d]); // supershape(step, <m1=>, <m2=>, <n1=>, <n2=>, <n3=>, <a=>, <b=>, <r=/d=>);
// Usage: With Attachments
// supershape(step, <m1=>, <m2=>, <n1=>, <n2=>, <n3=>, <a=>, <b=>, <r=/d=>) { attachments }
// Usage: As Function
// path = supershape(step, <m1=>, <m2=>, <n1=>, <n2=>, <n3=>, <a=>, <b=>, <r=/d=>);
// Topics: Shapes (2D), Paths (2D), Path Generators, Attachable
// See Also: circle(), oval()
// Description: // Description:
// When called as a function, returns a 2D path for the outline of the [Superformula](https://en.wikipedia.org/wiki/Superformula) shape. // When called as a function, returns a 2D path for the outline of the [Superformula](https://en.wikipedia.org/wiki/Superformula) shape.
// When called as a module, creates a 2D [Superformula](https://en.wikipedia.org/wiki/Superformula) shape. // When called as a module, creates a 2D [Superformula](https://en.wikipedia.org/wiki/Superformula) shape.
@ -1538,6 +1618,7 @@ function _superformula(theta,m1,m2,n1,n2=1,n3=1,a=1,b=1) =
// a = The a argument for the superformula. Default: 1. // a = The a argument for the superformula. Default: 1.
// b = The b argument for the superformula. Default: a. // b = The b argument for the superformula. Default: a.
// r = Radius of the shape. Scale shape to fit in a circle of radius r. // r = Radius of the shape. Scale shape to fit in a circle of radius r.
// ---
// d = Diameter of the shape. Scale shape to fit in a circle of diameter d. // d = Diameter of the shape. Scale shape to fit in a circle of diameter d.
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER` // anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0` // spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0`
@ -1566,7 +1647,7 @@ function _superformula(theta,m1,m2,n1,n2=1,n3=1,a=1,b=1) =
// Examples: // Examples:
// linear_extrude(height=0.3, scale=0) supershape(step=1, m1=6, n1=0.4, n2=0, n3=6); // linear_extrude(height=0.3, scale=0) supershape(step=1, m1=6, n1=0.4, n2=0, n3=6);
// linear_extrude(height=5, scale=0) supershape(step=1, b=3, m1=6, n1=3.8, n2=16, n3=10); // linear_extrude(height=5, scale=0) supershape(step=1, b=3, m1=6, n1=3.8, n2=16, n3=10);
function supershape(step=0.5,m1=4,m2=undef,n1=1,n2=undef,n3=undef,a=1,b=undef,r=undef,d=undef,anchor=CENTER, spin=0) = function supershape(step=0.5, m1=4, m2, n1=1, n2, n3, a=1, b, r, d,anchor=CENTER, spin=0) =
let( let(
r = get_radius(r=r, d=d, dflt=undef), r = get_radius(r=r, d=d, dflt=undef),
m2 = is_def(m2) ? m2 : m1, m2 = is_def(m2) ? m2 : m1,
@ -1592,14 +1673,17 @@ module supershape(step=0.5,m1=4,m2=undef,n1,n2=undef,n3=undef,a=1,b=undef, r=und
// Function&Module: reuleaux_polygon() // Function&Module: reuleaux_polygon()
// Usage: As Module // Usage: As Module
// reuleaux_polygon(N, r|d); // reuleaux_polygon(N, r|d, ...);
// Usage: As Function // Usage: As Function
// path = reuleaux_polygon(N, r|d); // path = reuleaux_polygon(N, r|d, ...);
// Topics: Shapes (2D), Paths (2D), Path Generators, Attachable
// See Also: regular_ngon(), pentagon(), hexagon(), octagon()
// Description: // Description:
// Creates a 2D Reuleaux Polygon; a constant width shape that is not circular. // Creates a 2D Reuleaux Polygon; a constant width shape that is not circular.
// Arguments: // Arguments:
// N = Number of "sides" to the Reuleaux Polygon. Must be an odd positive number. Default: 3 // N = Number of "sides" to the Reuleaux Polygon. Must be an odd positive number. Default: 3
// r = Radius of the shape. Scale shape to fit in a circle of radius r. // r = Radius of the shape. Scale shape to fit in a circle of radius r.
// ---
// d = Diameter of the shape. Scale shape to fit in a circle of diameter d. // d = Diameter of the shape. Scale shape to fit in a circle of diameter d.
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER` // anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0` // spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0`
@ -1655,17 +1739,26 @@ function reuleaux_polygon(N=3, r, d, anchor=CENTER, spin=0) =
// Section: 2D Masking Shapes // Section: 2D Masking Shapes
// Function&Module: mask2d_roundover() // Function&Module: mask2d_roundover()
// Usage: // Usage: As Module
// mask2d_roundover(r|d, [inset], [excess]); // mask2d_roundover(r|d, <inset>, <excess>);
// Usage: With Attachments
// mask2d_roundover(r|d, <inset>, <excess>) { attachments }
// Usage: As Module
// path = mask2d_roundover(r|d, <inset>, <excess>);
// Topics: Shapes (2D), Paths (2D), Path Generators, Attachable, Masks (2D)
// See Also: corner_profile(), edge_profile(), face_profile()
// Description: // Description:
// Creates a 2D roundover/bead mask shape that is useful for extruding into a 3D mask for a 90º edge. // Creates a 2D roundover/bead mask shape that is useful for extruding into a 3D mask for a 90º edge.
// This 2D mask is designed to be differenced away from the edge of a shape that is in the first (X+Y+) quadrant. // This 2D mask is designed to be differenced away from the edge of a shape that is in the first (X+Y+) quadrant.
// If called as a function, this just returns a 2D path of the outline of the mask shape. // If called as a function, this just returns a 2D path of the outline of the mask shape.
// Arguments: // Arguments:
// r = Radius of the roundover. // r = Radius of the roundover.
// d = Diameter of the roundover.
// inset = Optional bead inset size. Default: 0 // inset = Optional bead inset size. Default: 0
// excess = Extra amount of mask shape to creates on the X- and Y- sides of the shape. // excess = Extra amount of mask shape to creates on the X- and Y- sides of the shape.
// ---
// d = Diameter of the roundover.
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0`
// Example(2D): 2D Roundover Mask // Example(2D): 2D Roundover Mask
// mask2d_roundover(r=10); // mask2d_roundover(r=10);
// Example(2D): 2D Bead Mask // Example(2D): 2D Bead Mask
@ -1675,7 +1768,7 @@ function reuleaux_polygon(N=3, r, d, anchor=CENTER, spin=0) =
// cube([50,60,70],center=true) // cube([50,60,70],center=true)
// edge_profile([TOP,"Z"],except=[BACK,TOP+LEFT]) // edge_profile([TOP,"Z"],except=[BACK,TOP+LEFT])
// mask2d_roundover(r=10, inset=2); // mask2d_roundover(r=10, inset=2);
module mask2d_roundover(r, d, excess, inset=0, anchor=CENTER,spin=0) { module mask2d_roundover(r, inset=0, excess, d, anchor=CENTER,spin=0) {
path = mask2d_roundover(r=r,d=d,excess=excess,inset=inset); path = mask2d_roundover(r=r,d=d,excess=excess,inset=inset);
attachable(anchor,spin, two_d=true, path=path) { attachable(anchor,spin, two_d=true, path=path) {
polygon(path); polygon(path);
@ -1683,7 +1776,7 @@ module mask2d_roundover(r, d, excess, inset=0, anchor=CENTER,spin=0) {
} }
} }
function mask2d_roundover(r, d, excess, inset=0, anchor=CENTER,spin=0) = function mask2d_roundover(r, inset=0, excess, d, anchor=CENTER,spin=0) =
assert(is_num(r)||is_num(d)) assert(is_num(r)||is_num(d))
assert(is_undef(excess)||is_num(excess)) assert(is_undef(excess)||is_num(excess))
assert(is_num(inset)||(is_vector(inset)&&len(inset)==2)) assert(is_num(inset)||(is_vector(inset)&&len(inset)==2))
@ -1703,17 +1796,26 @@ function mask2d_roundover(r, d, excess, inset=0, anchor=CENTER,spin=0) =
// Function&Module: mask2d_cove() // Function&Module: mask2d_cove()
// Usage: // Usage: As Module
// mask2d_cove(r|d, [inset], [excess]); // mask2d_cove(r|d, <inset>, <excess>);
// Usage: With Attachments
// mask2d_cove(r|d, <inset>, <excess>) { attachments }
// Usage: As Function
// path = mask2d_cove(r|d, <inset>, <excess>);
// Topics: Shapes (2D), Paths (2D), Path Generators, Attachable, Masks (2D)
// See Also: corner_profile(), edge_profile(), face_profile()
// Description: // Description:
// Creates a 2D cove mask shape that is useful for extruding into a 3D mask for a 90º edge. // Creates a 2D cove mask shape that is useful for extruding into a 3D mask for a 90º edge.
// This 2D mask is designed to be differenced away from the edge of a shape that is in the first (X+Y+) quadrant. // This 2D mask is designed to be differenced away from the edge of a shape that is in the first (X+Y+) quadrant.
// If called as a function, this just returns a 2D path of the outline of the mask shape. // If called as a function, this just returns a 2D path of the outline of the mask shape.
// Arguments: // Arguments:
// r = Radius of the cove. // r = Radius of the cove.
// d = Diameter of the cove.
// inset = Optional amount to inset code from corner. Default: 0 // inset = Optional amount to inset code from corner. Default: 0
// excess = Extra amount of mask shape to creates on the X- and Y- sides of the shape. // excess = Extra amount of mask shape to creates on the X- and Y- sides of the shape.
// ---
// d = Diameter of the cove.
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0`
// Example(2D): 2D Cove Mask // Example(2D): 2D Cove Mask
// mask2d_cove(r=10); // mask2d_cove(r=10);
// Example(2D): 2D Inset Cove Mask // Example(2D): 2D Inset Cove Mask
@ -1723,7 +1825,7 @@ function mask2d_roundover(r, d, excess, inset=0, anchor=CENTER,spin=0) =
// cube([50,60,70],center=true) // cube([50,60,70],center=true)
// edge_profile([TOP,"Z"],except=[BACK,TOP+LEFT]) // edge_profile([TOP,"Z"],except=[BACK,TOP+LEFT])
// mask2d_cove(r=10, inset=2); // mask2d_cove(r=10, inset=2);
module mask2d_cove(r, d, inset=0, excess, anchor=CENTER,spin=0) { module mask2d_cove(r, inset=0, excess, d, anchor=CENTER,spin=0) {
path = mask2d_cove(r=r,d=d,excess=excess,inset=inset); path = mask2d_cove(r=r,d=d,excess=excess,inset=inset);
attachable(anchor,spin, two_d=true, path=path) { attachable(anchor,spin, two_d=true, path=path) {
polygon(path); polygon(path);
@ -1731,7 +1833,7 @@ module mask2d_cove(r, d, inset=0, excess, anchor=CENTER,spin=0) {
} }
} }
function mask2d_cove(r, d, inset=0, excess, anchor=CENTER,spin=0) = function mask2d_cove(r, inset=0, excess, d, anchor=CENTER,spin=0) =
assert(is_num(r)||is_num(d)) assert(is_num(r)||is_num(d))
assert(is_undef(excess)||is_num(excess)) assert(is_undef(excess)||is_num(excess))
assert(is_num(inset)||(is_vector(inset)&&len(inset)==2)) assert(is_num(inset)||(is_vector(inset)&&len(inset)==2))
@ -1751,19 +1853,32 @@ function mask2d_cove(r, d, inset=0, excess, anchor=CENTER,spin=0) =
// Function&Module: mask2d_chamfer() // Function&Module: mask2d_chamfer()
// Usage: // Usage: As Module
// mask2d_chamfer(x|y|edge, [angle], [inset], [excess]); // mask2d_chamfer(edge, <angle>, <inset>, <excess>);
// mask2d_chamfer(y, <angle>, <inset>, <excess>);
// mask2d_chamfer(x, <angle>, <inset>, <excess>);
// Usage: With Attachments
// mask2d_chamfer(edge, <angle>, <inset>, <excess>) { attachments }
// Usage: As Function
// path = mask2d_chamfer(edge, <angle>, <inset>, <excess>);
// path = mask2d_chamfer(y, <angle>, <inset>, <excess>);
// path = mask2d_chamfer(x, <angle>, <inset>, <excess>);
// Topics: Shapes (2D), Paths (2D), Path Generators, Attachable, Masks (2D)
// See Also: corner_profile(), edge_profile(), face_profile()
// Description: // Description:
// Creates a 2D chamfer mask shape that is useful for extruding into a 3D mask for a 90º edge. // Creates a 2D chamfer mask shape that is useful for extruding into a 3D mask for a 90º edge.
// This 2D mask is designed to be differenced away from the edge of a shape that is in the first (X+Y+) quadrant. // This 2D mask is designed to be differenced away from the edge of a shape that is in the first (X+Y+) quadrant.
// If called as a function, this just returns a 2D path of the outline of the mask shape. // If called as a function, this just returns a 2D path of the outline of the mask shape.
// Arguments: // Arguments:
// x = The width of the chamfer.
// y = The height of the chamfer.
// edge = The length of the edge of the chamfer. // edge = The length of the edge of the chamfer.
// angle = The angle of the chamfer edge, away from vertical. Default: 45. // angle = The angle of the chamfer edge, away from vertical. Default: 45.
// inset = Optional amount to inset code from corner. Default: 0 // inset = Optional amount to inset code from corner. Default: 0
// excess = Extra amount of mask shape to creates on the X- and Y- sides of the shape. // excess = Extra amount of mask shape to creates on the X- and Y- sides of the shape.
// ---
// x = The width of the chamfer.
// y = The height of the chamfer.
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0`
// Example(2D): 2D Chamfer Mask // Example(2D): 2D Chamfer Mask
// mask2d_chamfer(x=10); // mask2d_chamfer(x=10);
// Example(2D): 2D Chamfer Mask by Width. // Example(2D): 2D Chamfer Mask by Width.
@ -1777,7 +1892,7 @@ function mask2d_cove(r, d, inset=0, excess, anchor=CENTER,spin=0) =
// cube([50,60,70],center=true) // cube([50,60,70],center=true)
// edge_profile([TOP,"Z"],except=[BACK,TOP+LEFT]) // edge_profile([TOP,"Z"],except=[BACK,TOP+LEFT])
// mask2d_chamfer(x=10, inset=2); // mask2d_chamfer(x=10, inset=2);
module mask2d_chamfer(x, y, edge, angle=45, excess, inset=0, anchor=CENTER,spin=0) { module mask2d_chamfer(edge, angle=45, inset=0, excess, x, y, anchor=CENTER,spin=0) {
path = mask2d_chamfer(x=x, y=y, edge=edge, angle=angle, excess=excess, inset=inset); path = mask2d_chamfer(x=x, y=y, edge=edge, angle=angle, excess=excess, inset=inset);
attachable(anchor,spin, two_d=true, path=path, extent=true) { attachable(anchor,spin, two_d=true, path=path, extent=true) {
polygon(path); polygon(path);
@ -1785,7 +1900,7 @@ module mask2d_chamfer(x, y, edge, angle=45, excess, inset=0, anchor=CENTER,spin=
} }
} }
function mask2d_chamfer(x, y, edge, angle=45, excess, inset=0, anchor=CENTER,spin=0) = function mask2d_chamfer(edge, angle=45, inset=0, excess, x, y, anchor=CENTER,spin=0) =
assert(num_defined([x,y,edge])==1) assert(num_defined([x,y,edge])==1)
assert(is_num(first_defined([x,y,edge]))) assert(is_num(first_defined([x,y,edge])))
assert(is_num(angle)) assert(is_num(angle))
@ -1809,16 +1924,24 @@ function mask2d_chamfer(x, y, edge, angle=45, excess, inset=0, anchor=CENTER,spi
// Function&Module: mask2d_rabbet() // Function&Module: mask2d_rabbet()
// Usage: // Usage: As Module
// mask2d_rabbet(size, [excess]); // mask2d_rabbet(size, <excess>);
// Usage: With Attachments
// mask2d_rabbet(size, <excess>) { attachments }
// Usage: As Function
// path = mask2d_rabbet(size, <excess>);
// Topics: Shapes (2D), Paths (2D), Path Generators, Attachable, Masks (2D)
// See Also: corner_profile(), edge_profile(), face_profile()
// Description: // Description:
// Creates a 2D rabbet mask shape that is useful for extruding into a 3D mask for a 90º edge. // Creates a 2D rabbet mask shape that is useful for extruding into a 3D mask for a 90º edge.
// This 2D mask is designed to be differenced away from the edge of a shape that is in the first (X+Y+) quadrant. // This 2D mask is designed to be differenced away from the edge of a shape that is in the first (X+Y+) quadrant.
// If called as a function, this just returns a 2D path of the outline of the mask shape. // If called as a function, this just returns a 2D path of the outline of the mask shape.
// Arguments: // Arguments:
// size = The size of the rabbet, either as a scalar or an [X,Y] list. // size = The size of the rabbet, either as a scalar or an [X,Y] list.
// inset = Optional amount to inset code from corner. Default: 0
// excess = Extra amount of mask shape to creates on the X- and Y- sides of the shape. // excess = Extra amount of mask shape to creates on the X- and Y- sides of the shape.
// ---
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0`
// Example(2D): 2D Rabbet Mask // Example(2D): 2D Rabbet Mask
// mask2d_rabbet(size=10); // mask2d_rabbet(size=10);
// Example(2D): 2D Asymmetrical Rabbet Mask // Example(2D): 2D Asymmetrical Rabbet Mask
@ -1852,20 +1975,31 @@ function mask2d_rabbet(size, excess, anchor=CENTER,spin=0) =
// Function&Module: mask2d_dovetail() // Function&Module: mask2d_dovetail()
// Usage: // Usage: As Module
// mask2d_dovetail(x|y|edge, [angle], [inset], [shelf], [excess]); // mask2d_dovetail(edge, <angle>, <inset>, <shelf>, <excess>, ...);
// mask2d_dovetail(x=, <angle=>, <inset=>, <shelf=>, <excess=>, ...);
// mask2d_dovetail(y=, <angle=>, <inset=>, <shelf=>, <excess=>, ...);
// Usage: With Attachments
// mask2d_dovetail(edge, <angle>, <inset>, <shelf>, ...) { attachments }
// Usage: As Function
// path = mask2d_dovetail(edge, <angle>, <inset>, <shelf>, <excess>);
// Topics: Shapes (2D), Paths (2D), Path Generators, Attachable, Masks (2D)
// See Also: corner_profile(), edge_profile(), face_profile()
// Description: // Description:
// Creates a 2D dovetail mask shape that is useful for extruding into a 3D mask for a 90º edge. // Creates a 2D dovetail mask shape that is useful for extruding into a 3D mask for a 90º edge.
// This 2D mask is designed to be differenced away from the edge of a shape that is in the first (X+Y+) quadrant. // This 2D mask is designed to be differenced away from the edge of a shape that is in the first (X+Y+) quadrant.
// If called as a function, this just returns a 2D path of the outline of the mask shape. // If called as a function, this just returns a 2D path of the outline of the mask shape.
// Arguments: // Arguments:
// x = The width of the dovetail.
// y = The height of the dovetail.
// edge = The length of the edge of the dovetail. // edge = The length of the edge of the dovetail.
// angle = The angle of the chamfer edge, away from vertical. Default: 30. // angle = The angle of the chamfer edge, away from vertical. Default: 30.
// inset = Optional amount to inset code from corner. Default: 0 // inset = Optional amount to inset code from corner. Default: 0
// shelf = The extra height to add to the inside corner of the dovetail. Default: 0 // shelf = The extra height to add to the inside corner of the dovetail. Default: 0
// excess = Extra amount of mask shape to creates on the X- and Y- sides of the shape. // excess = Extra amount of mask shape to creates on the X- and Y- sides of the shape.
// ---
// x = The width of the dovetail.
// y = The height of the dovetail.
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0`
// Example(2D): 2D Dovetail Mask // Example(2D): 2D Dovetail Mask
// mask2d_dovetail(x=10); // mask2d_dovetail(x=10);
// Example(2D): 2D Dovetail Mask by Width. // Example(2D): 2D Dovetail Mask by Width.
@ -1879,7 +2013,7 @@ function mask2d_rabbet(size, excess, anchor=CENTER,spin=0) =
// cube([50,60,70],center=true) // cube([50,60,70],center=true)
// edge_profile([TOP,"Z"],except=[BACK,TOP+LEFT]) // edge_profile([TOP,"Z"],except=[BACK,TOP+LEFT])
// mask2d_dovetail(x=10, inset=2); // mask2d_dovetail(x=10, inset=2);
module mask2d_dovetail(x, y, edge, angle=30, inset=0, shelf=0, excess, anchor=CENTER, spin=0) { module mask2d_dovetail(edge, angle=30, inset=0, shelf=0, excess, x, y, anchor=CENTER, spin=0) {
path = mask2d_dovetail(x=x, y=y, edge=edge, angle=angle, inset=inset, shelf=shelf, excess=excess); path = mask2d_dovetail(x=x, y=y, edge=edge, angle=angle, inset=inset, shelf=shelf, excess=excess);
attachable(anchor,spin, two_d=true, path=path) { attachable(anchor,spin, two_d=true, path=path) {
polygon(path); polygon(path);
@ -1887,7 +2021,7 @@ module mask2d_dovetail(x, y, edge, angle=30, inset=0, shelf=0, excess, anchor=CE
} }
} }
function mask2d_dovetail(x, y, edge, angle=30, inset=0, shelf=0, excess, anchor=CENTER, spin=0) = function mask2d_dovetail(edge, angle=30, inset=0, shelf=0, excess, x, y, anchor=CENTER, spin=0) =
assert(num_defined([x,y,edge])==1) assert(num_defined([x,y,edge])==1)
assert(is_num(first_defined([x,y,edge]))) assert(is_num(first_defined([x,y,edge])))
assert(is_num(angle)) assert(is_num(angle))
@ -1912,8 +2046,14 @@ function mask2d_dovetail(x, y, edge, angle=30, inset=0, shelf=0, excess, anchor=
// Function&Module: mask2d_teardrop() // Function&Module: mask2d_teardrop()
// Usage: // Usage: As Module
// mask2d_teardrop(r|d, [angle], [excess]); // mask2d_teardrop(r|d, <angle>, <excess>);
// Usage: With Attachments
// mask2d_teardrop(r|d, <angle>, <excess>) { attachments }
// Usage: As Function
// path = mask2d_teardrop(r|d, <angle>, <excess>);
// Topics: Shapes (2D), Paths (2D), Path Generators, Attachable, Masks (2D)
// See Also: corner_profile(), edge_profile(), face_profile()
// Description: // Description:
// Creates a 2D teardrop mask shape that is useful for extruding into a 3D mask for a 90º edge. // Creates a 2D teardrop mask shape that is useful for extruding into a 3D mask for a 90º edge.
// This 2D mask is designed to be differenced away from the edge of a shape that is in the first (X+Y+) quadrant. // This 2D mask is designed to be differenced away from the edge of a shape that is in the first (X+Y+) quadrant.
@ -1921,9 +2061,12 @@ function mask2d_dovetail(x, y, edge, angle=30, inset=0, shelf=0, excess, anchor=
// This is particularly useful to make partially rounded bottoms, that don't need support to print. // This is particularly useful to make partially rounded bottoms, that don't need support to print.
// Arguments: // Arguments:
// r = Radius of the rounding. // r = Radius of the rounding.
// d = Diameter of the rounding.
// angle = The maximum angle from vertical. // angle = The maximum angle from vertical.
// excess = Extra amount of mask shape to creates on the X- and Y- sides of the shape. // excess = Extra amount of mask shape to creates on the X- and Y- sides of the shape.
// ---
// d = Diameter of the rounding.
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0`
// Example(2D): 2D Teardrop Mask // Example(2D): 2D Teardrop Mask
// mask2d_teardrop(r=10); // mask2d_teardrop(r=10);
// Example(2D): Using a Custom Angle // Example(2D): Using a Custom Angle
@ -1933,7 +2076,7 @@ function mask2d_dovetail(x, y, edge, angle=30, inset=0, shelf=0, excess, anchor=
// cube([50,60,70],center=true) // cube([50,60,70],center=true)
// edge_profile(BOT) // edge_profile(BOT)
// mask2d_teardrop(r=10, angle=40); // mask2d_teardrop(r=10, angle=40);
function mask2d_teardrop(r,d,angle=45,excess=0.1,anchor=CENTER,spin=0) = function mask2d_teardrop(r, angle=45, excess=0.1, d, anchor=CENTER, spin=0) =
assert(is_num(angle)) assert(is_num(angle))
assert(angle>0 && angle<90) assert(angle>0 && angle<90)
assert(is_num(excess)) assert(is_num(excess))
@ -1950,7 +2093,7 @@ function mask2d_teardrop(r,d,angle=45,excess=0.1,anchor=CENTER,spin=0) =
] ]
) reorient(anchor,spin, two_d=true, path=path, p=path); ) reorient(anchor,spin, two_d=true, path=path, p=path);
module mask2d_teardrop(r,d,angle=45,excess=0.1,anchor=CENTER,spin=0) { module mask2d_teardrop(r, angle=45, excess=0.1, d, anchor=CENTER, spin=0) {
path = mask2d_teardrop(r=r, d=d, angle=angle, excess=excess); path = mask2d_teardrop(r=r, d=d, angle=angle, excess=excess);
attachable(anchor,spin, two_d=true, path=path) { attachable(anchor,spin, two_d=true, path=path) {
polygon(path); polygon(path);
@ -1959,8 +2102,14 @@ module mask2d_teardrop(r,d,angle=45,excess=0.1,anchor=CENTER,spin=0) {
} }
// Function&Module: mask2d_ogee() // Function&Module: mask2d_ogee()
// Usage: // Usage: As Module
// mask2d_ogee(pattern, [excess]); // mask2d_ogee(pattern, <excess>, ...);
// Usage: With Attachments
// mask2d_ogee(pattern, <excess>, ...) { attachments }
// Usage: As Function
// path = mask2d_ogee(pattern, <excess>, ...);
// Topics: Shapes (2D), Paths (2D), Path Generators, Attachable, Masks (2D)
// See Also: corner_profile(), edge_profile(), face_profile()
// //
// Description: // Description:
// Creates a 2D Ogee mask shape that is useful for extruding into a 3D mask for a 90º edge. // Creates a 2D Ogee mask shape that is useful for extruding into a 3D mask for a 90º edge.
@ -1982,6 +2131,9 @@ module mask2d_teardrop(r,d,angle=45,excess=0.1,anchor=CENTER,spin=0) {
// Arguments: // Arguments:
// pattern = A list of pattern pieces to describe the Ogee. // pattern = A list of pattern pieces to describe the Ogee.
// excess = Extra amount of mask shape to creates on the X- and Y- sides of the shape. // excess = Extra amount of mask shape to creates on the X- and Y- sides of the shape.
// ---
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#spin). Default: `0`
// //
// Example(2D): 2D Ogee Mask // Example(2D): 2D Ogee Mask
// mask2d_ogee([ // mask2d_ogee([