Merge pull request #1423 from adrianVmariano/master

doc fixes
This commit is contained in:
Revar Desmera 2024-05-02 20:27:06 -07:00 committed by GitHub
commit 03a5869c30
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
4 changed files with 78 additions and 70 deletions

View file

@ -581,7 +581,7 @@ module orient(anchor, spin) {
// do the same thing but you would have to figure out the correct child anchor, which is not always obvious. // do the same thing but you would have to figure out the correct child anchor, which is not always obvious.
// . // .
// Because `align()` works by setting the child anchor, it overrides any anchor you specify to the child: // Because `align()` works by setting the child anchor, it overrides any anchor you specify to the child:
// any `anchor=` value given to the child is ignored. // **any `anchor=` value given to the child is ignored.**
// . // .
// Several options can adjust how the child is positioned. You can specify `inset=` to inset the // Several options can adjust how the child is positioned. You can specify `inset=` to inset the
// aligned object from its alignment location. If you set `inside=true` then the // aligned object from its alignment location. If you set `inside=true` then the
@ -648,14 +648,14 @@ module orient(anchor, spin) {
// cyl(h=20,d=10,$fn=128) // cyl(h=20,d=10,$fn=128)
// align([1,.3],TOP) // align([1,.3],TOP)
// color("lightblue")cuboid(5); // color("lightblue")cuboid(5);
// Example: Orienting the child is done in the global coordinate system (as usual) not in the parent coordinate system. Note that the blue prismoid is not lined up with the parent face. (To place the child on the face used {{attach()}}. // Example: Orienting the child is done in the global coordinate system (as usual) not in the parent coordinate system. Note that the blue prismoid is not lined up with the parent face. (To place the child on the face use {{attach()}}.
// prismoid(50,30,25) // prismoid(50,30,25)
// align(RIGHT) // align(RIGHT)
// color("lightblue")prismoid([10,5],[7,4],height=4,orient=RIGHT); // color("lightblue")prismoid([10,5],[7,4],height=4,orient=RIGHT);
// Example: Setting inside=true enables us to subtract the child from the parent with {{diff()}. The "remove" tag is automatically applied when you set `inside=true`, and we used `out=0.01` to prevent z-fighting on the faces. // Example: Setting `inside=true` enables us to subtract the child from the parent with {{diff()}}. The "remove" tag is automatically applied when you set `inside=true`, and we used `shiftout=0.01` to prevent z-fighting on the faces.
// diff() // diff()
// cuboid([40,30,10]) // cuboid([40,30,10])
// align(FRONT,TOP,inside=true,shiftout=.01) // align(FRONT,TOP,inside=true,shiftout=0.01)
// prismoid([10,5],[7,5],height=4); // prismoid([10,5],[7,5],height=4);
// Example: Setting inset shifts all of the children away from their aligned edge, which is a different direction for each child. // Example: Setting inset shifts all of the children away from their aligned edge, which is a different direction for each child.
// cuboid([40,30,30]) // cuboid([40,30,30])

View file

@ -588,7 +588,7 @@ function _inherit_gear_thickness(thickness,dflt=10) =
// the gear resembles a crown. This type of gear is not the same as a bevel gear with vertical teeth, which would mate // the gear resembles a crown. This type of gear is not the same as a bevel gear with vertical teeth, which would mate
// to another bevel gear. A crown gear mates to a spur gear at a ninety degree angle. A feature of the crown gear assembly // to another bevel gear. A crown gear mates to a spur gear at a ninety degree angle. A feature of the crown gear assembly
// is that the spur gear can shift along its axis without affecting the mesh. // is that the spur gear can shift along its axis without affecting the mesh.
// Figure(2D,Med,NoAxes,VPT=[-2.19006,-1.67419,-4.49379],VPR=[67.6,0,131.9],VPD=113.4): A Crown or Face gear with its mating spur gear in blue. // Figure(2D,Med,NoAxes,VPR=[50.1,0,52.5],VPD=121.5,VPT=[8.28415,-8.1257,9.45986]): A Crown or Face gear with its mating spur gear in blue.
// crown_gear(mod=1, teeth=32, backing=3, face_width=7); // crown_gear(mod=1, teeth=32, backing=3, face_width=7);
// color("lightblue") // color("lightblue")
// back(pitch_radius(mod=1,teeth=32)+7/2) // back(pitch_radius(mod=1,teeth=32)+7/2)

View file

@ -3652,7 +3652,8 @@ module cylindrical_heightfield(
// Usage: // Usage:
// ruler(length, width, [thickness=], [depth=], [labels=], [pipscale=], [maxscale=], [colors=], [alpha=], [unit=], [inch=]) [ATTACHMENTS]; // ruler(length, width, [thickness=], [depth=], [labels=], [pipscale=], [maxscale=], [colors=], [alpha=], [unit=], [inch=]) [ATTACHMENTS];
// Description: // Description:
// Creates an attachable ruler for checking dimensions of the model. // Creates an attachable ruler for checking dimensions of the model. The rule appears only in preview mode (F5) and is not displayed
// when the model is rendered (F6).
// Arguments: // Arguments:
// length = length of the ruler. Default 100 // length = length of the ruler. Default 100
// width = width of the ruler. Default: size of the largest unit division // width = width of the ruler. Default: size of the largest unit division
@ -3683,66 +3684,66 @@ module cylindrical_heightfield(
module ruler(length=100, width, thickness=1, depth=3, labels=false, pipscale=1/3, maxscale, module ruler(length=100, width, thickness=1, depth=3, labels=false, pipscale=1/3, maxscale,
colors=["black","white"], alpha=1.0, unit=1, inch=false, anchor=LEFT+BACK+TOP, spin=0, orient=UP) colors=["black","white"], alpha=1.0, unit=1, inch=false, anchor=LEFT+BACK+TOP, spin=0, orient=UP)
{ {
inchfactor = 25.4; if ($preview){
checks = checks =
assert(depth<=5, "Cannot render scales smaller than depth=5") assert(depth<=5, "Cannot render scales smaller than depth=5")
assert(len(colors)==2, "colors must contain a list of exactly two colors."); assert(len(colors)==2, "colors must contain a list of exactly two colors.");
length = inch ? inchfactor * length : length; length = inch ? INCH * length : length;
unit = inch ? inchfactor*unit : unit; unit = inch ? INCH*unit : unit;
maxscale = is_def(maxscale)? maxscale : floor(log(length/unit-EPSILON)); maxscale = is_def(maxscale)? maxscale : floor(log(length/unit-EPSILON));
scales = unit * [for(logsize = [maxscale:-1:maxscale-depth+1]) pow(10,logsize)]; scales = unit * [for(logsize = [maxscale:-1:maxscale-depth+1]) pow(10,logsize)];
widthfactor = (1-pipscale) / (1-pow(pipscale,depth)); widthfactor = (1-pipscale) / (1-pow(pipscale,depth));
width = default(width, scales[0]); width = default(width, scales[0]);
widths = width * widthfactor * [for(logsize = [0:-1:-depth+1]) pow(pipscale,-logsize)]; widths = width * widthfactor * [for(logsize = [0:-1:-depth+1]) pow(pipscale,-logsize)];
offsets = concat([0],cumsum(widths)); offsets = concat([0],cumsum(widths));
attachable(anchor,spin,orient, size=[length,width,thickness]) { attachable(anchor,spin,orient, size=[length,width,thickness]) {
translate([-length/2, -width/2, 0]) translate([-length/2, -width/2, 0])
for(i=[0:1:len(scales)-1]) { for(i=[0:1:len(scales)-1]) {
count = ceil(length/scales[i]); count = ceil(length/scales[i]);
fontsize = 0.5*min(widths[i], scales[i]/ceil(log(count*scales[i]/unit))); fontsize = 0.5*min(widths[i], scales[i]/ceil(log(count*scales[i]/unit)));
back(offsets[i]) { back(offsets[i]) {
xcopies(scales[i], n=count, sp=[0,0,0]) union() { xcopies(scales[i], n=count, sp=[0,0,0]) union() {
actlen = ($idx<count-1) || approx(length%scales[i],0) ? scales[i] : length % scales[i]; actlen = ($idx<count-1) || approx(length%scales[i],0) ? scales[i] : length % scales[i];
color(colors[$idx%2], alpha=alpha) { color(colors[$idx%2], alpha=alpha) {
w = i>0 ? quantup(widths[i],1/1024) : widths[i]; // What is the i>0 test supposed to do here? w = i>0 ? quantup(widths[i],1/1024) : widths[i]; // What is the i>0 test supposed to do here?
cube([quantup(actlen,1/1024),quantup(w,1/1024),thickness], anchor=FRONT+LEFT); cube([quantup(actlen,1/1024),quantup(w,1/1024),thickness], anchor=FRONT+LEFT);
} }
mark = mark =
i == 0 && $idx % 10 == 0 && $idx != 0 ? 0 : i == 0 && $idx % 10 == 0 && $idx != 0 ? 0 :
i == 0 && $idx % 10 == 9 && $idx != count-1 ? 1 : i == 0 && $idx % 10 == 9 && $idx != count-1 ? 1 :
$idx % 10 == 4 ? 1 : $idx % 10 == 4 ? 1 :
$idx % 10 == 5 ? 0 : -1; $idx % 10 == 5 ? 0 : -1;
flip = 1-mark*2; flip = 1-mark*2;
if (mark >= 0) { if (mark >= 0) {
marklength = min(widths[i]/2, scales[i]*2); marklength = min(widths[i]/2, scales[i]*2);
markwidth = marklength*0.4; markwidth = marklength*0.4;
translate([mark*scales[i], widths[i], 0]) { translate([mark*scales[i], widths[i], 0]) {
color(colors[1-$idx%2], alpha=alpha) { color(colors[1-$idx%2], alpha=alpha) {
linear_extrude(height=thickness+scales[i]/100, convexity=2, center=true) {
polygon(scale([flip*markwidth, marklength],p=[[0,0], [1, -1], [0,-0.9]]));
}
}
}
}
if (labels && scales[i]/unit+EPSILON >= 1) {
color(colors[($idx+1)%2], alpha=alpha) {
linear_extrude(height=thickness+scales[i]/100, convexity=2, center=true) { linear_extrude(height=thickness+scales[i]/100, convexity=2, center=true) {
polygon(scale([flip*markwidth, marklength],p=[[0,0], [1, -1], [0,-0.9]])); back(scales[i]*.02) {
text(text=str( $idx * scales[i] / unit), size=fontsize, halign="left", valign="baseline");
}
} }
} }
} }
}
if (labels && scales[i]/unit+EPSILON >= 1) {
color(colors[($idx+1)%2], alpha=alpha) {
linear_extrude(height=thickness+scales[i]/100, convexity=2, center=true) {
back(scales[i]*.02) {
text(text=str( $idx * scales[i] / unit), size=fontsize, halign="left", valign="baseline");
}
}
}
}
}
} }
} }
children();
} }
children();
} }
} }
// vim: expandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap // vim: expandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap

View file

@ -89,7 +89,7 @@ For cylindrical type attachables, the Z component of the vector will be 1, 0,
to the bottom rim, the middle side, or the top rim of the cylindrical or conical shape. to the bottom rim, the middle side, or the top rim of the cylindrical or conical shape.
The X and Y components can be any value, pointing towards the circular perimeter of the cone. The X and Y components can be any value, pointing towards the circular perimeter of the cone.
These combined let you point at any place on the bottom or top rims, or at an arbitrary These combined let you point at any place on the bottom or top rims, or at an arbitrary
side wall: side wall.
```openscad-3D ```openscad-3D
include <BOSL2/std.scad> include <BOSL2/std.scad>
@ -101,16 +101,18 @@ include <BOSL2/std.scad>
cylinder(r1=25, r2=15, h=60, anchor=BOTTOM+FRONT); cylinder(r1=25, r2=15, h=60, anchor=BOTTOM+FRONT);
``` ```
Here we convert a 30 deg angle into an anchor using [cylindrical_to_xyz()](https://github.com/BelfrySCAD/BOSL2/wiki/coords.scad#function-cylindrical_to_xyz)
```openscad-3D ```openscad-3D
include <BOSL2/std.scad> include <BOSL2/std.scad>
cylinder(r1=25, r2=15, h=60, anchor=UP+spherical_to_xyz(1,30,90)); cylinder(r1=25, r2=15, h=60, anchor=cylindrical_to_xyz(1,30,1));
``` ```
--- ---
For Spherical type attachables, you can pass a vector that points at any arbitrary place on For Spherical type attachables, you can pass a vector that points at any arbitrary place on
the surface of the sphere: the surface of the sphere:
p
```openscad-3D ```openscad-3D
include <BOSL2/std.scad> include <BOSL2/std.scad>
sphere(r=50, anchor=TOP); sphere(r=50, anchor=TOP);
@ -121,6 +123,9 @@ include <BOSL2/std.scad>
sphere(r=50, anchor=TOP+FRONT); sphere(r=50, anchor=TOP+FRONT);
``` ```
Here the [spherical_to_xyz()](https://github.com/BelfrySCAD/BOSL2/wiki/coords.scad#function-spherical_to_xyz) function converts spherical coordinates into
a vector you can use as an anchor:
```openscad-3D ```openscad-3D
include <BOSL2/std.scad> include <BOSL2/std.scad>
sphere(r=50, anchor=spherical_to_xyz(1,-30,60)); sphere(r=50, anchor=spherical_to_xyz(1,-30,60));
@ -484,8 +489,9 @@ cuboid([50,40,15])
color("lightblue")cuboid(5,anchor=LEFT); color("lightblue")cuboid(5,anchor=LEFT);
``` ```
Using align(), the determination of the anchor is automatic. Any When you use align() it automatically determines the correct anchor to
anchor you do specify is ignored. use for the child and this anchor overrides any anchor specified to
the child: any anchor you specify for the child is ignored.
```openscad-3D ```openscad-3D
include<BOSL2/std.scad> include<BOSL2/std.scad>
@ -745,13 +751,15 @@ specified in the child: **with parent-child anchor attachment the
`anchor=` and `orient=` parameters to the child are ignored.** `anchor=` and `orient=` parameters to the child are ignored.**
When you specify attachment using a pair of anchors, the attached When you specify attachment using a pair of anchors, the attached
child can spin around the parent anchor while still being attached. child can spin around the parent anchor while still being attached at
As noted earlier, this ambiguity is resolved by anchors having a the designated anchors: specifying the anchors leaves one unspecified
degree of freedom. As noted earlier, this ambiguity is resolved by anchors having a
defined spin which specifies where the Y+ axis is located. defined spin which specifies where the Y+ axis is located.
The way that BOSL2 positions objects can be understood by viewing the The way that BOSL2 positions objects can be understood by viewing the
anchor arrows as shown above, or you can remember these rules: anchor arrows as shown above, or you can remember these rules:
1. When attaching to the TOP or BOTTOM the FRONT of the child points to the front if possible; otherwise the TOP of the child points BACK. 1. When attaching to the TOP or BOTTOM: the FRONT of the child points to the front if possible; otherwise the TOP of the child points BACK.
2. When attaching to other faces, if possible the child's UP anchor will point UP; otherwise, the BACK of the child points up (so the FRONT is pointed down). 2. When attaching to other faces, if possible the child's UP anchor will point UP; otherwise, the BACK of the child points up (so the FRONT is pointed down).
To show how this works we use this prismoid where the blue arrow is To show how this works we use this prismoid where the blue arrow is
pointing to the front and the green arrow points up. Also note that pointing to the front and the green arrow points up. Also note that
the front left edge is the only right angle. the front left edge is the only right angle.
@ -780,11 +788,11 @@ color_this("orange")
If we attach to the RIGHT using the same LEFT side anchor on the If we attach to the RIGHT using the same LEFT side anchor on the
prismoid then we get the result below. Note that the green UP anchor prismoid then we get the result below. Note that the green UP anchor
is pointing (approximately) UP, in accordance with rule 2 from above. is pointing UP, in accordance with rule 2 from above.
```openscad-3D ```openscad-3D
include <BOSL2/std.scad> include <BOSL2/std.scad>
cube(30) attach(TOP,LEFT) cube(30) attach(RIGHT,LEFT)
color_this("orange") color_this("orange")
prismoid([8,8],[6,6],shift=-[1,1],h=8) { prismoid([8,8],[6,6],shift=-[1,1],h=8) {
attach(TOP,BOT) anchor_arrow(color=[0,1,0],s=12); attach(TOP,BOT) anchor_arrow(color=[0,1,0],s=12);
@ -846,8 +854,7 @@ of the parent. Sometimes it's useful to have the child overlap the
parent by translating it into the parent. You can do this with the parent by translating it into the parent. You can do this with the
`overlap=` argument to `attach()`. A positive value will cause the `overlap=` argument to `attach()`. A positive value will cause the
child to overlap the parent, and a negative value will move the child child to overlap the parent, and a negative value will move the child
away from the parent, leaving a small gap, which may be helpful when away from the parent, leaving a small gap. In the first example we use a very large value of
doing differences. In the first example we use a very large value of
overlap so the cube is sunk deeply into the parent. In the second overlap so the cube is sunk deeply into the parent. In the second
example a large negative overlap value raises the child high above the example a large negative overlap value raises the child high above the
parent. parent.
@ -871,7 +878,7 @@ alignment, which works in a similar way to `align()`. You can specify
`align=` to align the attached child to an edge or corner. The `align=` to align the attached child to an edge or corner. The
example below shows five different alignments. example below shows five different alignments.
```openscad-3D ```openscad-3D;Big
include <BOSL2/std.scad> include <BOSL2/std.scad>
module thing(){ module thing(){
color_this("orange") color_this("orange")
@ -1032,8 +1039,8 @@ cuboid(50){
} }
``` ```
Attachment with CENTER anchors can be surprising because the anchors Parent-child Anchor attachment with CENTER anchors can be surprising because the anchors
point upwards, so in the example below, the child's CENTER anchor both point upwards, so in the example below, the child's CENTER anchor
points up, so it is inverted when it is attached to the parent cone. points up, so it is inverted when it is attached to the parent cone.
Note that the anchors are CENTER anchors, so the bases of the anchors are Note that the anchors are CENTER anchors, so the bases of the anchors are
hidden in the middle of the objects. hidden in the middle of the objects.
@ -1056,7 +1063,7 @@ cylinder(d1=30,d2=15,h=25)
The second form of attachment is parent anchor attachment, which just The second form of attachment is parent anchor attachment, which just
uses a single argument. This form of attachment is less useful in uses a single argument. This form of attachment is less useful in
general and does not provide alignment. When you give `attach()` a parent anchor but no child anchor it general and does not provide alignment. When you give `attach()` a parent anchor but no child anchor it
orients the child according to the pafrent anchor direction but then orients the child according to the parent anchor direction but then
simply places the child based on its internally defined anchor at the simply places the child based on its internally defined anchor at the
parent anchor position. For most objects the default anchor is the parent anchor position. For most objects the default anchor is the
CENTER anchor, so objects will appear sunk half-way into the parent. CENTER anchor, so objects will appear sunk half-way into the parent.