mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-04 03:09:45 +00:00
Added debug modules for rendering beziers and polylines.
This commit is contained in:
parent
4c935bf9f2
commit
34dc5ed72e
1 changed files with 39 additions and 0 deletions
39
debug.scad
39
debug.scad
|
@ -34,6 +34,45 @@ include <transforms.scad>
|
|||
include <math.scad>
|
||||
|
||||
|
||||
module trace_polyline(pline, N=1, showpts=false, size=1, color="yellow") {
|
||||
if (showpts) {
|
||||
for (i = [0:len(pline)-1]) {
|
||||
translate(pline[i]) {
|
||||
if (i%N == 0) {
|
||||
color("blue") sphere(d=size*2.5, $fn=8);
|
||||
} else {
|
||||
color("red") {
|
||||
cylinder(d=size/2, h=size*3, center=true, $fn=8);
|
||||
xrot(90) cylinder(d=size/2, h=size*3, center=true, $fn=8);
|
||||
yrot(90) cylinder(d=size/2, h=size*3, center=true, $fn=8);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
for (i = [0:len(pline)-2]) {
|
||||
delta = pline[i+1] - pline[i];
|
||||
dist2d = norm([delta[0], delta[1], 0]);
|
||||
dist3d = norm(delta);
|
||||
theta = atan2(delta[1], delta[0]);
|
||||
phi = atan2(delta[2], dist2d);
|
||||
translate(pline[i]) {
|
||||
rotate([0, -phi, theta]) {
|
||||
yrot(90) {
|
||||
color(color) cylinder(d=size, h=dist3d, center=false, $fn=4);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
module trace_bez(bez, N=3, size=1) {
|
||||
trace_polyline(bez, N=N, showpts=true, size=size/2, color="green");
|
||||
trace_polyline(bezier_polyline(bez, N=N), size=size);
|
||||
}
|
||||
|
||||
|
||||
// Draws all the vertices in an array, at their 3D position, numbered by their
|
||||
// position in the vertex array. Also draws any children of this module with
|
||||
// transparency.
|
||||
|
|
Loading…
Reference in a new issue