mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-01 09:49:45 +00:00
Merge branch 'master' into master
This commit is contained in:
commit
8a16c0d826
3 changed files with 32 additions and 7 deletions
|
@ -776,7 +776,6 @@ function group_sort(list, idx) =
|
||||||
// Usage:
|
// Usage:
|
||||||
// groupings = group_data(groups, values);
|
// groupings = group_data(groups, values);
|
||||||
// Topics: List Handling
|
// Topics: List Handling
|
||||||
// See Also: zip()
|
|
||||||
// Description:
|
// Description:
|
||||||
// Given a list of integer group numbers, and an equal-length list of values,
|
// Given a list of integer group numbers, and an equal-length list of values,
|
||||||
// returns a list of groups with the values sorted into the corresponding groups.
|
// returns a list of groups with the values sorted into the corresponding groups.
|
||||||
|
|
30
drawing.scad
30
drawing.scad
|
@ -156,6 +156,8 @@ function stroke(
|
||||||
trim, trim1, trim2,
|
trim, trim1, trim2,
|
||||||
convexity=10, hull=true
|
convexity=10, hull=true
|
||||||
) = no_function("stroke");
|
) = no_function("stroke");
|
||||||
|
|
||||||
|
|
||||||
module stroke(
|
module stroke(
|
||||||
path, width=1, closed,
|
path, width=1, closed,
|
||||||
endcaps, endcap1, endcap2, joints, dots,
|
endcaps, endcap1, endcap2, joints, dots,
|
||||||
|
@ -297,9 +299,33 @@ module stroke(
|
||||||
|
|
||||||
if (len(path) == 1) {
|
if (len(path) == 1) {
|
||||||
if (len(path[0]) == 2) {
|
if (len(path[0]) == 2) {
|
||||||
translate(path[0]) circle(d=width[0]);
|
// Endcap1
|
||||||
|
setcolor(endcap_color1) {
|
||||||
|
translate(path[0]) {
|
||||||
|
mat = is_undef(endcap_angle1)? ident(3) : zrot(endcap_angle1);
|
||||||
|
multmatrix(mat) polygon(endcap_shape1);
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
translate(path[0]) sphere(d=width[0]);
|
// Endcap1
|
||||||
|
setcolor(endcap_color1) {
|
||||||
|
translate(path[0]) {
|
||||||
|
$fn = segs(width[0]/2);
|
||||||
|
if (is_undef(endcap_angle1)) {
|
||||||
|
rotate_extrude(convexity=convexity) {
|
||||||
|
right_half(planar=true) {
|
||||||
|
polygon(endcap_shape1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
rotate([90,0,endcap_angle1]) {
|
||||||
|
linear_extrude(height=max(widths[0],0.001), center=true, convexity=convexity) {
|
||||||
|
polygon(endcap_shape1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
dummy=assert(trim1<path_length(path)-trim2, "Path is too short for endcap(s). Try a smaller width, or set endcap_length to a smaller value.");
|
dummy=assert(trim1<path_length(path)-trim2, "Path is too short for endcap(s). Try a smaller width, or set endcap_length to a smaller value.");
|
||||||
|
|
|
@ -137,7 +137,7 @@ hexagon(d=50, anchor=LEFT);
|
||||||
```
|
```
|
||||||
|
|
||||||
```openscad-2D
|
```openscad-2D
|
||||||
oval(d=[50,30], anchor=FRONT);
|
ellipse(d=[50,30], anchor=FRONT);
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
|
@ -166,7 +166,7 @@ square([40,30], spin=30);
|
||||||
```
|
```
|
||||||
|
|
||||||
```openscad-2D
|
```openscad-2D
|
||||||
oval(d=[40,30], spin=30);
|
ellipse(d=[40,30], spin=30);
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
|
@ -821,10 +821,10 @@ module ovalish(l,rx1,ry1,rx2,ry2, anchor=CENTER, spin=0, orient=UP) {
|
||||||
hull() {
|
hull() {
|
||||||
up(l/2-0.005)
|
up(l/2-0.005)
|
||||||
linear_extrude(height=0.01, center=true)
|
linear_extrude(height=0.01, center=true)
|
||||||
oval([rx2,ry2]);
|
ellipse([rx2,ry2]);
|
||||||
down(l/2-0.005)
|
down(l/2-0.005)
|
||||||
linear_extrude(height=0.01, center=true)
|
linear_extrude(height=0.01, center=true)
|
||||||
oval([rx1,ry1]);
|
ellipse([rx1,ry1]);
|
||||||
}
|
}
|
||||||
children();
|
children();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue