mirror of
https://github.com/nophead/NopSCADlib.git
synced 2025-09-20 12:12:36 +02:00
Compare commits
11 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
a40a2190dc | ||
|
6556d14a11 | ||
|
c7d12b20c9 | ||
|
545329b875 | ||
|
760e3a890d | ||
|
16c1eeef27 | ||
|
800bb89921 | ||
|
41a0723362 | ||
|
6b8ea9685e | ||
|
0cf8cb7d28 | ||
|
7c439a687f |
15
readme.md
15
readme.md
@@ -1687,6 +1687,13 @@ Cylindrical and ring magnets.
|
|||||||
|
|
||||||

|

|
||||||
|
|
||||||
|
### Vitamins
|
||||||
|
| Qty | Module call | BOM entry |
|
||||||
|
| ---:|:--- |:---|
|
||||||
|
| 1 | `magnet(MAG484)` | Magnet 6.35mm diameter, 6.35mm high, 3.175mm bore |
|
||||||
|
| 1 | `magnet(MAG8x4x4p2)` | Magnet 8mm diameter, 4mm high, 4.2mm bore |
|
||||||
|
| 1 | `magnet(MAG5x8)` | Magnet 8mm diameter, 5mm high |
|
||||||
|
|
||||||
|
|
||||||
<a href="#top">Top</a>
|
<a href="#top">Top</a>
|
||||||
|
|
||||||
@@ -1771,6 +1778,7 @@ Used for limit switches.
|
|||||||
|:--- |:--- |
|
|:--- |:--- |
|
||||||
| `microswitch_lower_extent(type)` | How far legs extend downwards |
|
| `microswitch_lower_extent(type)` | How far legs extend downwards |
|
||||||
| `microswitch_right_extent(type)` | How far legs extend right |
|
| `microswitch_right_extent(type)` | How far legs extend right |
|
||||||
|
| `microswitch_size(type)` | Body size |
|
||||||
|
|
||||||
### Modules
|
### Modules
|
||||||
| Module | Description |
|
| Module | Description |
|
||||||
@@ -2673,7 +2681,7 @@ Linear rails with carriages.
|
|||||||
| `rail(type, length)` | Draw the specified rail |
|
| `rail(type, length)` | Draw the specified rail |
|
||||||
| `rail_assembly(type, length, pos, carriage_end_colour = grey(20)` | Rail and carriage assembly |
|
| `rail_assembly(type, length, pos, carriage_end_colour = grey(20)` | Rail and carriage assembly |
|
||||||
| `rail_hole_positions(type, length, first = 0, screws = 100, both_ends = true)` | Position children over screw holes |
|
| `rail_hole_positions(type, length, first = 0, screws = 100, both_ends = true)` | Position children over screw holes |
|
||||||
| `rail_screws(type, length, thickness, screws = 100)` | Place screws in the rail |
|
| `rail_screws(type, length, thickness, screws = 100, index_screws = undef)` | Place screws in the rail |
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
@@ -3768,6 +3776,7 @@ Veroboard with mounting holes, track breaks, removed tracks, solder points and c
|
|||||||
| Function | Description |
|
| Function | Description |
|
||||||
|:--- |:--- |
|
|:--- |:--- |
|
||||||
| `vero_length(type)` | Length of the board |
|
| `vero_length(type)` | Length of the board |
|
||||||
|
| `vero_size(type)` | Board size |
|
||||||
| `vero_thickness(type)` | Thickness of the substrate |
|
| `vero_thickness(type)` | Thickness of the substrate |
|
||||||
| `vero_track_thickness(type)` | Thickness of the tracks |
|
| `vero_track_thickness(type)` | Thickness of the tracks |
|
||||||
| `vero_track_width(type)` | The width of the tracks |
|
| `vero_track_width(type)` | The width of the tracks |
|
||||||
@@ -5728,7 +5737,8 @@ Cylinder with a rounded end.
|
|||||||
---
|
---
|
||||||
<a name="Rounded_polygon"></a>
|
<a name="Rounded_polygon"></a>
|
||||||
## Rounded_polygon
|
## Rounded_polygon
|
||||||
Draw a polygon with rounded corners. Each element of the vector is the XY coordinate and a radius. Radius can be negative for a concave corner.
|
Draw a polygon with rounded corners. Each element of the vector is the XY coordinate and a radius in clockwise order.
|
||||||
|
Radius can be negative for a concave corner.
|
||||||
|
|
||||||
Because the tangents need to be calculated to find the length these can be calculated separately and re-used when drawing to save calculating them twice.
|
Because the tangents need to be calculated to find the length these can be calculated separately and re-used when drawing to save calculating them twice.
|
||||||
|
|
||||||
@@ -5739,6 +5749,7 @@ Because the tangents need to be calculated to find the length these can be calcu
|
|||||||
### Functions
|
### Functions
|
||||||
| Function | Description |
|
| Function | Description |
|
||||||
|:--- |:--- |
|
|:--- |:--- |
|
||||||
|
| `circle_tangent(p1, p2)` | Compute the clockwise tangent between two circles represented as [x,y,r] |
|
||||||
| `rounded_polygon_length(points, tangents)` | Calculate the length given the point list and the list of tangents computed by ` rounded_polygon_tangents` |
|
| `rounded_polygon_length(points, tangents)` | Calculate the length given the point list and the list of tangents computed by ` rounded_polygon_tangents` |
|
||||||
| `rounded_polygon_tangents(points)` | Compute the straight sections needed to draw and to compute the lengths |
|
| `rounded_polygon_tangents(points)` | Compute the straight sections needed to draw and to compute the lengths |
|
||||||
|
|
||||||
|
@@ -25,7 +25,7 @@ from __future__ import print_function
|
|||||||
import subprocess, sys
|
import subprocess, sys
|
||||||
|
|
||||||
def run_list(args, silent = False, verbose = False):
|
def run_list(args, silent = False, verbose = False):
|
||||||
cmd = ["openscad.exe"] + args
|
cmd = ["openscad"] + args
|
||||||
if not silent:
|
if not silent:
|
||||||
for arg in cmd:
|
for arg in cmd:
|
||||||
print(arg, end=" ")
|
print(arg, end=" ")
|
||||||
|
@@ -18,13 +18,14 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
//
|
//
|
||||||
//! Draw a polygon with rounded corners. Each element of the vector is the XY coordinate and a radius. Radius can be negative for a concave corner.
|
//! Draw a polygon with rounded corners. Each element of the vector is the XY coordinate and a radius in clockwise order.
|
||||||
|
//! Radius can be negative for a concave corner.
|
||||||
//!
|
//!
|
||||||
//! Because the tangents need to be calculated to find the length these can be calculated separately and re-used when drawing to save calculating them twice.
|
//! Because the tangents need to be calculated to find the length these can be calculated separately and re-used when drawing to save calculating them twice.
|
||||||
//
|
//
|
||||||
include <../utils/core/core.scad>
|
include <../utils/core/core.scad>
|
||||||
|
|
||||||
function circle_tangent(p1, p2) =
|
function circle_tangent(p1, p2) = //! Compute the clockwise tangent between two circles represented as [x,y,r]
|
||||||
let(
|
let(
|
||||||
r1 = p1[2],
|
r1 = p1[2],
|
||||||
r2 = p2[2],
|
r2 = p2[2],
|
||||||
@@ -32,11 +33,8 @@ function circle_tangent(p1, p2) =
|
|||||||
dy = p2.y - p1.y,
|
dy = p2.y - p1.y,
|
||||||
d = sqrt(dx * dx + dy * dy),
|
d = sqrt(dx * dx + dy * dy),
|
||||||
theta = atan2(dy, dx) + acos((r1 - r2) / d),
|
theta = atan2(dy, dx) + acos((r1 - r2) / d),
|
||||||
xa = p1.x +(cos(theta) * r1),
|
v = [cos(theta), sin(theta)]
|
||||||
ya = p1.y +(sin(theta) * r1),
|
)[ p1 + r1 * v, p2 + r2 * v ];
|
||||||
xb = p2.x +(cos(theta) * r2),
|
|
||||||
yb = p2.y +(sin(theta) * r2)
|
|
||||||
)[ [xa, ya], [xb, yb] ];
|
|
||||||
|
|
||||||
function rounded_polygon_tangents(points) = //! Compute the straight sections needed to draw and to compute the lengths
|
function rounded_polygon_tangents(points) = //! Compute the straight sections needed to draw and to compute the lengths
|
||||||
let(len = len(points))
|
let(len = len(points))
|
||||||
|
@@ -34,15 +34,16 @@ hygrometer_hole_r = 21.3;
|
|||||||
slot_w = 5.5;
|
slot_w = 5.5;
|
||||||
|
|
||||||
module hygrometer_hole(h = 0) { //! Drill the hole for a hygrometer
|
module hygrometer_hole(h = 0) { //! Drill the hole for a hygrometer
|
||||||
round(cnc_bit_r) {
|
extrude_if(h)
|
||||||
intersection() {
|
round(cnc_bit_r) {
|
||||||
drill(hygrometer_hole_r, h);
|
intersection() {
|
||||||
|
drill(hygrometer_hole_r, 0);
|
||||||
|
|
||||||
rotate(30)
|
rotate(30)
|
||||||
square([slot_w + 2 * cnc_bit_r, 100], center = true);
|
square([slot_w + 2 * cnc_bit_r, 100], center = true);
|
||||||
|
}
|
||||||
|
drill((od + 0.2) / 2, 0);
|
||||||
}
|
}
|
||||||
drill((od + 0.2) / 2, h);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function hygrometer_or() = flange_d / 2; //! The outside radius of a hygrometer
|
function hygrometer_or() = flange_d / 2; //! The outside radius of a hygrometer
|
||||||
@@ -54,13 +55,13 @@ module hygrometer() { //! Draw a hygrometer
|
|||||||
color(grey(30))
|
color(grey(30))
|
||||||
rotate_extrude()
|
rotate_extrude()
|
||||||
polygon([
|
polygon([
|
||||||
[0, 0],
|
[0, 0],
|
||||||
[aperture_d / 2, 0],
|
[aperture_d / 2, 0],
|
||||||
[aperture_d / 2, flange_t],
|
[aperture_d / 2, flange_t],
|
||||||
[flange_d2 / 2, flange_t2],
|
[flange_d2 / 2, flange_t2],
|
||||||
[flange_d / 2, flange_t],
|
[flange_d / 2, flange_t],
|
||||||
[flange_d / 2, 0],
|
[flange_d / 2, 0],
|
||||||
[od / 2, 0],
|
[od / 2, 0],
|
||||||
[od / 2, -h],
|
[od / 2, -h],
|
||||||
[0, -h]
|
[0, -h]
|
||||||
]);
|
]);
|
||||||
|
@@ -33,7 +33,7 @@ module magnet(type) { //! Draw specified magnet
|
|||||||
h = magnet_h(type);
|
h = magnet_h(type);
|
||||||
r = magnet_r(type);
|
r = magnet_r(type);
|
||||||
|
|
||||||
//vitamin(str("magnet(", type[0], "): Magnet ", od, "mm diameter, ", h, "mm high", id ? str(", ", id, "mm bore") : "" ));
|
vitamin(str("magnet(", type[0], "): Magnet ", od, "mm diameter, ", h, "mm high", id ? str(", ", id, "mm bore") : "" ));
|
||||||
|
|
||||||
or = od / 2;
|
or = od / 2;
|
||||||
ir = id / 2;
|
ir = id / 2;
|
||||||
|
@@ -23,7 +23,7 @@
|
|||||||
// od, id, h, r
|
// od, id, h, r
|
||||||
MAG8x4x4p2 = ["MAG8x4x4p2", 8, 4.2, 4, 0.5];
|
MAG8x4x4p2 = ["MAG8x4x4p2", 8, 4.2, 4, 0.5];
|
||||||
MAG484 = ["MAG484", inch(1/4), inch(1/8), inch(1/4), 0.5];
|
MAG484 = ["MAG484", inch(1/4), inch(1/8), inch(1/4), 0.5];
|
||||||
MAG5x8 = ["MAG484", 8, 0, 5, 0.5];
|
MAG5x8 = ["MAG5x8", 8, 0, 5, 0.5];
|
||||||
|
|
||||||
magnets = [MAG8x4x4p2, MAG484, MAG5x8];
|
magnets = [MAG8x4x4p2, MAG484, MAG5x8];
|
||||||
|
|
||||||
|
@@ -41,6 +41,8 @@ function microswitch_button_clr(type)= type[14]; //! Button colour
|
|||||||
function microswitch_lower_extent(type) = let(leg = microswitch_leg(type)) min([for(pos = microswitch_legs(type)) pos.y - leg.y / 2]); //! How far legs extend downwards
|
function microswitch_lower_extent(type) = let(leg = microswitch_leg(type)) min([for(pos = microswitch_legs(type)) pos.y - leg.y / 2]); //! How far legs extend downwards
|
||||||
function microswitch_right_extent(type) = let(leg = microswitch_leg(type)) max([microswitch_length(type) / 2, for(pos = microswitch_legs(type)) pos.x + leg.x / 2]); //! How far legs extend right
|
function microswitch_right_extent(type) = let(leg = microswitch_leg(type)) max([microswitch_length(type) / 2, for(pos = microswitch_legs(type)) pos.x + leg.x / 2]); //! How far legs extend right
|
||||||
|
|
||||||
|
function microswitch_size(type) = [microswitch_length(type), microswitch_width(type), microswitch_thickness(type)]; //! Body size
|
||||||
|
|
||||||
module microswitch_hole_positions(type) //! Place children at the hole positions
|
module microswitch_hole_positions(type) //! Place children at the hole positions
|
||||||
{
|
{
|
||||||
for(hole = microswitch_holes(type))
|
for(hole = microswitch_holes(type))
|
||||||
|
@@ -53,7 +53,7 @@ function rail_holes(type, length) = //! Number of holes in a rail given its `len
|
|||||||
module rail_hole_positions(type, length, first = 0, screws = 100, both_ends = true) { //! Position children over screw holes
|
module rail_hole_positions(type, length, first = 0, screws = 100, both_ends = true) { //! Position children over screw holes
|
||||||
pitch = rail_pitch(type);
|
pitch = rail_pitch(type);
|
||||||
holes = rail_holes(type, length);
|
holes = rail_holes(type, length);
|
||||||
last = first + screws;
|
last = first + min(screws, both_ends ? ceil(holes / 2) : holes);
|
||||||
for(i = [first : holes - 1], j = holes - 1 - i)
|
for(i = [first : holes - 1], j = holes - 1 - i)
|
||||||
if(i < last || both_ends && (j >= first && j < last))
|
if(i < last || both_ends && (j >= first && j < last))
|
||||||
translate([i * pitch - length / 2 + (length - (holes - 1) * pitch) / 2, 0])
|
translate([i * pitch - length / 2 + (length - (holes - 1) * pitch) / 2, 0])
|
||||||
@@ -181,19 +181,19 @@ module rail_assembly(type, length, pos, carriage_end_colour = grey(20), carriage
|
|||||||
carriage(rail_carriage(type), type, carriage_end_colour, carriage_wiper_colour);
|
carriage(rail_carriage(type), type, carriage_end_colour, carriage_wiper_colour);
|
||||||
}
|
}
|
||||||
|
|
||||||
module rail_screws(type, length, thickness, screws = 100) { //! Place screws in the rail
|
module rail_screws(type, length, thickness, screws = 100, index_screws = undef) { //! Place screws in the rail
|
||||||
screw = rail_screw(type);
|
screw = rail_screw(type);
|
||||||
end_screw = rail_end_screw(type);
|
end_screw = rail_end_screw(type);
|
||||||
screw_len = screw_longer_than(rail_screw_height(type, screw) + thickness);
|
screw_len = screw_longer_than(rail_screw_height(type, screw) + thickness);
|
||||||
end_screw_len = screw_longer_than(rail_screw_height(type, end_screw) + thickness);
|
end_screw_len = screw_longer_than(rail_screw_height(type, end_screw) + thickness);
|
||||||
|
|
||||||
index_screws = screws > 2 ? 1 : 2;
|
index_screws = is_undef(index_screws) ? screws > 2 ? 1 : 2 : index_screws;
|
||||||
|
|
||||||
translate_z(rail_screw_height(type, end_screw))
|
translate_z(rail_screw_height(type, end_screw))
|
||||||
rail_hole_positions(type, length, 0, index_screws)
|
rail_hole_positions(type, length, 0, index_screws)
|
||||||
screw(end_screw, end_screw_len);
|
screw(end_screw, end_screw_len);
|
||||||
|
|
||||||
translate_z(rail_screw_height(type, screw))
|
translate_z(rail_screw_height(type, screw))
|
||||||
rail_hole_positions(type, length, index_screws, min(screws, rail_holes(type, length)) - 2 * index_screws)
|
rail_hole_positions(type, length, index_screws, screws - index_screws)
|
||||||
screw(screw, screw_len);
|
screw(screw, screw_len);
|
||||||
}
|
}
|
||||||
|
@@ -41,6 +41,8 @@ function vero_track_width(type) = vero_pitch(type) * 0.8; //! The width of th
|
|||||||
function vero_length(type) = vero_holes(type) * vero_pitch(type); //! Length of the board
|
function vero_length(type) = vero_holes(type) * vero_pitch(type); //! Length of the board
|
||||||
function vero_width(type) = vero_strips(type) * vero_pitch(type); //! Width of the board
|
function vero_width(type) = vero_strips(type) * vero_pitch(type); //! Width of the board
|
||||||
|
|
||||||
|
function vero_size(type) = [vero_length(type), vero_width(type), vero_thickness(type)]; //! Board size
|
||||||
|
|
||||||
module solder_meniscus(type) {
|
module solder_meniscus(type) {
|
||||||
h = 1;
|
h = 1;
|
||||||
r = vero_track_width(type) / 2;
|
r = vero_track_width(type) / 2;
|
||||||
|
Reference in New Issue
Block a user