mirror of
https://github.com/revarbat/BOSL2.git
synced 2025-01-16 21:58:27 +01:00
rename anchorpt to named_anchor
This commit is contained in:
parent
32d9a96bc4
commit
fd0bcc0903
@ -1008,9 +1008,9 @@ module attachable(
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Function: anchorpt()
|
// Function: named_anchor()
|
||||||
// Usage:
|
// Usage:
|
||||||
// a = anchorpt(name, pos, [orient], [spin]);
|
// a = named_anchor(name, pos, [orient], [spin]);
|
||||||
// Topics: Attachments
|
// Topics: Attachments
|
||||||
// See Also: reorient(), attachable()
|
// See Also: reorient(), attachable()
|
||||||
// Description:
|
// Description:
|
||||||
@ -1021,7 +1021,7 @@ module attachable(
|
|||||||
// pos = The [X,Y,Z] position of the anchor.
|
// pos = The [X,Y,Z] position of the anchor.
|
||||||
// orient = A vector pointing in the direction parts should project from the anchor position.
|
// orient = A vector pointing in the direction parts should project from the anchor position.
|
||||||
// spin = If needed, the angle to rotate the part around the direction vector.
|
// spin = If needed, the angle to rotate the part around the direction vector.
|
||||||
function anchorpt(name, pos=[0,0,0], orient=UP, spin=0) = [name, pos, orient, spin];
|
function named_anchor(name, pos=[0,0,0], orient=UP, spin=0) = [name, pos, orient, spin];
|
||||||
|
|
||||||
|
|
||||||
// Function: reorient()
|
// Function: reorient()
|
||||||
|
@ -67,8 +67,8 @@ module pco1810_neck(wall=2, anchor="support-ring", spin=0, orient=UP)
|
|||||||
h = support_h+neck_h;
|
h = support_h+neck_h;
|
||||||
thread_h = (thread_od-threadbase_d)/2;
|
thread_h = (thread_od-threadbase_d)/2;
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("support-ring", [0,0,neck_h-h/2]),
|
named_anchor("support-ring", [0,0,neck_h-h/2]),
|
||||||
anchorpt("tamper-ring", [0,0,h/2-tamper_base_h])
|
named_anchor("tamper-ring", [0,0,h/2-tamper_base_h])
|
||||||
];
|
];
|
||||||
attachable(anchor,spin,orient, d1=neck_d, d2=lip_recess_d+2*lip_leadin_r, l=h, anchors=anchors) {
|
attachable(anchor,spin,orient, d1=neck_d, d2=lip_recess_d+2*lip_leadin_r, l=h, anchors=anchors) {
|
||||||
down(h/2) {
|
down(h/2) {
|
||||||
@ -173,7 +173,7 @@ module pco1810_cap(wall=2, texture="none", anchor=BOTTOM, spin=0, orient=UP)
|
|||||||
w = cap_id + 2*wall;
|
w = cap_id + 2*wall;
|
||||||
h = tamper_ring_h + wall;
|
h = tamper_ring_h + wall;
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("inside-top", [0,0,-(h/2-wall)])
|
named_anchor("inside-top", [0,0,-(h/2-wall)])
|
||||||
];
|
];
|
||||||
attachable(anchor,spin,orient, d=w, l=h, anchors=anchors) {
|
attachable(anchor,spin,orient, d=w, l=h, anchors=anchors) {
|
||||||
down(h/2) zrot(45) {
|
down(h/2) zrot(45) {
|
||||||
@ -260,8 +260,8 @@ module pco1881_neck(wall=2, anchor="support-ring", spin=0, orient=UP)
|
|||||||
h = support_h+neck_h;
|
h = support_h+neck_h;
|
||||||
thread_h = (thread_od-threadbase_d)/2;
|
thread_h = (thread_od-threadbase_d)/2;
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("support-ring", [0,0,neck_h-h/2]),
|
named_anchor("support-ring", [0,0,neck_h-h/2]),
|
||||||
anchorpt("tamper-ring", [0,0,h/2-tamper_base_h])
|
named_anchor("tamper-ring", [0,0,h/2-tamper_base_h])
|
||||||
];
|
];
|
||||||
attachable(anchor,spin,orient, d1=neck_d, d2=lip_recess_d+2*lip_leadin_r, l=h, anchors=anchors) {
|
attachable(anchor,spin,orient, d1=neck_d, d2=lip_recess_d+2*lip_leadin_r, l=h, anchors=anchors) {
|
||||||
down(h/2) {
|
down(h/2) {
|
||||||
@ -357,7 +357,7 @@ module pco1881_cap(wall=2, texture="none", anchor=BOTTOM, spin=0, orient=UP)
|
|||||||
w = 28.58 + 2*wall;
|
w = 28.58 + 2*wall;
|
||||||
h = 11.2 + wall;
|
h = 11.2 + wall;
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("inside-top", [0,0,-(h/2-wall)])
|
named_anchor("inside-top", [0,0,-(h/2-wall)])
|
||||||
];
|
];
|
||||||
attachable(anchor,spin,orient, d=w, l=h, anchors=anchors) {
|
attachable(anchor,spin,orient, d=w, l=h, anchors=anchors) {
|
||||||
down(h/2) zrot(45) {
|
down(h/2) zrot(45) {
|
||||||
@ -448,7 +448,7 @@ module generic_bottle_neck(
|
|||||||
$fn = segs(33 / 2);
|
$fn = segs(33 / 2);
|
||||||
thread_h = (thread_od - threadbase_d) / 2;
|
thread_h = (thread_od - threadbase_d) / 2;
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("support-ring", [0, 0, 0 - h / 2])
|
named_anchor("support-ring", [0, 0, 0 - h / 2])
|
||||||
];
|
];
|
||||||
attachable(anchor, spin, orient, d1 = neck_d, d2 = 0, l = h, anchors = anchors) {
|
attachable(anchor, spin, orient, d1 = neck_d, d2 = 0, l = h, anchors = anchors) {
|
||||||
down(h / 2) {
|
down(h / 2) {
|
||||||
@ -563,7 +563,7 @@ module generic_bottle_cap(
|
|||||||
heightMagMult = (height > 11.2) ? height / 11.2 : 1;
|
heightMagMult = (height > 11.2) ? height / 11.2 : 1;
|
||||||
|
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("inside-top", [0, 0, -(h / 2 - wall)])
|
named_anchor("inside-top", [0, 0, -(h / 2 - wall)])
|
||||||
];
|
];
|
||||||
attachable(anchor, spin, orient, d = w, l = h, anchors = anchors) {
|
attachable(anchor, spin, orient, d = w, l = h, anchors = anchors) {
|
||||||
down(h / 2) {
|
down(h / 2) {
|
||||||
|
76
gears.scad
76
gears.scad
@ -579,12 +579,12 @@ function rack2d(
|
|||||||
xd = d * sin(pressure_angle),
|
xd = d * sin(pressure_angle),
|
||||||
l = teeth * pitch,
|
l = teeth * pitch,
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("adendum", [ 0, a,0], BACK),
|
named_anchor("adendum", [ 0, a,0], BACK),
|
||||||
anchorpt("adendum-left", [-l/2, a,0], LEFT),
|
named_anchor("adendum-left", [-l/2, a,0], LEFT),
|
||||||
anchorpt("adendum-right", [ l/2, a,0], RIGHT),
|
named_anchor("adendum-right", [ l/2, a,0], RIGHT),
|
||||||
anchorpt("dedendum", [ 0,-d,0], BACK),
|
named_anchor("dedendum", [ 0,-d,0], BACK),
|
||||||
anchorpt("dedendum-left", [-l/2,-d,0], LEFT),
|
named_anchor("dedendum-left", [-l/2,-d,0], LEFT),
|
||||||
anchorpt("dedendum-right", [ l/2,-d,0], RIGHT),
|
named_anchor("dedendum-right", [ l/2,-d,0], RIGHT),
|
||||||
],
|
],
|
||||||
path = [
|
path = [
|
||||||
[-(teeth-1)/2 * pitch + -1/2 * pitch, a-height],
|
[-(teeth-1)/2 * pitch + -1/2 * pitch, a-height],
|
||||||
@ -619,12 +619,12 @@ module rack2d(
|
|||||||
d = dedendum(pitch, clearance);
|
d = dedendum(pitch, clearance);
|
||||||
l = teeth * pitch;
|
l = teeth * pitch;
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("adendum", [ 0, a,0], BACK),
|
named_anchor("adendum", [ 0, a,0], BACK),
|
||||||
anchorpt("adendum-left", [-l/2, a,0], LEFT),
|
named_anchor("adendum-left", [-l/2, a,0], LEFT),
|
||||||
anchorpt("adendum-right", [ l/2, a,0], RIGHT),
|
named_anchor("adendum-right", [ l/2, a,0], RIGHT),
|
||||||
anchorpt("dedendum", [ 0,-d,0], BACK),
|
named_anchor("dedendum", [ 0,-d,0], BACK),
|
||||||
anchorpt("dedendum-left", [-l/2,-d,0], LEFT),
|
named_anchor("dedendum-left", [-l/2,-d,0], LEFT),
|
||||||
anchorpt("dedendum-right", [ l/2,-d,0], RIGHT),
|
named_anchor("dedendum-right", [ l/2,-d,0], RIGHT),
|
||||||
];
|
];
|
||||||
path = rack2d(
|
path = rack2d(
|
||||||
pitch = pitch,
|
pitch = pitch,
|
||||||
@ -994,9 +994,9 @@ function bevel_gear(
|
|||||||
lvnf = left_handed? vnf1 : xflip(p=vnf1),
|
lvnf = left_handed? vnf1 : xflip(p=vnf1),
|
||||||
vnf = down(cpz, p=lvnf),
|
vnf = down(cpz, p=lvnf),
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("pitchbase", [0,0,pitchoff-thickness/2]),
|
named_anchor("pitchbase", [0,0,pitchoff-thickness/2]),
|
||||||
anchorpt("flattop", [0,0,thickness/2]),
|
named_anchor("flattop", [0,0,thickness/2]),
|
||||||
anchorpt("apex", [0,0,hyp_ang_to_opp(ocone_rad,90-pitch_angle)+pitchoff-thickness/2])
|
named_anchor("apex", [0,0,hyp_ang_to_opp(ocone_rad,90-pitch_angle)+pitchoff-thickness/2])
|
||||||
]
|
]
|
||||||
) reorient(anchor,spin,orient, vnf=vnf, extent=true, anchors=anchors, p=vnf);
|
) reorient(anchor,spin,orient, vnf=vnf, extent=true, anchors=anchors, p=vnf);
|
||||||
|
|
||||||
@ -1048,9 +1048,9 @@ module bevel_gear(
|
|||||||
axis_zs = [for (p=vnf[0]) if(norm(point2d(p)) < EPSILON) p.z];
|
axis_zs = [for (p=vnf[0]) if(norm(point2d(p)) < EPSILON) p.z];
|
||||||
thickness = max(axis_zs) - min(axis_zs);
|
thickness = max(axis_zs) - min(axis_zs);
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("pitchbase", [0,0,pitchoff-thickness/2]),
|
named_anchor("pitchbase", [0,0,pitchoff-thickness/2]),
|
||||||
anchorpt("flattop", [0,0,thickness/2]),
|
named_anchor("flattop", [0,0,thickness/2]),
|
||||||
anchorpt("apex", [0,0,adj_ang_to_opp(pr,90-pitch_angle)+pitchoff-thickness/2])
|
named_anchor("apex", [0,0,adj_ang_to_opp(pr,90-pitch_angle)+pitchoff-thickness/2])
|
||||||
];
|
];
|
||||||
attachable(anchor,spin,orient, r1=pr, r2=ipr, h=thickness, anchors=anchors) {
|
attachable(anchor,spin,orient, r1=pr, r2=ipr, h=thickness, anchors=anchors) {
|
||||||
difference() {
|
difference() {
|
||||||
@ -1137,16 +1137,16 @@ module rack(
|
|||||||
d = dedendum(pitch, clearance);
|
d = dedendum(pitch, clearance);
|
||||||
l = teeth * pitch;
|
l = teeth * pitch;
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("adendum", [0,0,a], BACK),
|
named_anchor("adendum", [0,0,a], BACK),
|
||||||
anchorpt("adendum-left", [-l/2,0,a], LEFT),
|
named_anchor("adendum-left", [-l/2,0,a], LEFT),
|
||||||
anchorpt("adendum-right", [ l/2,0,a], RIGHT),
|
named_anchor("adendum-right", [ l/2,0,a], RIGHT),
|
||||||
anchorpt("adendum-front", [0,-thickness/2,a], DOWN),
|
named_anchor("adendum-front", [0,-thickness/2,a], DOWN),
|
||||||
anchorpt("adendum-back", [0, thickness/2,a], UP),
|
named_anchor("adendum-back", [0, thickness/2,a], UP),
|
||||||
anchorpt("dedendum", [0,0,-d], BACK),
|
named_anchor("dedendum", [0,0,-d], BACK),
|
||||||
anchorpt("dedendum-left", [-l/2,0,-d], LEFT),
|
named_anchor("dedendum-left", [-l/2,0,-d], LEFT),
|
||||||
anchorpt("dedendum-right", [ l/2,0,-d], RIGHT),
|
named_anchor("dedendum-right", [ l/2,0,-d], RIGHT),
|
||||||
anchorpt("dedendum-front", [0,-thickness/2,-d], DOWN),
|
named_anchor("dedendum-front", [0,-thickness/2,-d], DOWN),
|
||||||
anchorpt("dedendum-back", [0, thickness/2,-d], UP),
|
named_anchor("dedendum-back", [0, thickness/2,-d], UP),
|
||||||
];
|
];
|
||||||
attachable(anchor,spin,orient, size=[l, thickness, 2*abs(a-height)], anchors=anchors) {
|
attachable(anchor,spin,orient, size=[l, thickness, 2*abs(a-height)], anchors=anchors) {
|
||||||
skew(sxy=tan(helical)) xrot(90) {
|
skew(sxy=tan(helical)) xrot(90) {
|
||||||
@ -1186,16 +1186,16 @@ function rack(
|
|||||||
d = dedendum(pitch, clearance),
|
d = dedendum(pitch, clearance),
|
||||||
l = teeth * pitch,
|
l = teeth * pitch,
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("adendum", [0,0,a], BACK),
|
named_anchor("adendum", [0,0,a], BACK),
|
||||||
anchorpt("adendum-left", [-l/2,0,a], LEFT),
|
named_anchor("adendum-left", [-l/2,0,a], LEFT),
|
||||||
anchorpt("adendum-right", [ l/2,0,a], RIGHT),
|
named_anchor("adendum-right", [ l/2,0,a], RIGHT),
|
||||||
anchorpt("adendum-front", [0,-thickness/2,a], DOWN),
|
named_anchor("adendum-front", [0,-thickness/2,a], DOWN),
|
||||||
anchorpt("adendum-back", [0, thickness/2,a], UP),
|
named_anchor("adendum-back", [0, thickness/2,a], UP),
|
||||||
anchorpt("dedendum", [0,0,-d], BACK),
|
named_anchor("dedendum", [0,0,-d], BACK),
|
||||||
anchorpt("dedendum-left", [-l/2,0,-d], LEFT),
|
named_anchor("dedendum-left", [-l/2,0,-d], LEFT),
|
||||||
anchorpt("dedendum-right", [ l/2,0,-d], RIGHT),
|
named_anchor("dedendum-right", [ l/2,0,-d], RIGHT),
|
||||||
anchorpt("dedendum-front", [0,-thickness/2,-d], DOWN),
|
named_anchor("dedendum-front", [0,-thickness/2,-d], DOWN),
|
||||||
anchorpt("dedendum-back", [0, thickness/2,-d], UP),
|
named_anchor("dedendum-back", [0, thickness/2,-d], UP),
|
||||||
],
|
],
|
||||||
path = rack2d(
|
path = rack2d(
|
||||||
pitch = pitch,
|
pitch = pitch,
|
||||||
|
@ -86,9 +86,9 @@ module linear_bearing_housing(d=15, l=24, tab=7, gap=5, wall=3, tabwall=5, screw
|
|||||||
tabh = tab/2+od/2*sqrt(2)-ogap/2;
|
tabh = tab/2+od/2*sqrt(2)-ogap/2;
|
||||||
h = od+tab/2;
|
h = od+tab/2;
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("axis", [0,0,-tab/2/2]),
|
named_anchor("axis", [0,0,-tab/2/2]),
|
||||||
anchorpt("screw", [0,2-ogap/2,tabh-tab/2/2],FWD),
|
named_anchor("screw", [0,2-ogap/2,tabh-tab/2/2],FWD),
|
||||||
anchorpt("nut", [0,ogap/2-2,tabh-tab/2/2],FWD)
|
named_anchor("nut", [0,ogap/2-2,tabh-tab/2/2],FWD)
|
||||||
];
|
];
|
||||||
attachable(anchor,spin,orient, size=[l, od, h], anchors=anchors) {
|
attachable(anchor,spin,orient, size=[l, od, h], anchors=anchors) {
|
||||||
down(tab/2/2)
|
down(tab/2/2)
|
||||||
|
@ -395,8 +395,8 @@ module generic_screw(
|
|||||||
) {
|
) {
|
||||||
sides = max(12, segs(screwsize/2));
|
sides = max(12, segs(screwsize/2));
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("countersunk", [0,0,(headlen+screwlen)/2-0.01]),
|
named_anchor("countersunk", [0,0,(headlen+screwlen)/2-0.01]),
|
||||||
anchorpt("base", [0,0,-headlen/2+screwlen/2])
|
named_anchor("base", [0,0,-headlen/2+screwlen/2])
|
||||||
];
|
];
|
||||||
attachable(anchor,spin,orient, d=screwsize, l=headlen+screwlen, anchors=anchors) {
|
attachable(anchor,spin,orient, d=screwsize, l=headlen+screwlen, anchors=anchors) {
|
||||||
down(headlen/2-screwlen/2) {
|
down(headlen/2-screwlen/2) {
|
||||||
@ -517,9 +517,9 @@ module metric_bolt(
|
|||||||
);
|
);
|
||||||
|
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("countersunk", [0,0,base+sunklen]),
|
named_anchor("countersunk", [0,0,base+sunklen]),
|
||||||
anchorpt("base", [0,0,base]),
|
named_anchor("base", [0,0,base]),
|
||||||
anchorpt("shank", [0,0,base-shank])
|
named_anchor("shank", [0,0,base-shank])
|
||||||
];
|
];
|
||||||
|
|
||||||
//color("silver")
|
//color("silver")
|
||||||
|
@ -122,14 +122,14 @@ module nema11_stepper(h=24, shaft=5, shaft_len=20, anchor=TOP, spin=0, orient=UP
|
|||||||
screw_depth = nema_motor_screw_depth(size);
|
screw_depth = nema_motor_screw_depth(size);
|
||||||
|
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("shaft-top", [0,0,h/2+shaft_len]),
|
named_anchor("shaft-top", [0,0,h/2+shaft_len]),
|
||||||
anchorpt("shaft-middle", [0,0,h/2+plinth_height+(shaft_len-plinth_height)/2]),
|
named_anchor("shaft-middle", [0,0,h/2+plinth_height+(shaft_len-plinth_height)/2]),
|
||||||
anchorpt("shaft-bottom", [0,0,h/2+plinth_height+0.1]),
|
named_anchor("shaft-bottom", [0,0,h/2+plinth_height+0.1]),
|
||||||
anchorpt("plinth-top", [0,0,h/2+plinth_height]),
|
named_anchor("plinth-top", [0,0,h/2+plinth_height]),
|
||||||
anchorpt("screw1", [+screw_spacing/2, +screw_spacing/2, h/2]),
|
named_anchor("screw1", [+screw_spacing/2, +screw_spacing/2, h/2]),
|
||||||
anchorpt("screw2", [-screw_spacing/2, +screw_spacing/2, h/2]),
|
named_anchor("screw2", [-screw_spacing/2, +screw_spacing/2, h/2]),
|
||||||
anchorpt("screw3", [-screw_spacing/2, -screw_spacing/2, h/2]),
|
named_anchor("screw3", [-screw_spacing/2, -screw_spacing/2, h/2]),
|
||||||
anchorpt("screw4", [+screw_spacing/2, -screw_spacing/2, h/2]),
|
named_anchor("screw4", [+screw_spacing/2, -screw_spacing/2, h/2]),
|
||||||
];
|
];
|
||||||
attachable(anchor,spin,orient, size=[motor_width, motor_width, h], anchors=anchors) {
|
attachable(anchor,spin,orient, size=[motor_width, motor_width, h], anchors=anchors) {
|
||||||
up(h/2)
|
up(h/2)
|
||||||
@ -187,14 +187,14 @@ module nema14_stepper(h=24, shaft=5, shaft_len=24, anchor=TOP, spin=0, orient=UP
|
|||||||
screw_depth = nema_motor_screw_depth(size);
|
screw_depth = nema_motor_screw_depth(size);
|
||||||
|
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("shaft-top", [0,0,h/2+shaft_len]),
|
named_anchor("shaft-top", [0,0,h/2+shaft_len]),
|
||||||
anchorpt("shaft-middle", [0,0,h/2+plinth_height+(shaft_len-plinth_height)/2]),
|
named_anchor("shaft-middle", [0,0,h/2+plinth_height+(shaft_len-plinth_height)/2]),
|
||||||
anchorpt("shaft-bottom", [0,0,h/2+plinth_height+0.1]),
|
named_anchor("shaft-bottom", [0,0,h/2+plinth_height+0.1]),
|
||||||
anchorpt("plinth-top", [0,0,h/2+plinth_height]),
|
named_anchor("plinth-top", [0,0,h/2+plinth_height]),
|
||||||
anchorpt("screw1", [+screw_spacing/2, +screw_spacing/2, h/2]),
|
named_anchor("screw1", [+screw_spacing/2, +screw_spacing/2, h/2]),
|
||||||
anchorpt("screw2", [-screw_spacing/2, +screw_spacing/2, h/2]),
|
named_anchor("screw2", [-screw_spacing/2, +screw_spacing/2, h/2]),
|
||||||
anchorpt("screw3", [-screw_spacing/2, -screw_spacing/2, h/2]),
|
named_anchor("screw3", [-screw_spacing/2, -screw_spacing/2, h/2]),
|
||||||
anchorpt("screw4", [+screw_spacing/2, -screw_spacing/2, h/2]),
|
named_anchor("screw4", [+screw_spacing/2, -screw_spacing/2, h/2]),
|
||||||
];
|
];
|
||||||
attachable(anchor,spin,orient, size=[motor_width, motor_width, h], anchors=anchors) {
|
attachable(anchor,spin,orient, size=[motor_width, motor_width, h], anchors=anchors) {
|
||||||
up(h/2)
|
up(h/2)
|
||||||
@ -252,14 +252,14 @@ module nema17_stepper(h=34, shaft=5, shaft_len=20, anchor=TOP, spin=0, orient=UP
|
|||||||
screw_depth = nema_motor_screw_depth(size);
|
screw_depth = nema_motor_screw_depth(size);
|
||||||
|
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("shaft-top", [0,0,h/2+shaft_len]),
|
named_anchor("shaft-top", [0,0,h/2+shaft_len]),
|
||||||
anchorpt("shaft-middle", [0,0,h/2+plinth_height+(shaft_len-plinth_height)/2]),
|
named_anchor("shaft-middle", [0,0,h/2+plinth_height+(shaft_len-plinth_height)/2]),
|
||||||
anchorpt("shaft-bottom", [0,0,h/2+plinth_height+0.1]),
|
named_anchor("shaft-bottom", [0,0,h/2+plinth_height+0.1]),
|
||||||
anchorpt("plinth-top", [0,0,h/2+plinth_height]),
|
named_anchor("plinth-top", [0,0,h/2+plinth_height]),
|
||||||
anchorpt("screw1", [+screw_spacing/2, +screw_spacing/2, h/2]),
|
named_anchor("screw1", [+screw_spacing/2, +screw_spacing/2, h/2]),
|
||||||
anchorpt("screw2", [-screw_spacing/2, +screw_spacing/2, h/2]),
|
named_anchor("screw2", [-screw_spacing/2, +screw_spacing/2, h/2]),
|
||||||
anchorpt("screw3", [-screw_spacing/2, -screw_spacing/2, h/2]),
|
named_anchor("screw3", [-screw_spacing/2, -screw_spacing/2, h/2]),
|
||||||
anchorpt("screw4", [+screw_spacing/2, -screw_spacing/2, h/2]),
|
named_anchor("screw4", [+screw_spacing/2, -screw_spacing/2, h/2]),
|
||||||
];
|
];
|
||||||
attachable(anchor,spin,orient, size=[motor_width, motor_width, h], anchors=anchors) {
|
attachable(anchor,spin,orient, size=[motor_width, motor_width, h], anchors=anchors) {
|
||||||
up(h/2)
|
up(h/2)
|
||||||
@ -337,14 +337,14 @@ module nema23_stepper(h=50, shaft=6.35, shaft_len=25, anchor=TOP, spin=0, orient
|
|||||||
|
|
||||||
screw_inset = motor_width - screw_spacing + 1;
|
screw_inset = motor_width - screw_spacing + 1;
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("shaft-top", [0,0,h/2+shaft_len]),
|
named_anchor("shaft-top", [0,0,h/2+shaft_len]),
|
||||||
anchorpt("shaft-middle", [0,0,h/2+plinth_height+(shaft_len-plinth_height)/2]),
|
named_anchor("shaft-middle", [0,0,h/2+plinth_height+(shaft_len-plinth_height)/2]),
|
||||||
anchorpt("shaft-bottom", [0,0,h/2+plinth_height+0.1]),
|
named_anchor("shaft-bottom", [0,0,h/2+plinth_height+0.1]),
|
||||||
anchorpt("plinth-top", [0,0,h/2+plinth_height]),
|
named_anchor("plinth-top", [0,0,h/2+plinth_height]),
|
||||||
anchorpt("screw1", [+screw_spacing/2, +screw_spacing/2, h/2]),
|
named_anchor("screw1", [+screw_spacing/2, +screw_spacing/2, h/2]),
|
||||||
anchorpt("screw2", [-screw_spacing/2, +screw_spacing/2, h/2]),
|
named_anchor("screw2", [-screw_spacing/2, +screw_spacing/2, h/2]),
|
||||||
anchorpt("screw3", [-screw_spacing/2, -screw_spacing/2, h/2]),
|
named_anchor("screw3", [-screw_spacing/2, -screw_spacing/2, h/2]),
|
||||||
anchorpt("screw4", [+screw_spacing/2, -screw_spacing/2, h/2]),
|
named_anchor("screw4", [+screw_spacing/2, -screw_spacing/2, h/2]),
|
||||||
];
|
];
|
||||||
attachable(anchor,spin,orient, size=[motor_width, motor_width, h], anchors=anchors) {
|
attachable(anchor,spin,orient, size=[motor_width, motor_width, h], anchors=anchors) {
|
||||||
up(h/2)
|
up(h/2)
|
||||||
@ -404,14 +404,14 @@ module nema34_stepper(h=75, shaft=12.7, shaft_len=32, anchor=TOP, spin=0, orient
|
|||||||
|
|
||||||
screw_inset = motor_width - screw_spacing + 1;
|
screw_inset = motor_width - screw_spacing + 1;
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("shaft-top", [0,0,h/2+shaft_len]),
|
named_anchor("shaft-top", [0,0,h/2+shaft_len]),
|
||||||
anchorpt("shaft-middle", [0,0,h/2+plinth_height+(shaft_len-plinth_height)/2]),
|
named_anchor("shaft-middle", [0,0,h/2+plinth_height+(shaft_len-plinth_height)/2]),
|
||||||
anchorpt("shaft-bottom", [0,0,h/2+plinth_height+0.1]),
|
named_anchor("shaft-bottom", [0,0,h/2+plinth_height+0.1]),
|
||||||
anchorpt("plinth-top", [0,0,h/2+plinth_height]),
|
named_anchor("plinth-top", [0,0,h/2+plinth_height]),
|
||||||
anchorpt("screw1", [+screw_spacing/2, +screw_spacing/2, h/2]),
|
named_anchor("screw1", [+screw_spacing/2, +screw_spacing/2, h/2]),
|
||||||
anchorpt("screw2", [-screw_spacing/2, +screw_spacing/2, h/2]),
|
named_anchor("screw2", [-screw_spacing/2, +screw_spacing/2, h/2]),
|
||||||
anchorpt("screw3", [-screw_spacing/2, -screw_spacing/2, h/2]),
|
named_anchor("screw3", [-screw_spacing/2, -screw_spacing/2, h/2]),
|
||||||
anchorpt("screw4", [+screw_spacing/2, -screw_spacing/2, h/2]),
|
named_anchor("screw4", [+screw_spacing/2, -screw_spacing/2, h/2]),
|
||||||
];
|
];
|
||||||
attachable(anchor,spin,orient, size=[motor_width, motor_width, h], anchors=anchors) {
|
attachable(anchor,spin,orient, size=[motor_width, motor_width, h], anchors=anchors) {
|
||||||
up(h/2)
|
up(h/2)
|
||||||
@ -472,10 +472,10 @@ module nema_mount_holes(size=17, depth=5, l=5, anchor=CENTER, spin=0, orient=UP)
|
|||||||
screw_size = nema_motor_screw_size(size)+$slop;
|
screw_size = nema_motor_screw_size(size)+$slop;
|
||||||
|
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("screw1", [+screw_spacing/2, +screw_spacing/2, depth/2]),
|
named_anchor("screw1", [+screw_spacing/2, +screw_spacing/2, depth/2]),
|
||||||
anchorpt("screw2", [-screw_spacing/2, +screw_spacing/2, depth/2]),
|
named_anchor("screw2", [-screw_spacing/2, +screw_spacing/2, depth/2]),
|
||||||
anchorpt("screw3", [-screw_spacing/2, -screw_spacing/2, depth/2]),
|
named_anchor("screw3", [-screw_spacing/2, -screw_spacing/2, depth/2]),
|
||||||
anchorpt("screw4", [+screw_spacing/2, -screw_spacing/2, depth/2]),
|
named_anchor("screw4", [+screw_spacing/2, -screw_spacing/2, depth/2]),
|
||||||
];
|
];
|
||||||
screwfn = quantup(max(8,segs(screw_size/2)),4);
|
screwfn = quantup(max(8,segs(screw_size/2)),4);
|
||||||
plinthfn = quantup(max(8,segs(plinth_diam/2)),4);
|
plinthfn = quantup(max(8,segs(plinth_diam/2)),4);
|
||||||
|
@ -279,8 +279,8 @@ function regular_ngon(n=6, r, d, or, od, ir, id, side, rounding=0, realign=false
|
|||||||
tipp = apply(mat, polar_to_xy(r-inset+rounding,a1)),
|
tipp = apply(mat, polar_to_xy(r-inset+rounding,a1)),
|
||||||
pos = (p1+p2)/2
|
pos = (p1+p2)/2
|
||||||
) each [
|
) each [
|
||||||
anchorpt(str("tip",i), tipp, unit(tipp,BACK), 0),
|
named_anchor(str("tip",i), tipp, unit(tipp,BACK), 0),
|
||||||
anchorpt(str("side",i), pos, unit(pos,BACK), 0),
|
named_anchor(str("side",i), pos, unit(pos,BACK), 0),
|
||||||
]
|
]
|
||||||
]
|
]
|
||||||
) reorient(anchor,spin, two_d=true, path=path, extent=false, p=path, anchors=anchors);
|
) reorient(anchor,spin, two_d=true, path=path, extent=false, p=path, anchors=anchors);
|
||||||
@ -308,8 +308,8 @@ module regular_ngon(n=6, r, d, or, od, ir, id, side, rounding=0, realign=false,
|
|||||||
tipp = apply(mat, polar_to_xy(r-inset+rounding,a1)),
|
tipp = apply(mat, polar_to_xy(r-inset+rounding,a1)),
|
||||||
pos = (p1+p2)/2
|
pos = (p1+p2)/2
|
||||||
) each [
|
) each [
|
||||||
anchorpt(str("tip",i), tipp, unit(tipp,BACK), 0),
|
named_anchor(str("tip",i), tipp, unit(tipp,BACK), 0),
|
||||||
anchorpt(str("side",i), pos, unit(pos,BACK), 0),
|
named_anchor(str("side",i), pos, unit(pos,BACK), 0),
|
||||||
]
|
]
|
||||||
];
|
];
|
||||||
path = regular_ngon(n=n, r=r, rounding=rounding, _mat=mat, _anchs=anchors);
|
path = regular_ngon(n=n, r=r, rounding=rounding, _mat=mat, _anchs=anchors);
|
||||||
@ -694,9 +694,9 @@ function star(n, r, ir, d, or, od, id, step, realign=false, align_tip, align_pit
|
|||||||
p3 = apply(mat, polar_to_xy(r,a3)),
|
p3 = apply(mat, polar_to_xy(r,a3)),
|
||||||
pos = (p1+p3)/2
|
pos = (p1+p3)/2
|
||||||
) each [
|
) each [
|
||||||
anchorpt(str("tip",i), p1, unit(p1,BACK), 0),
|
named_anchor(str("tip",i), p1, unit(p1,BACK), 0),
|
||||||
anchorpt(str("pit",i), p2, unit(p2,BACK), 0),
|
named_anchor(str("pit",i), p2, unit(p2,BACK), 0),
|
||||||
anchorpt(str("midpt",i), pos, unit(pos,BACK), 0),
|
named_anchor(str("midpt",i), pos, unit(pos,BACK), 0),
|
||||||
]
|
]
|
||||||
]
|
]
|
||||||
) reorient(anchor,spin, two_d=true, path=path, p=path, anchors=anchors);
|
) reorient(anchor,spin, two_d=true, path=path, p=path, anchors=anchors);
|
||||||
@ -724,9 +724,9 @@ module star(n, r, ir, d, or, od, id, step, realign=false, align_tip, align_pit,
|
|||||||
p3 = apply(mat, polar_to_xy(r,a3)),
|
p3 = apply(mat, polar_to_xy(r,a3)),
|
||||||
pos = (p1+p3)/2
|
pos = (p1+p3)/2
|
||||||
) each [
|
) each [
|
||||||
anchorpt(str("tip",i), p1, unit(p1,BACK), 0),
|
named_anchor(str("tip",i), p1, unit(p1,BACK), 0),
|
||||||
anchorpt(str("pit",i), p2, unit(p2,BACK), 0),
|
named_anchor(str("pit",i), p2, unit(p2,BACK), 0),
|
||||||
anchorpt(str("midpt",i), pos, unit(pos,BACK), 0),
|
named_anchor(str("midpt",i), pos, unit(pos,BACK), 0),
|
||||||
]
|
]
|
||||||
];
|
];
|
||||||
path = star(n=n, r=r, ir=ir, realign=realign, _mat=mat, _anchs=anchors);
|
path = star(n=n, r=r, ir=ir, realign=realign, _mat=mat, _anchs=anchors);
|
||||||
@ -1007,7 +1007,7 @@ module reuleaux_polygon(N=3, r, d, anchor=CENTER, spin=0) {
|
|||||||
for (i = [0:1:N-1]) let(
|
for (i = [0:1:N-1]) let(
|
||||||
ca = 360 - i * 360/N,
|
ca = 360 - i * 360/N,
|
||||||
cp = polar_to_xy(r, ca)
|
cp = polar_to_xy(r, ca)
|
||||||
) anchorpt(str("tip",i), cp, unit(cp,BACK), 0),
|
) named_anchor(str("tip",i), cp, unit(cp,BACK), 0),
|
||||||
];
|
];
|
||||||
attachable(anchor,spin, two_d=true, path=path, anchors=anchors) {
|
attachable(anchor,spin, two_d=true, path=path, anchors=anchors) {
|
||||||
polygon(path);
|
polygon(path);
|
||||||
@ -1034,7 +1034,7 @@ function reuleaux_polygon(N=3, r, d, anchor=CENTER, spin=0) =
|
|||||||
for (i = [0:1:N-1]) let(
|
for (i = [0:1:N-1]) let(
|
||||||
ca = 360 - i * 360/N,
|
ca = 360 - i * 360/N,
|
||||||
cp = polar_to_xy(r, ca)
|
cp = polar_to_xy(r, ca)
|
||||||
) anchorpt(str("tip",i), cp, unit(cp,BACK), 0),
|
) named_anchor(str("tip",i), cp, unit(cp,BACK), 0),
|
||||||
]
|
]
|
||||||
) reorient(anchor,spin, two_d=true, path=path, anchors=anchors, p=path);
|
) reorient(anchor,spin, two_d=true, path=path, anchors=anchors, p=path);
|
||||||
|
|
||||||
|
@ -1614,9 +1614,9 @@ module teardrop(h, r, ang=45, cap_h, r1, r2, d, d1, d2, cap_h1, cap_h2, l, ancho
|
|||||||
cap_h2 = min(first_defined([cap_h2, cap_h, tip_y2]), tip_y2);
|
cap_h2 = min(first_defined([cap_h2, cap_h, tip_y2]), tip_y2);
|
||||||
capvec = unit([0, cap_h1-cap_h2, l]);
|
capvec = unit([0, cap_h1-cap_h2, l]);
|
||||||
anchors = [
|
anchors = [
|
||||||
anchorpt("cap", [0,0,(cap_h1+cap_h2)/2], capvec),
|
named_anchor("cap", [0,0,(cap_h1+cap_h2)/2], capvec),
|
||||||
anchorpt("cap_fwd", [0,-l/2,cap_h1], unit((capvec+FWD)/2)),
|
named_anchor("cap_fwd", [0,-l/2,cap_h1], unit((capvec+FWD)/2)),
|
||||||
anchorpt("cap_back", [0,+l/2,cap_h2], unit((capvec+BACK)/2), 180),
|
named_anchor("cap_back", [0,+l/2,cap_h2], unit((capvec+BACK)/2), 180),
|
||||||
];
|
];
|
||||||
attachable(anchor,spin,orient, r1=r1, r2=r2, l=l, axis=BACK, anchors=anchors) {
|
attachable(anchor,spin,orient, r1=r1, r2=r2, l=l, axis=BACK, anchors=anchors) {
|
||||||
rot(from=UP,to=FWD) {
|
rot(from=UP,to=FWD) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user