Merge pull request #845 from revarbat/revarbat_dev

Enabled attachable(..., geom=)
This commit is contained in:
Revar Desmera 2022-04-11 19:20:09 -07:00 committed by GitHub
commit 1576046795
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 63 additions and 47 deletions

View file

@ -1155,6 +1155,8 @@ module corner_profile(corners=CORNERS_ALL, except=[], r, d, convexity=10) {
// attachable(anchor, spin, region=, l=|h=, [extent=], ...) {OBJECT; children();} // attachable(anchor, spin, region=, l=|h=, [extent=], ...) {OBJECT; children();}
// Usage: VNF Geometry // Usage: VNF Geometry
// attachable(anchor, spin, [orient], vnf=, [extent=], ...) {OBJECT; children();} // attachable(anchor, spin, [orient], vnf=, [extent=], ...) {OBJECT; children();}
// Usage: Pre-Specified Geometry
// attachable(anchor, spin, [orient], geom=) {OBJECT; children();}
// //
// Topics: Attachments // Topics: Attachments
// See Also: reorient() // See Also: reorient()
@ -1212,6 +1214,7 @@ module corner_profile(corners=CORNERS_ALL, except=[], r, d, convexity=10) {
// anchors = If given as a list of anchor points, allows named anchor points. // anchors = If given as a list of anchor points, allows named anchor points.
// two_d = If true, the attachable shape is 2D. If false, 3D. Default: false (3D) // two_d = If true, the attachable shape is 2D. If false, 3D. Default: false (3D)
// axis = The vector pointing along the axis of a cylinder geometry. Default: UP // axis = The vector pointing along the axis of a cylinder geometry. Default: UP
// geom = If given, uses the pre-defined (via {{attach_geom()}} geometry.
// //
// Side Effects: // Side Effects:
// `$parent_anchor` is set to the parent object's `anchor` value. // `$parent_anchor` is set to the parent object's `anchor` value.
@ -1342,6 +1345,16 @@ module corner_profile(corners=CORNERS_ALL, except=[], r, d, convexity=10) {
// polygon(path); // polygon(path);
// children(); // children();
// } // }
//
// Example(NORENDER): Using Pre-defined Geometry
// geom = atype=="perim"? attach_geom(two_d=true, path=path, extent=false) :
// atype=="extents"? attach_geom(two_d=true, path=path, extent=true) :
// atype=="circle"? attach_geom(two_d=true, r=r) :
// assert(false, "Bad atype");
// attachable(anchor, spin, orient, geom=geom) {
// polygon(path);
// children();
// }
module attachable( module attachable(
anchor, spin, orient, anchor, spin, orient,
size, size2, shift, size, size2, shift,
@ -1352,7 +1365,8 @@ module attachable(
offset=[0,0,0], offset=[0,0,0],
anchors=[], anchors=[],
two_d=false, two_d=false,
axis=UP axis=UP,
geom
) { ) {
dummy1 = dummy1 =
assert($children==2, "attachable() expects exactly two children; the shape to manage, and the union of all attachment candidates.") assert($children==2, "attachable() expects exactly two children; the shape to manage, and the union of all attachment candidates.")
@ -1365,7 +1379,7 @@ module attachable(
region = !is_undef(region)? region : region = !is_undef(region)? region :
!is_undef(path)? [path] : !is_undef(path)? [path] :
undef; undef;
geom = _attach_geom( geom = is_def(geom)? geom : attach_geom(
size=size, size2=size2, shift=shift, size=size, size2=size2, shift=shift,
r=r, r1=r1, r2=r2, h=h, r=r, r1=r1, r2=r2, h=h,
d=d, d1=d1, d2=d2, l=l, d=d, d1=d1, d2=d2, l=l,
@ -1492,6 +1506,7 @@ function reorient(
anchors=[], anchors=[],
two_d=false, two_d=false,
axis=UP, axis=UP,
geom,
p=undef p=undef
) = ) =
assert(is_undef(anchor) || is_vector(anchor) || is_string(anchor), str("Got: ",anchor)) assert(is_undef(anchor) || is_vector(anchor) || is_string(anchor), str("Got: ",anchor))
@ -1505,8 +1520,9 @@ function reorient(
!is_undef(path)? [path] : !is_undef(path)? [path] :
undef undef
) )
(anchor==CENTER && spin==0 && orient==UP && p!=undef)? p : let( (anchor==CENTER && spin==0 && orient==UP && p!=undef)? p :
geom = _attach_geom( let(
geom = is_def(geom)? geom : attach_geom(
size=size, size2=size2, shift=shift, size=size, size2=size2, shift=shift,
r=r, r1=r1, r2=r2, h=h, r=r, r1=r1, r2=r2, h=h,
d=d, d1=d1, d2=d2, l=l, d=d, d1=d1, d2=d2, l=l,
@ -1534,37 +1550,29 @@ function reorient(
function named_anchor(name, pos, orient=UP, spin=0) = [name, pos, orient, spin]; function named_anchor(name, pos, orient=UP, spin=0) = [name, pos, orient, spin];
// Function: attach_geom()
//////////////////////////////////////////////////////////////////////////////////////////////////////////////
//
// Attachment internal functions
/// Internal Function: _attach_geom()
// //
// Usage: Square/Trapezoid Geometry // Usage: Square/Trapezoid Geometry
// geom = _attach_geom(two_d=true, size=, [size2=], [shift=], ...); // geom = attach_geom(two_d=true, size=, [size2=], [shift=], ...);
// Usage: Circle/Oval Geometry // Usage: Circle/Oval Geometry
// geom = _attach_geom(two_d=true, r=|d=, ...); // geom = attach_geom(two_d=true, r=|d=, ...);
// Usage: 2D Path/Polygon/Region Geometry // Usage: 2D Path/Polygon/Region Geometry
// geom = _attach_geom(two_d=true, region=, [extent=], ...); // geom = attach_geom(two_d=true, region=, [extent=], ...);
// Usage: Cubical/Prismoidal Geometry // Usage: Cubical/Prismoidal Geometry
// geom = _attach_geom(size=, [size2=], [shift=], ...); // geom = attach_geom(size=, [size2=], [shift=], ...);
// Usage: Cylindrical Geometry // Usage: Cylindrical Geometry
// geom = _attach_geom(r=|d=, l=|h=, [axis=], ...); // geom = attach_geom(r=|d=, l=|h=, [axis=], ...);
// Usage: Conical Geometry // Usage: Conical Geometry
// geom = _attach_geom(r1|d1=, r2=|d2=, l=, [axis=], ...); // geom = attach_geom(r1|d1=, r2=|d2=, l=, [axis=], ...);
// Usage: Spheroid/Ovoid Geometry // Usage: Spheroid/Ovoid Geometry
// geom = _attach_geom(r=|d=, ...); // geom = attach_geom(r=|d=, ...);
// Usage: Extruded 2D Path/Polygon/Region Geometry // Usage: Extruded 2D Path/Polygon/Region Geometry
// geom = _attach_geom(region=, l=|h=, [extent=], ...); // geom = attach_geom(region=, l=|h=, [extent=], ...);
// Usage: VNF Geometry // Usage: VNF Geometry
// geom = _attach_geom(vnf=, [extent=], ...); // geom = attach_geom(vnf=, [extent=], ...);
// //
/// Topics: Attachments // Topics: Attachments
/// See Also: reorient(), attachable() // See Also: reorient(), attachable()
// //
// 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.
@ -1592,69 +1600,69 @@ function named_anchor(name, pos, orient=UP, spin=0) = [name, pos, orient, spin];
// axis = The vector pointing along the axis of a cylinder geometry. Default: UP // axis = The vector pointing along the axis of a cylinder geometry. Default: UP
// //
// Example(NORENDER): Cubical Shape // Example(NORENDER): Cubical Shape
// geom = _attach_geom(size=size); // geom = attach_geom(size=size);
// //
// Example(NORENDER): Prismoidal Shape // Example(NORENDER): Prismoidal Shape
// geom = _attach_geom( // geom = attach_geom(
// size=point3d(botsize,h), // size=point3d(botsize,h),
// size2=topsize, shift=shift // size2=topsize, shift=shift
// ); // );
// //
// Example(NORENDER): Cylindrical Shape, Z-Axis Aligned // Example(NORENDER): Cylindrical Shape, Z-Axis Aligned
// geom = _attach_geom(r=r, h=h); // geom = attach_geom(r=r, h=h);
// //
// Example(NORENDER): Cylindrical Shape, Y-Axis Aligned // Example(NORENDER): Cylindrical Shape, Y-Axis Aligned
// geom = _attach_geom(r=r, h=h, axis=BACK); // geom = attach_geom(r=r, h=h, axis=BACK);
// //
// Example(NORENDER): Cylindrical Shape, X-Axis Aligned // Example(NORENDER): Cylindrical Shape, X-Axis Aligned
// geom = _attach_geom(r=r, h=h, axis=RIGHT); // geom = attach_geom(r=r, h=h, axis=RIGHT);
// //
// Example(NORENDER): Conical Shape, Z-Axis Aligned // Example(NORENDER): Conical Shape, Z-Axis Aligned
// geom = _attach_geom(r1=r1, r2=r2, h=h); // geom = attach_geom(r1=r1, r2=r2, h=h);
// //
// Example(NORENDER): Conical Shape, Y-Axis Aligned // Example(NORENDER): Conical Shape, Y-Axis Aligned
// geom = _attach_geom(r1=r1, r2=r2, h=h, axis=BACK); // geom = attach_geom(r1=r1, r2=r2, h=h, axis=BACK);
// //
// Example(NORENDER): Conical Shape, X-Axis Aligned // Example(NORENDER): Conical Shape, X-Axis Aligned
// geom = _attach_geom(r1=r1, r2=r2, h=h, axis=RIGHT); // geom = attach_geom(r1=r1, r2=r2, h=h, axis=RIGHT);
// //
// Example(NORENDER): Spherical Shape // Example(NORENDER): Spherical Shape
// geom = _attach_geom(r=r); // geom = attach_geom(r=r);
// //
// Example(NORENDER): Ovoid Shape // Example(NORENDER): Ovoid Shape
// geom = _attach_geom(r=[r_x, r_y, r_z]); // geom = attach_geom(r=[r_x, r_y, r_z]);
// //
// Example(NORENDER): Arbitrary VNF Shape, Anchored by Extents // Example(NORENDER): Arbitrary VNF Shape, Anchored by Extents
// geom = _attach_geom(vnf=vnf); // geom = attach_geom(vnf=vnf);
// //
// Example(NORENDER): Arbitrary VNF Shape, Anchored by Intersection // Example(NORENDER): Arbitrary VNF Shape, Anchored by Intersection
// geom = _attach_geom(vnf=vnf, extent=false); // geom = attach_geom(vnf=vnf, extent=false);
// //
// Example(NORENDER): 2D Rectangular Shape // Example(NORENDER): 2D Rectangular Shape
// geom = _attach_geom(two_d=true, size=size); // geom = attach_geom(two_d=true, size=size);
// //
// Example(NORENDER): 2D Trapezoidal Shape // Example(NORENDER): 2D Trapezoidal Shape
// geom = _attach_geom(two_d=true, size=[x1,y], size2=x2, shift=shift); // geom = attach_geom(two_d=true, size=[x1,y], size2=x2, shift=shift);
// //
// Example(NORENDER): 2D Circular Shape // Example(NORENDER): 2D Circular Shape
// geom = _attach_geom(two_d=true, r=r); // geom = attach_geom(two_d=true, r=r);
// //
// Example(NORENDER): 2D Oval Shape // Example(NORENDER): 2D Oval Shape
// geom = _attach_geom(two_d=true, r=[r_x, r_y]); // geom = attach_geom(two_d=true, r=[r_x, r_y]);
// //
// Example(NORENDER): Arbitrary 2D Region Shape, Anchored by Extents // Example(NORENDER): Arbitrary 2D Region Shape, Anchored by Extents
// geom = _attach_geom(two_d=true, region=region); // geom = attach_geom(two_d=true, region=region);
// //
// Example(NORENDER): Arbitrary 2D Region Shape, Anchored by Intersection // Example(NORENDER): Arbitrary 2D Region Shape, Anchored by Intersection
// geom = _attach_geom(two_d=true, region=region, extent=false); // geom = attach_geom(two_d=true, region=region, extent=false);
// //
// Example(NORENDER): Extruded Region, Anchored by Extents // Example(NORENDER): Extruded Region, Anchored by Extents
// geom = _attach_geom(region=region, l=height); // geom = attach_geom(region=region, l=height);
// //
// Example(NORENDER): Extruded Region, Anchored by Intersection // Example(NORENDER): Extruded Region, Anchored by Intersection
// geom = _attach_geom(region=region, l=length, extent=false); // geom = attach_geom(region=region, l=length, extent=false);
// //
function _attach_geom( function attach_geom(
size, size2, shift, size, size2, shift,
r,r1,r2, d,d1,d2, l,h, r,r1,r2, d,d1,d2, l,h,
vnf, region, vnf, region,
@ -1738,6 +1746,14 @@ function _attach_geom(
//////////////////////////////////////////////////////////////////////////////////////////////////////////////
//
// Attachment internal functions
/// Internal Function: _attach_geom_2d() /// Internal Function: _attach_geom_2d()
// Usage: // Usage:
// bool = _attach_geom_2d(geom); // bool = _attach_geom_2d(geom);

View file

@ -1584,7 +1584,7 @@ module text(text, size=10, font="Helvetica", halign, valign, spacing=1.0, direct
assert(is_undef(spin) || is_vector(spin,3) || is_num(spin), str("Got: ",spin)); assert(is_undef(spin) || is_vector(spin,3) || is_num(spin), str("Got: ",spin));
anchor = default(anchor, CENTER); anchor = default(anchor, CENTER);
spin = default(spin, 0); spin = default(spin, 0);
geom = _attach_geom(size=[size,size],two_d=true); geom = attach_geom(size=[size,size],two_d=true);
anch = !any([for (c=anchor) c=="["])? anchor : anch = !any([for (c=anchor) c=="["])? anchor :
let( let(
parts = str_split(str_split(str_split(anchor,"]")[0],"[")[1],","), parts = str_split(str_split(str_split(anchor,"]")[0],"[")[1],","),

View file

@ -2442,7 +2442,7 @@ module text3d(text, h=1, size=10, font="Helvetica", halign, valign, spacing=1.0,
anchor = default(anchor, CENTER); anchor = default(anchor, CENTER);
spin = default(spin, 0); spin = default(spin, 0);
orient = default(orient, UP); orient = default(orient, UP);
geom = _attach_geom(size=[size,size,h]); geom = attach_geom(size=[size,size,h]);
anch = !any([for (c=anchor) c=="["])? anchor : anch = !any([for (c=anchor) c=="["])? anchor :
let( let(
parts = str_split(str_split(str_split(anchor,"]")[0],"[")[1],","), parts = str_split(str_split(str_split(anchor,"]")[0],"[")[1],","),