2019-02-11 18:24:41 -08:00
|
|
|
//////////////////////////////////////////////////////////////////////
|
2019-03-22 21:13:18 -07:00
|
|
|
// LibFile: constants.scad
|
|
|
|
// Useful Constants.
|
2021-01-05 01:20:01 -08:00
|
|
|
// Includes:
|
2019-04-19 00:25:10 -07:00
|
|
|
// include <BOSL2/std.scad>
|
2019-02-11 18:24:41 -08:00
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
2019-03-22 21:13:18 -07:00
|
|
|
// Section: General Constants
|
|
|
|
|
2019-07-17 18:57:23 -07:00
|
|
|
// Constant: $slop
|
|
|
|
// Description:
|
2021-02-22 18:54:46 -08:00
|
|
|
// A number of printers, particularly FDM/FFF printers, tend to be a bit sloppy in their printing.
|
|
|
|
// This has made it so that some parts won't fit together without adding a bit of extra slop space.
|
|
|
|
// That is what the `$slop` value is for. The value for this will vary from printer to printer.
|
|
|
|
// By default, we use a value of 0.00 so that parts should fit exactly for resin and other precision
|
|
|
|
// printers. This value is measured in millimeters. When making your own parts, you should add
|
|
|
|
// `$slop` to both sides of a hole that another part is to fit snugly into. For a loose fit, add
|
|
|
|
// `2*$slop` to each side. This should be done for both X and Y axes. The Z axis will require a
|
|
|
|
// slop that depends on your layer height and bridging settings, and hole sizes. We leave that as
|
|
|
|
// a more complicated exercise for the user.
|
|
|
|
// DefineHeader(NumList): Calibration
|
|
|
|
// Calibration: To calibrate the `$slop` value for your printer, follow this procedure:
|
|
|
|
// Print the Slop Calibration part from the example below.
|
|
|
|
// Take the long block and orient it so the numbers are upright, facing you.
|
|
|
|
// Take the plug and orient it so that the arrow points down, facing you.
|
|
|
|
// Starting with the hole with the largest number in front of it, insert the small end of the plug into the hole.
|
|
|
|
// If you can insert and remove the small end of the plug from the hole without much force, then try again with the hole with the next smaller number.
|
|
|
|
// Repeat step 5 until you have found the hole with the smallest number that the plug fits into without much force.
|
|
|
|
// The correct hole should hold the plug when the long block is turned upside-down.
|
|
|
|
// The number in front of that hole will indicate the `$slop` value that is ideal for your printer.
|
|
|
|
// Remember to set that slop value in your scripts after you include the BOSL2 library: ie: `$slop = 0.15;`
|
|
|
|
// Example: Slop Calibration Part.
|
|
|
|
// min_slop = 0.00;
|
|
|
|
// slop_step = 0.05;
|
|
|
|
// holes = 8;
|
|
|
|
// holesize = [15,15,15];
|
|
|
|
// height = 20;
|
|
|
|
// gap = 5;
|
|
|
|
// l = holes * (holesize.x + gap) + gap;
|
|
|
|
// w = holesize.y + 2*gap;
|
|
|
|
// h = holesize.z + 5;
|
|
|
|
// diff("holes")
|
|
|
|
// cuboid([l, w, h], anchor=BOT) {
|
|
|
|
// for (i=[0:holes-1]) {
|
|
|
|
// right((i-holes/2+0.5)*(holesize.x+gap)) {
|
|
|
|
// s = min_slop + slop_step * i;
|
|
|
|
// tags("holes") {
|
|
|
|
// cuboid([holesize.x + 2*s, holesize.y + 2*s, h+0.2]);
|
|
|
|
// fwd(w/2-1) xrot(90) linear_extrude(1.1) {
|
|
|
|
// text(
|
|
|
|
// text=fmt_fixed(s,2),
|
|
|
|
// size=0.4*holesize.x,
|
|
|
|
// halign="center",
|
|
|
|
// valign="center",
|
|
|
|
// font="Helvetica"
|
|
|
|
// );
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// back(holesize.y*2.5) {
|
|
|
|
// difference() {
|
|
|
|
// union() {
|
|
|
|
// cuboid([holesize.x+10, holesize.y+10, 15], anchor=BOT);
|
|
|
|
// cuboid([holesize.x, holesize.y, 15+holesize.z], anchor=BOT);
|
|
|
|
// }
|
|
|
|
// up(3) fwd((holesize.y+10)/2) {
|
|
|
|
// prismoid([holesize.x/2,1], [0,1], h=holesize.y-6);
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// Example(2D): Where to add `$slop` gaps.
|
|
|
|
// $slop = 0.2;
|
|
|
|
// difference() {
|
|
|
|
// square([20,12],center=true);
|
|
|
|
// back(3) square([10+2*$slop,11],center=true);
|
|
|
|
// }
|
|
|
|
// back(8) {
|
|
|
|
// rect([15,5],anchor=FWD);
|
|
|
|
// rect([10,8],anchor=BACK);
|
|
|
|
// }
|
|
|
|
// color("#000") {
|
|
|
|
// xflip_copy()
|
|
|
|
// stroke([[5.1,6.1], [6.0,7.1], [8,7.1], [10.5,10]], width=0.3, endcap1="arrow2", endcap2="butt");
|
|
|
|
// xcopies(21) back(10.5) {
|
|
|
|
// back(1.2) text("$slop", size=1, halign="center");
|
|
|
|
// text("gap", size=1, halign="center");
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
$slop = 0.0;
|
2019-03-22 21:13:18 -07:00
|
|
|
|
|
|
|
|
2021-02-06 22:36:16 -08:00
|
|
|
// Constant: INCH
|
|
|
|
// Description:
|
|
|
|
// The number of millimeters in an inch.
|
|
|
|
INCH = 25.4;
|
|
|
|
|
|
|
|
|
2019-03-22 21:13:18 -07:00
|
|
|
|
|
|
|
// Section: Directional Vectors
|
2019-04-22 20:55:03 -07:00
|
|
|
// Vectors useful for `rotate()`, `mirror()`, and `anchor` arguments for `cuboid()`, `cyl()`, etc.
|
2019-03-22 21:13:18 -07:00
|
|
|
|
2019-04-18 23:32:17 -07:00
|
|
|
// Constant: LEFT
|
2019-03-22 21:13:18 -07:00
|
|
|
// Description: Vector pointing left. [-1,0,0]
|
2019-04-22 20:55:03 -07:00
|
|
|
// Example(3D): Usage with `anchor`
|
|
|
|
// cuboid(20, anchor=LEFT);
|
2019-04-18 23:32:17 -07:00
|
|
|
LEFT = [-1, 0, 0];
|
2019-03-22 21:13:18 -07:00
|
|
|
|
2019-04-18 23:32:17 -07:00
|
|
|
// Constant: RIGHT
|
2019-03-22 21:13:18 -07:00
|
|
|
// Description: Vector pointing right. [1,0,0]
|
2019-04-22 20:55:03 -07:00
|
|
|
// Example(3D): Usage with `anchor`
|
|
|
|
// cuboid(20, anchor=RIGHT);
|
2019-04-18 23:32:17 -07:00
|
|
|
RIGHT = [ 1, 0, 0];
|
2019-03-22 21:13:18 -07:00
|
|
|
|
2019-05-07 22:42:44 -07:00
|
|
|
// Constant: FRONT
|
2019-03-22 21:13:18 -07:00
|
|
|
// Description: Vector pointing forward. [0,-1,0]
|
2019-04-22 20:55:03 -07:00
|
|
|
// Example(3D): Usage with `anchor`
|
2019-05-07 22:42:44 -07:00
|
|
|
// cuboid(20, anchor=FRONT);
|
|
|
|
FRONT = [ 0, -1, 0];
|
2019-03-22 21:13:18 -07:00
|
|
|
|
2019-04-18 23:32:17 -07:00
|
|
|
// Constant: BACK
|
2019-03-22 21:13:18 -07:00
|
|
|
// Description: Vector pointing back. [0,1,0]
|
2019-04-22 20:55:03 -07:00
|
|
|
// Example(3D): Usage with `anchor`
|
|
|
|
// cuboid(20, anchor=BACK);
|
2019-04-18 23:32:17 -07:00
|
|
|
BACK = [ 0, 1, 0];
|
2019-03-22 21:13:18 -07:00
|
|
|
|
2019-05-07 22:42:44 -07:00
|
|
|
// Constant: BOTTOM
|
2019-03-22 21:13:18 -07:00
|
|
|
// Description: Vector pointing down. [0,0,-1]
|
2019-04-22 20:55:03 -07:00
|
|
|
// Example(3D): Usage with `anchor`
|
2019-05-07 22:42:44 -07:00
|
|
|
// cuboid(20, anchor=BOTTOM);
|
|
|
|
BOTTOM = [ 0, 0, -1];
|
2019-03-22 21:13:18 -07:00
|
|
|
|
2019-05-07 22:42:44 -07:00
|
|
|
// Constant: TOP
|
2019-03-22 21:13:18 -07:00
|
|
|
// Description: Vector pointing up. [0,0,1]
|
2019-04-22 20:55:03 -07:00
|
|
|
// Example(3D): Usage with `anchor`
|
2019-05-07 22:42:44 -07:00
|
|
|
// cuboid(20, anchor=TOP);
|
|
|
|
TOP = [ 0, 0, 1];
|
2019-02-27 03:46:40 -08:00
|
|
|
|
2019-04-18 23:32:17 -07:00
|
|
|
// Constant: ALLPOS
|
2019-03-22 21:13:18 -07:00
|
|
|
// Description: Vector pointing right, back, and up. [1,1,1]
|
2019-04-22 20:55:03 -07:00
|
|
|
// Example(3D): Usage with `anchor`
|
2019-05-10 04:02:58 -07:00
|
|
|
// cuboid(20, anchor=ALLPOS);
|
2019-04-18 23:32:17 -07:00
|
|
|
ALLPOS = [ 1, 1, 1]; // Vector pointing X+,Y+,Z+.
|
2019-03-22 21:13:18 -07:00
|
|
|
|
2019-04-18 23:32:17 -07:00
|
|
|
// Constant: ALLNEG
|
2019-03-22 21:13:18 -07:00
|
|
|
// Description: Vector pointing left, forwards, and down. [-1,-1,-1]
|
2019-04-22 20:55:03 -07:00
|
|
|
// Example(3D): Usage with `anchor`
|
2019-05-10 04:02:58 -07:00
|
|
|
// cuboid(20, anchor=ALLNEG);
|
2019-04-18 23:32:17 -07:00
|
|
|
ALLNEG = [-1, -1, -1]; // Vector pointing X-,Y-,Z-.
|
2019-03-22 21:13:18 -07:00
|
|
|
|
2019-04-18 23:32:17 -07:00
|
|
|
// Constant: CENTER
|
2019-03-22 21:13:18 -07:00
|
|
|
// Description: Zero vector. Centered. [0,0,0]
|
2019-04-22 20:55:03 -07:00
|
|
|
// Example(3D): Usage with `anchor`
|
2019-05-10 04:02:58 -07:00
|
|
|
// cuboid(20, anchor=CENTER);
|
2019-04-18 23:32:17 -07:00
|
|
|
CENTER = [ 0, 0, 0]; // Centered zero vector.
|
2019-03-22 21:13:18 -07:00
|
|
|
|
|
|
|
|
|
|
|
// Section: Vector Aliases
|
2019-04-22 20:55:03 -07:00
|
|
|
// Useful aliases for use with `anchor`.
|
2019-03-22 21:13:18 -07:00
|
|
|
|
2021-02-19 19:56:43 -08:00
|
|
|
// Constant: CTR
|
|
|
|
// Description: Zero vector. Centered. `[0,0,0]`. Alias to `CENTER`.
|
|
|
|
// Example(3D): Usage with `anchor`
|
|
|
|
// cuboid(20, anchor=CTR);
|
|
|
|
CTR = CENTER;
|
|
|
|
|
|
|
|
// Constant: UP
|
|
|
|
// Description: Vector pointing up. [0,0,1] Alias to `TOP`.
|
|
|
|
// Example(3D): Usage with `anchor`
|
|
|
|
// cuboid(20, anchor=UP);
|
2019-05-07 22:42:44 -07:00
|
|
|
UP = TOP; // Vector pointing up, alias to `TOP`.
|
2021-02-19 19:56:43 -08:00
|
|
|
|
|
|
|
// Constant: DOWN
|
|
|
|
// Description: Vector pointing down. [0,0,-1] Alias to `BOTTOM`.
|
|
|
|
// Example(3D): Usage with `anchor`
|
|
|
|
// cuboid(20, anchor=DOWN);
|
2019-05-07 22:42:44 -07:00
|
|
|
DOWN = BOTTOM; // Vector pointing down, alias to `BOTTOM`.
|
2019-04-18 23:32:17 -07:00
|
|
|
|
2021-02-19 19:56:43 -08:00
|
|
|
// Constant: BTM
|
|
|
|
// Description: Vector pointing down. [0,0,-1] Alias to `BOTTOM`.
|
|
|
|
// Example(3D): Usage with `anchor`
|
|
|
|
// cuboid(20, anchor=BTM);
|
|
|
|
BTM = BOTTOM; // Vector pointing down, alias to `BOTTOM`.
|
2019-02-16 00:55:35 -08:00
|
|
|
|
2021-02-19 19:56:43 -08:00
|
|
|
// Constant: BOT
|
|
|
|
// Description: Vector pointing down. [0,0,-1] Alias to `BOTTOM`.
|
|
|
|
// Example(3D): Usage with `anchor`
|
|
|
|
// cuboid(20, anchor=BOT);
|
|
|
|
BOT = BOTTOM; // Vector pointing down, alias to `BOTTOM`.
|
2019-02-16 00:55:35 -08:00
|
|
|
|
2021-02-19 19:56:43 -08:00
|
|
|
// Constant: FWD
|
|
|
|
// Description: Vector pointing forward. [0,-1,0] Alias to `FRONT`.
|
|
|
|
// Example(3D): Usage with `anchor`
|
|
|
|
// cuboid(20, anchor=FWD);
|
|
|
|
FWD = FRONT; // Vector pointing forward, alias to `FRONT`.
|
2019-02-16 00:55:35 -08:00
|
|
|
|
2021-02-19 19:56:43 -08:00
|
|
|
// Constant: FORWARD
|
|
|
|
// Description: Vector pointing forward. [0,-1,0] Alias to `FRONT`.
|
|
|
|
// Example(3D): Usage with `anchor`
|
|
|
|
// cuboid(20, anchor=FORWARD);
|
|
|
|
FORWARD = FRONT; // Vector pointing forward, alias to `FRONT`.
|
2019-02-16 00:55:35 -08:00
|
|
|
|
2019-03-22 21:13:18 -07:00
|
|
|
|
2020-05-29 19:04:34 -07:00
|
|
|
// vim: expandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap
|