Merge pull request #526 from revarbat/revarbat_dev

Added Attachments Tutorial links to attachments.scad docs.
This commit is contained in:
Revar Desmera 2021-05-07 16:07:36 -07:00 committed by GitHub
commit d8e6be5c91
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -79,6 +79,8 @@ $tags_hidden = [];
// at the vector direction given in the `orient` argument. Orientation is always applied after // at the vector direction given in the `orient` argument. Orientation is always applied after
// anchoring and spin. The constants `UP`, `DOWN`, `FRONT`, `BACK`, `LEFT`, and `RIGHT` can be // anchoring and spin. The constants `UP`, `DOWN`, `FRONT`, `BACK`, `LEFT`, and `RIGHT` can be
// added together to form the directional vector for this. ie: `LEFT+BACK` // added together to form the directional vector for this. ie: `LEFT+BACK`
// .
// For a more step-by-step explanation of attachments, see the [[Attachments Tutorial|Tutorial-Attachments]].
// Section: Functions // Section: Functions
@ -89,7 +91,8 @@ $tags_hidden = [];
// Topics: Attachments // Topics: Attachments
// See Also: attach_geom(), reorient(), attachable() // See Also: attach_geom(), reorient(), attachable()
// Description: // Description:
// Creates a anchor data structure. // Creates an anchor data structure. For a more step-by-step explanation of attachments,
// see the [[Attachments Tutorial|Tutorial-Attachments]].
// Arguments: // Arguments:
// name = The string name of the anchor. Lowercase. Words separated by single dashes. No spaces. // name = The string name of the anchor. Lowercase. Words separated by single dashes. No spaces.
// pos = The [X,Y,Z] position of the anchor. // pos = The [X,Y,Z] position of the anchor.
@ -122,6 +125,7 @@ function anchorpt(name, pos=[0,0,0], orient=UP, spin=0) = [name, pos, orient, sp
// //
// Description: // Description:
// Given arguments that describe the geometry of an attachable object, returns the internal geometry description. // Given arguments that describe the geometry of an attachable object, returns the internal geometry description.
// This will probably not not ever need to be called by the end user.
// //
// Arguments: // Arguments:
// --- // ---
@ -631,7 +635,7 @@ function find_anchor(anchor, geom) =
// Topics: Attachments // Topics: Attachments
// See Also: reorient(), attachable() // See Also: reorient(), attachable()
// Description: // Description:
// Returns true if the given space-delimited string of tag names should currently be shown. // Returns true if shapes tagged with any of the given space-delimited string of tag names should currently be shown.
function attachment_is_shown(tags) = function attachment_is_shown(tags) =
assert(!is_undef($tags_shown)) assert(!is_undef($tags_shown))
assert(!is_undef($tags_hidden)) assert(!is_undef($tags_hidden))
@ -693,6 +697,8 @@ function attachment_is_shown(tags) =
// * Translates this part so it's anchor position matches the parent's anchor position. // * Translates this part so it's anchor position matches the parent's anchor position.
// * Rotates this part so it's anchor direction vector exactly opposes the parent's anchor direction vector. // * Rotates this part so it's anchor direction vector exactly opposes the parent's anchor direction vector.
// * Rotates this part so it's anchor spin matches the parent's anchor spin. // * Rotates this part so it's anchor spin matches the parent's anchor spin.
// .
// For a more step-by-step explanation of attachments, see the [[Attachments Tutorial|Tutorial-Attachments]].
// //
// Arguments: // Arguments:
// 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`
@ -803,6 +809,8 @@ function reorient(
// * Translates this part so it's anchor position matches the parent's anchor position. // * Translates this part so it's anchor position matches the parent's anchor position.
// * Rotates this part so it's anchor direction vector exactly opposes the parent's anchor direction vector. // * Rotates this part so it's anchor direction vector exactly opposes the parent's anchor direction vector.
// * Rotates this part so it's anchor spin matches the parent's anchor spin. // * Rotates this part so it's anchor spin matches the parent's anchor spin.
// .
// For a more step-by-step explanation of attachments, see the [[Attachments Tutorial|Tutorial-Attachments]].
// //
// Arguments: // Arguments:
// 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`
@ -989,7 +997,8 @@ module attachable(
// See Also: attachable() // See Also: attachable()
// //
// Description: // Description:
// Attaches children to a parent object at an anchor point. // Attaches children to a parent object at an anchor point. For a more step-by-step explanation
// of attachments, see the [[Attachments Tutorial|Tutorial-Attachments]].
// Arguments: // Arguments:
// from = The vector, or name of the parent anchor point to attach to. // from = The vector, or name of the parent anchor point to attach to.
// Example: // Example:
@ -1019,12 +1028,12 @@ module position(from)
// Topics: Attachments // Topics: Attachments
// See Also: attachable(), position(), face_profile(), edge_profile(), corner_profile() // See Also: attachable(), position(), face_profile(), edge_profile(), corner_profile()
// Description: // Description:
// Attaches children to a parent object at an anchor point and orientation. // Attaches children to a parent object at an anchor point and orientation. Attached objects will
// Attached objects will be overlapped into the parent object by a little bit, // be overlapped into the parent object by a little bit, as specified by the default `$overlap`
// as specified by the default `$overlap` value (0.01 by default), or by the // value (0.01 by default), or by the overriding `overlap=` argument. This is to prevent OpenSCAD
// overriding `overlap=` argument. This is to prevent OpenSCAD from making // from making non-manifold objects. You can also define `$overlap=` as an argument in a parent
// non-manifold objects. You can also define `$overlap=` as an argument in a // module to set the default for all attachments to it. For a more step-by-step explanation of
// parent module to set the default for all attachments to it. // attachments, see the [[Attachments Tutorial|Tutorial-Attachments]].
// Arguments: // Arguments:
// from = The vector, or name of the parent anchor point to attach to. // from = The vector, or name of the parent anchor point to attach to.
// to = Optional name of the child anchor point. If given, orients the child such that the named anchors align together rotationally. // to = Optional name of the child anchor point. If given, orients the child such that the named anchors align together rotationally.
@ -1065,6 +1074,7 @@ module attach(from, to, overlap, norot=false)
// See Also: attachable(), position(), attach(), edge_profile(), corner_profile() // See Also: attachable(), position(), attach(), edge_profile(), corner_profile()
// Description: // Description:
// Given a 2D edge profile, extrudes it into a mask for all edges and corners bounding each given face. // Given a 2D edge profile, extrudes it into a mask for all edges and corners bounding each given face.
// For a more step-by-step explanation of attachments, see the [[Attachments Tutorial|Tutorial-Attachments]].
// Arguments: // Arguments:
// faces = Faces to mask edges and corners of. // faces = Faces to mask edges and corners of.
// r = Radius of corner mask. // r = Radius of corner mask.
@ -1094,8 +1104,9 @@ module face_profile(faces=[], r, d, convexity=10) {
// Topics: Attachments // Topics: Attachments
// See Also: attachable(), position(), attach(), face_profile(), corner_profile() // See Also: attachable(), position(), attach(), face_profile(), corner_profile()
// Description: // Description:
// Takes a 2D mask shape and attaches it to the selected edges, with the appropriate orientation // Takes a 2D mask shape and attaches it to the selected edges, with the appropriate orientation and
// and extruded length to be `diff()`ed away, to give the edge a matching profile. // extruded length to be `diff()`ed away, to give the edge a matching profile. For a more step-by-step
// explanation of attachments, see the [[Attachments Tutorial|Tutorial-Attachments]].
// Arguments: // Arguments:
// edges = Edges to mask. See the docs for [`edges()`](edges.scad#edges) to see acceptable values. Default: All edges. // edges = Edges to mask. See the docs for [`edges()`](edges.scad#edges) to see acceptable values. Default: All edges.
// except = Edges to explicitly NOT mask. See the docs for [`edges()`](edges.scad#edges) to see acceptable values. Default: No edges. // except = Edges to explicitly NOT mask. See the docs for [`edges()`](edges.scad#edges) to see acceptable values. Default: No edges.
@ -1148,7 +1159,8 @@ module edge_profile(edges=EDGES_ALL, except=[], convexity=10) {
// Description: // Description:
// Takes a 2D mask shape, rotationally extrudes and converts it into a corner mask, and attaches it // Takes a 2D mask shape, rotationally extrudes and converts it into a corner mask, and attaches it
// to the selected corners with the appropriate orientation. Tags it as a "mask" to allow it to be // to the selected corners with the appropriate orientation. Tags it as a "mask" to allow it to be
// `diff()`ed away, to give the corner a matching profile. // `diff()`ed away, to give the corner a matching profile. For a more step-by-step explanation of
// attachments, see the [[Attachments Tutorial|Tutorial-Attachments]].
// Arguments: // Arguments:
// corners = Edges to mask. See the docs for [`corners()`](edges.scad#corners) to see acceptable values. Default: All corners. // corners = Edges to mask. See the docs for [`corners()`](edges.scad#corners) to see acceptable values. Default: All corners.
// except = Edges to explicitly NOT mask. See the docs for [`corners()`](edges.scad#corners) to see acceptable values. Default: No corners. // except = Edges to explicitly NOT mask. See the docs for [`corners()`](edges.scad#corners) to see acceptable values. Default: No corners.
@ -1211,8 +1223,8 @@ module corner_profile(corners=CORNERS_ALL, except=[], r, d, convexity=10) {
// Topics: Attachments // Topics: Attachments
// See Also: attachable(), position(), attach(), face_profile(), edge_profile(), corner_mask() // See Also: attachable(), position(), attach(), face_profile(), edge_profile(), corner_mask()
// Description: // Description:
// Takes a 3D mask shape, and attaches it to the given edges, with the // Takes a 3D mask shape, and attaches it to the given edges, with the appropriate orientation to be `diff()`ed away.
// appropriate orientation to be `diff()`ed away. // For a more step-by-step explanation of attachments, see the [[Attachments Tutorial|Tutorial-Attachments]].
// Arguments: // Arguments:
// edges = Edges to mask. See the docs for [`edges()`](edges.scad#edges) to see acceptable values. Default: All edges. // edges = Edges to mask. See the docs for [`edges()`](edges.scad#edges) to see acceptable values. Default: All edges.
// except = Edges to explicitly NOT mask. See the docs for [`edges()`](edges.scad#edges) to see acceptable values. Default: No edges. // except = Edges to explicitly NOT mask. See the docs for [`edges()`](edges.scad#edges) to see acceptable values. Default: No edges.
@ -1255,9 +1267,9 @@ module edge_mask(edges=EDGES_ALL, except=[]) {
// Topics: Attachments // Topics: Attachments
// See Also: attachable(), position(), attach(), face_profile(), edge_profile(), edge_mask() // See Also: attachable(), position(), attach(), face_profile(), edge_profile(), edge_mask()
// Description: // Description:
// Takes a 3D mask shape, and attaches it to the given corners, with the appropriate // Takes a 3D mask shape, and attaches it to the given corners, with the appropriate orientation to
// orientation to be `diff()`ed away. The 3D corner mask shape should be designed to // be `diff()`ed away. The 3D corner mask shape should be designed to mask away the X+Y+Z+ octant.
// mask away the X+Y+Z+ octant. // For a more step-by-step explanation of attachments, see the [[Attachments Tutorial|Tutorial-Attachments]].
// Arguments: // Arguments:
// corners = Edges to mask. See the docs for [`corners()`](edges.scad#corners) to see acceptable values. Default: All corners. // corners = Edges to mask. See the docs for [`corners()`](edges.scad#corners) to see acceptable values. Default: All corners.
// except = Edges to explicitly NOT mask. See the docs for [`corners()`](edges.scad#corners) to see acceptable values. Default: No corners. // except = Edges to explicitly NOT mask. See the docs for [`corners()`](edges.scad#corners) to see acceptable values. Default: No corners.
@ -1309,6 +1321,8 @@ module corner_mask(corners=CORNERS_ALL, except=[]) {
// - `rotate_extrude()` // - `rotate_extrude()`
// - `surface()` // - `surface()`
// - `import()` // - `import()`
// .
// For a more step-by-step explanation of attachments, see the [[Attachments Tutorial|Tutorial-Attachments]].
// Arguments: // Arguments:
// tags = String containing space delimited set of tags to apply. // tags = String containing space delimited set of tags to apply.
module tags(tags) module tags(tags)
@ -1326,7 +1340,8 @@ module tags(tags)
// Topics: Attachments // Topics: Attachments
// See Also: tags(), hide(), show(), diff(), intersect() // See Also: tags(), hide(), show(), diff(), intersect()
// Description: // Description:
// Sets the color for children that can use the $color special variable. // Sets the color for children that can use the $color special variable. For a more step-by-step
// explanation of attachments, see the [[Attachments Tutorial|Tutorial-Attachments]].
// Arguments: // Arguments:
// c = Color name or RGBA vector. // c = Color name or RGBA vector.
// Example: // Example:
@ -1345,6 +1360,7 @@ module recolor(c)
// See Also: tags(), recolor(), show(), diff(), intersect() // See Also: tags(), recolor(), show(), diff(), intersect()
// Description: // Description:
// Hides all children with the given tags. Overrides any previous `hide()` or `show()` calls. // Hides all children with the given tags. Overrides any previous `hide()` or `show()` calls.
// For a more step-by-step explanation of attachments, see the [[Attachments Tutorial|Tutorial-Attachments]].
// Example: // Example:
// hide("A") cube(50, anchor=CENTER, $tags="Main") { // hide("A") cube(50, anchor=CENTER, $tags="Main") {
// attach(LEFT, BOTTOM) cylinder(d=30, l=30, $tags="A"); // attach(LEFT, BOTTOM) cylinder(d=30, l=30, $tags="A");
@ -1365,6 +1381,7 @@ module hide(tags="")
// See Also: tags(), recolor(), hide(), diff(), intersect() // See Also: tags(), recolor(), hide(), diff(), intersect()
// Description: // Description:
// Shows only children with the given tags. Overrides any previous `hide()` or `show()` calls. // Shows only children with the given tags. Overrides any previous `hide()` or `show()` calls.
// For a more step-by-step explanation of attachments, see the [[Attachments Tutorial|Tutorial-Attachments]].
// Example: // Example:
// show("A B") cube(50, anchor=CENTER, $tags="Main") { // show("A B") cube(50, anchor=CENTER, $tags="Main") {
// attach(LEFT, BOTTOM) cylinder(d=30, l=30, $tags="A"); // attach(LEFT, BOTTOM) cylinder(d=30, l=30, $tags="A");
@ -1391,6 +1408,8 @@ module show(tags="")
// `keep` are then unioned with the result. If `keep` is not given, all children without tags in // `keep` are then unioned with the result. If `keep` is not given, all children without tags in
// `pos` or `neg` are then unioned with the result. // `pos` or `neg` are then unioned with the result.
// Cannot be used in conjunction with `intersect()` or `hulling()` on the same parent object. // Cannot be used in conjunction with `intersect()` or `hulling()` on the same parent object.
// .
// For a more step-by-step explanation of attachments, see the [[Attachments Tutorial|Tutorial-Attachments]].
// Arguments: // Arguments:
// neg = String containing space delimited set of tag names of children to difference away. // neg = String containing space delimited set of tag names of children to difference away.
// pos = String containing space delimited set of tag names of children to be differenced away from. // pos = String containing space delimited set of tag names of children to be differenced away from.
@ -1451,6 +1470,8 @@ module diff(neg, pos, keep)
// `keep` is given, then the result is unioned with all the children with tags in `keep`. If `keep` // `keep` is given, then the result is unioned with all the children with tags in `keep`. If `keep`
// is not given, all children without tags in `a` or `b` are unioned with the result. // is not given, all children without tags in `a` or `b` are unioned with the result.
// Cannot be used in conjunction with `diff()` or `hulling()` on the same parent object. // Cannot be used in conjunction with `diff()` or `hulling()` on the same parent object.
// .
// For a more step-by-step explanation of attachments, see the [[Attachments Tutorial|Tutorial-Attachments]].
// Arguments: // Arguments:
// a = String containing space delimited set of tag names of children. // a = String containing space delimited set of tag names of children.
// b = String containing space delimited set of tag names of children. // b = String containing space delimited set of tag names of children.
@ -1498,6 +1519,8 @@ module intersect(a, b=undef, keep=undef)
// If `a` is given as a string, then all children with `$tags` that are in `a` are // If `a` is given as a string, then all children with `$tags` that are in `a` are
// `hull()`ed together and the result is then unioned with all the remaining children. // `hull()`ed together and the result is then unioned with all the remaining children.
// Cannot be used in conjunction with `diff()` or `intersect()` on the same parent object. // Cannot be used in conjunction with `diff()` or `intersect()` on the same parent object.
// .
// For a more step-by-step explanation of attachments, see the [[Attachments Tutorial|Tutorial-Attachments]].
// Arguments: // Arguments:
// a = String containing space delimited set of tag names of children to hull. // a = String containing space delimited set of tag names of children to hull.
// Example: // Example: