2018-11-12 06:00:07 +00:00
|
|
|
//////////////////////////////////////////////////////////////////////
|
2019-03-23 04:13:18 +00:00
|
|
|
// LibFile: debug.scad
|
|
|
|
// Helpers to make debugging OpenScad code easier.
|
|
|
|
// To use, add the following lines to the beginning of your file:
|
|
|
|
// ```
|
2019-04-19 06:45:46 +00:00
|
|
|
// include <BOSL2/constants.scad>
|
|
|
|
// use <BOSL2/debug.scad>
|
2019-03-23 04:13:18 +00:00
|
|
|
// ```
|
2018-11-12 06:00:07 +00:00
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/*
|
|
|
|
BSD 2-Clause License
|
|
|
|
|
|
|
|
Copyright (c) 2017, Revar Desmera
|
|
|
|
All rights reserved.
|
|
|
|
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
|
|
modification, are permitted provided that the following conditions are met:
|
|
|
|
|
|
|
|
* Redistributions of source code must retain the above copyright notice, this
|
|
|
|
list of conditions and the following disclaimer.
|
|
|
|
|
|
|
|
* Redistributions in binary form must reproduce the above copyright notice,
|
|
|
|
this list of conditions and the following disclaimer in the documentation
|
|
|
|
and/or other materials provided with the distribution.
|
|
|
|
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
|
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
|
|
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
|
|
|
|
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
|
|
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
|
|
|
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
|
|
|
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
include <transforms.scad>
|
|
|
|
include <math.scad>
|
2019-02-03 08:13:21 +00:00
|
|
|
include <paths.scad>
|
2018-11-26 02:36:47 +00:00
|
|
|
include <beziers.scad>
|
2018-11-12 06:00:07 +00:00
|
|
|
|
|
|
|
|
2019-03-23 04:13:18 +00:00
|
|
|
// Section: Debugging Polyhedrons
|
2018-11-24 09:40:36 +00:00
|
|
|
|
|
|
|
|
2019-03-23 04:13:18 +00:00
|
|
|
// Module: debug_vertices()
|
|
|
|
// Description:
|
|
|
|
// 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.
|
|
|
|
// Arguments:
|
2018-11-12 08:47:51 +00:00
|
|
|
// vertices = Array of point vertices.
|
2018-11-26 02:36:47 +00:00
|
|
|
// size = The size of the text used to label the vertices.
|
2018-11-12 08:47:51 +00:00
|
|
|
// disabled = If true, don't draw numbers, and draw children without transparency. Default = false.
|
2018-11-26 02:36:47 +00:00
|
|
|
// Example:
|
2019-03-23 04:13:18 +00:00
|
|
|
// verts = [for (z=[-10,10], y=[-10,10], x=[-10,10]) [x,y,z]];
|
|
|
|
// faces = [[0,1,2], [1,3,2], [0,4,5], [0,5,1], [1,5,7], [1,7,3], [3,7,6], [3,6,2], [2,6,4], [2,4,0], [4,6,7], [4,7,5]];
|
2018-11-26 02:36:47 +00:00
|
|
|
// debug_vertices(vertices=verts, size=2) {
|
|
|
|
// polyhedron(points=verts, faces=faces);
|
|
|
|
// }
|
2018-11-12 06:00:07 +00:00
|
|
|
module debug_vertices(vertices, size=1, disabled=false) {
|
|
|
|
if (!disabled) {
|
|
|
|
echo(vertices=vertices);
|
|
|
|
color("blue") {
|
|
|
|
for (i = [0:len(vertices)-1]) {
|
|
|
|
v = vertices[i];
|
|
|
|
translate(v) {
|
2018-11-26 04:01:12 +00:00
|
|
|
up(size/8) zrot($vpr[2]) xrot(90) {
|
2018-11-12 06:00:07 +00:00
|
|
|
linear_extrude(height=size/10, center=true, convexity=10) {
|
2018-11-26 04:01:12 +00:00
|
|
|
text(text=str(i), size=size, halign="center");
|
2018-11-12 06:00:07 +00:00
|
|
|
}
|
|
|
|
}
|
2018-11-26 04:01:12 +00:00
|
|
|
sphere(size/10);
|
2018-11-12 06:00:07 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($children > 0) {
|
|
|
|
if (!disabled) {
|
2019-03-23 04:13:18 +00:00
|
|
|
color([0.2, 1.0, 0, 0.5]) children();
|
2018-11-12 06:00:07 +00:00
|
|
|
} else {
|
|
|
|
children();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2019-03-23 04:13:18 +00:00
|
|
|
// Module: debug_faces()
|
|
|
|
// Description:
|
|
|
|
// Draws all the vertices at their 3D position, numbered in blue by their
|
|
|
|
// position in the vertex array. Each face will have their face number drawn
|
|
|
|
// in red, aligned with the center of face. All children of this module are drawn
|
|
|
|
// with transparency.
|
|
|
|
// Arguments:
|
2018-11-12 08:47:51 +00:00
|
|
|
// vertices = Array of point vertices.
|
|
|
|
// faces = Array of faces by vertex numbers.
|
2018-11-26 02:36:47 +00:00
|
|
|
// size = The size of the text used to label the faces and vertices.
|
2018-11-12 08:47:51 +00:00
|
|
|
// disabled = If true, don't draw numbers, and draw children without transparency. Default = false.
|
2018-11-26 02:36:47 +00:00
|
|
|
// Example:
|
2019-03-23 04:13:18 +00:00
|
|
|
// verts = [for (z=[-10,10], y=[-10,10], x=[-10,10]) [x,y,z]];
|
|
|
|
// faces = [[0,1,2], [1,3,2], [0,4,5], [0,5,1], [1,5,7], [1,7,3], [3,7,6], [3,6,2], [2,6,4], [2,4,0], [4,6,7], [4,7,5]];
|
2018-11-26 02:36:47 +00:00
|
|
|
// debug_faces(vertices=verts, faces=faces, size=2) {
|
|
|
|
// polyhedron(points=verts, faces=faces);
|
|
|
|
// }
|
2018-11-12 06:00:07 +00:00
|
|
|
module debug_faces(vertices, faces, size=1, disabled=false) {
|
|
|
|
if (!disabled) {
|
|
|
|
vlen = len(vertices);
|
|
|
|
color("red") {
|
|
|
|
for (i = [0:len(faces)-1]) {
|
|
|
|
face = faces[i];
|
|
|
|
if (face[0] < 0 || face[1] < 0 || face[2] < 0 || face[0] >= vlen || face[1] >= vlen || face[2] >= vlen) {
|
|
|
|
echo("BAD FACE: ", vlen=vlen, face=face);
|
|
|
|
} else {
|
|
|
|
v0 = vertices[face[0]];
|
|
|
|
v1 = vertices[face[1]];
|
|
|
|
v2 = vertices[face[2]];
|
|
|
|
c = (v0 + v1 + v2) / 3;
|
|
|
|
dv0 = normalize(v1 - v0);
|
|
|
|
dv1 = normalize(v2 - v0);
|
|
|
|
nrm0 = normalize(cross(dv0, dv1));
|
|
|
|
nrm1 = [0, 0, 1];
|
|
|
|
axis = normalize(cross(nrm0, nrm1));
|
2019-03-25 10:52:09 +00:00
|
|
|
ang = vector_angle(nrm0, nrm1);
|
2018-11-12 06:00:07 +00:00
|
|
|
theta = atan2(nrm0[1], nrm0[0]);
|
|
|
|
translate(c) {
|
|
|
|
rotate(a=180-ang, v=axis) {
|
|
|
|
zrot(theta-90)
|
|
|
|
linear_extrude(height=size/10, center=true, convexity=10) {
|
|
|
|
union() {
|
|
|
|
text(text=str(i), size=size, halign="center");
|
|
|
|
text(text=str("_"), size=size, halign="center");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
debug_vertices(vertices, size=size, disabled=disabled) {
|
|
|
|
children();
|
|
|
|
}
|
|
|
|
if (!disabled) {
|
|
|
|
echo(faces=faces);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2019-03-23 04:13:18 +00:00
|
|
|
// Module: debug_polyhedron()
|
|
|
|
// Description:
|
|
|
|
// A drop-in module to replace `polyhedron()` and help debug vertices and faces.
|
|
|
|
// Draws all the vertices at their 3D position, numbered in blue by their
|
|
|
|
// position in the vertex array. Each face will have their face number drawn
|
|
|
|
// in red, aligned with the center of face. All given faces are drawn with
|
|
|
|
// transparency. All children of this module are drawn with transparency.
|
|
|
|
// Works best with Thrown-Together preview mode, to see reversed faces.
|
|
|
|
// Arguments:
|
2018-11-12 08:47:51 +00:00
|
|
|
// vertices = Array of point vertices.
|
|
|
|
// faces = Array of faces by vertex numbers.
|
2018-11-26 02:36:47 +00:00
|
|
|
// txtsize = The size of the text used to label the faces and vertices.
|
2018-11-12 08:47:51 +00:00
|
|
|
// disabled = If true, act exactly like `polyhedron()`. Default = false.
|
|
|
|
// Example:
|
2019-03-23 04:13:18 +00:00
|
|
|
// verts = [for (z=[-10,10], a=[0:120:359.9]) [10*cos(a),10*sin(a),z]];
|
|
|
|
// faces = [[0,1,2], [5,4,3], [0,3,4], [0,4,1], [1,4,5], [1,5,2], [2,5,3], [2,3,0]];
|
|
|
|
// debug_polyhedron(points=verts, faces=faces, txtsize=1);
|
2018-11-12 06:38:34 +00:00
|
|
|
module debug_polyhedron(points, faces, convexity=10, txtsize=1, disabled=false) {
|
|
|
|
debug_faces(vertices=points, faces=faces, size=txtsize, disabled=disabled) {
|
|
|
|
polyhedron(points=points, faces=faces, convexity=convexity);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-11-12 06:00:07 +00:00
|
|
|
|
2019-04-17 02:16:50 +00:00
|
|
|
// Function: all_conns()
|
|
|
|
// Description:
|
|
|
|
// Return the names for all standard connectors for a region.
|
|
|
|
// Arguments:
|
|
|
|
// type = The type of region to show connectors for. "cube", "cylinder", "sphere"
|
|
|
|
function all_conns(type="cube") =
|
|
|
|
assert(in_list(type,["cube", "cylinder", "sphere"]))
|
|
|
|
let (
|
2019-04-19 06:32:17 +00:00
|
|
|
zs = [TOP, BOTTOM],
|
|
|
|
ys = [FRONT, BACK],
|
|
|
|
xs = [LEFT, RIGHT]
|
2019-04-17 02:16:50 +00:00
|
|
|
) concat(
|
2019-04-19 06:32:17 +00:00
|
|
|
[CENTER],
|
2019-04-17 02:16:50 +00:00
|
|
|
[for (a=concat(xs,ys,zs)) a],
|
2019-04-19 06:32:17 +00:00
|
|
|
in_list(type,["cube","cylinder"])? [for (a=zs, b=ys) a+b] : [],
|
|
|
|
in_list(type,["cube","cylinder"])? [for (a=zs, b=xs) a+b] : [],
|
|
|
|
in_list(type,["cube"])? [for (a=ys, b=xs) a+b] : [],
|
|
|
|
in_list(type,["cube"])? [for (a=zs, b=ys, c=xs) a+b+c] : []
|
2019-04-17 02:16:50 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Module: connector_arrow()
|
|
|
|
// Usage:
|
|
|
|
// connector_arrow([s], [color], [flag]);
|
|
|
|
// Description:
|
|
|
|
// Show a connector orientation arrow.
|
|
|
|
// Arguments:
|
|
|
|
// s = Length of the arrows.
|
|
|
|
// color = Color of the arrow.
|
|
|
|
// flag = If true, draw the orientation flag on the arrowhead.
|
|
|
|
module connector_arrow(s=10, color=[0.333,0.333,1], flag=true) {
|
|
|
|
$fn=12;
|
|
|
|
recolor("gray") spheroid(d=s/6)
|
2019-04-19 06:32:17 +00:00
|
|
|
recolor(color) cyl(h=s*2/3, d=s/15, align=UP)
|
|
|
|
attach(TOP) cyl(h=s/3, d1=s/5, d2=0, align=UP) {
|
2019-04-17 02:16:50 +00:00
|
|
|
if(flag) {
|
2019-04-19 06:32:17 +00:00
|
|
|
attach(BOTTOM) recolor([1,0.5,0.5]) cuboid([s/50, s/6, s/4], align="front-top");
|
2019-04-17 02:16:50 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Module: show_connectors()
|
|
|
|
// Description:
|
|
|
|
// Show all standard connectors for a given region.
|
|
|
|
// Arguments:
|
|
|
|
// type = The type of region to show connectors for. "cube", "cylinder", "sphere"
|
|
|
|
module show_connectors(type="cube") {
|
|
|
|
for (conn=all_conns(type)) {
|
|
|
|
attach(conn) connector_arrow();
|
|
|
|
}
|
|
|
|
children();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Module: frameref()
|
|
|
|
// Description:
|
|
|
|
// Displays X,Y,Z axis arrows in red, green, and blue respectively.
|
|
|
|
// Arguments:
|
|
|
|
// s = Length of the arrows.
|
|
|
|
module frameref(s=15) {
|
|
|
|
sphere(0.001) {
|
2019-04-19 06:32:17 +00:00
|
|
|
attach(RIGHT) connector_arrow(s=s, color="red", flag=false);
|
|
|
|
attach(BACK) connector_arrow(s=s, color="green", flag=false);
|
|
|
|
attach(TOP) connector_arrow(s=s, color="blue", flag=false);
|
2019-04-17 02:16:50 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-11-12 06:00:07 +00:00
|
|
|
// vim: noexpandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap
|