mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-01 09:49:45 +00:00
bug fixes
This commit is contained in:
parent
b1ed2d0c6c
commit
b41b90bc2a
1 changed files with 5 additions and 15 deletions
14
beziers.scad
14
beziers.scad
|
@ -1192,7 +1192,7 @@ function bezier_vnf(patches=[], splinesteps=16, style="default") =
|
||||||
// color("red")move_copies(flatten(patch)) sphere(r=0.3,$fn=9);
|
// color("red")move_copies(flatten(patch)) sphere(r=0.3,$fn=9);
|
||||||
function bezier_vnf_degenerate_patch(patch, splinesteps=16, reverse=false, return_edges=false) =
|
function bezier_vnf_degenerate_patch(patch, splinesteps=16, reverse=false, return_edges=false) =
|
||||||
!return_edges ? bezier_vnf_degenerate_patch(patch, splinesteps, reverse, true)[0] :
|
!return_edges ? bezier_vnf_degenerate_patch(patch, splinesteps, reverse, true)[0] :
|
||||||
assert(_is_rectpatch(patch), "Must supply rectangular bezier patch")
|
assert(is_bezier_patch(patch), "Input is not a Bezier patch")
|
||||||
assert(is_int(splinesteps) && splinesteps>0, "splinesteps must be a positive integer")
|
assert(is_int(splinesteps) && splinesteps>0, "splinesteps must be a positive integer")
|
||||||
let(
|
let(
|
||||||
row_degen = [for(row=patch) all_equal(row)],
|
row_degen = [for(row=patch) all_equal(row)],
|
||||||
|
@ -1379,21 +1379,11 @@ module debug_bezier_patches(patches=[], size, splinesteps=16, showcps=true, show
|
||||||
max(bounds[1]-bounds[0])*0.01;
|
max(bounds[1]-bounds[0])*0.01;
|
||||||
if (showcps) {
|
if (showcps) {
|
||||||
move_copies(flatten(patch)) color("red") sphere(d=size*2);
|
move_copies(flatten(patch)) color("red") sphere(d=size*2);
|
||||||
color("cyan") {
|
color("cyan")
|
||||||
if (_is_tripatch(patch)) {
|
|
||||||
for (i=[0:1:len(patch)-2], j=[0:1:len(patch[i])-2]) {
|
|
||||||
extrude_from_to(patch[i][j], patch[i+1][j]) circle(d=size);
|
|
||||||
extrude_from_to(patch[i][j], patch[i][j+1]) circle(d=size);
|
|
||||||
extrude_from_to(patch[i+1][j], patch[i][j+1]) circle(d=size);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
for (i=[0:1:len(patch)-1], j=[0:1:len(patch[i])-1]) {
|
for (i=[0:1:len(patch)-1], j=[0:1:len(patch[i])-1]) {
|
||||||
if (i<len(patch)-1) extrude_from_to(patch[i][j], patch[i+1][j]) circle(d=size);
|
if (i<len(patch)-1) extrude_from_to(patch[i][j], patch[i+1][j]) circle(d=size);
|
||||||
if (j<len(patch[i])-1) extrude_from_to(patch[i][j], patch[i][j+1]) circle(d=size);
|
if (j<len(patch[i])-1) extrude_from_to(patch[i][j], patch[i][j+1]) circle(d=size);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (showpatch || showdots){
|
if (showpatch || showdots){
|
||||||
vnf = bezier_vnf(patch, splinesteps=splinesteps, style=style);
|
vnf = bezier_vnf(patch, splinesteps=splinesteps, style=style);
|
||||||
if (showpatch) vnf_polyhedron(vnf, convexity=convexity);
|
if (showpatch) vnf_polyhedron(vnf, convexity=convexity);
|
||||||
|
|
Loading…
Reference in a new issue