2019-06-08 22:10:47 +01:00
|
|
|
//
|
|
|
|
// NopSCADlib Copyright Chris Palmer 2018
|
|
|
|
// nop.head@gmail.com
|
|
|
|
// hydraraptor.blogspot.com
|
|
|
|
//
|
|
|
|
// This file is part of NopSCADlib.
|
|
|
|
//
|
|
|
|
// NopSCADlib is free software: you can redistribute it and/or modify it under the terms of the
|
|
|
|
// GNU General Public License as published by the Free Software Foundation, either version 3 of
|
|
|
|
// the License, or (at your option) any later version.
|
|
|
|
//
|
|
|
|
// NopSCADlib is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
|
|
|
|
// without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
// See the GNU General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License along with NopSCADlib.
|
|
|
|
// If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
//
|
|
|
|
|
2020-02-29 17:52:36 +00:00
|
|
|
include <../utils/core/core.scad>
|
2019-06-08 22:10:47 +01:00
|
|
|
use <../vitamins/rod.scad>
|
|
|
|
include <../vitamins/sheets.scad>
|
|
|
|
|
2020-12-18 09:22:39 +00:00
|
|
|
module positions()
|
|
|
|
for(i = [1 : 10]) {
|
|
|
|
translate([(i * i + i) / 2 + 3 * i , 8])
|
|
|
|
let($r = i / 2)
|
|
|
|
children();
|
|
|
|
|
|
|
|
let(d = i + 0.5)
|
|
|
|
translate([(d * d + d) / 2 + 3 * d, 19])
|
|
|
|
let($r = d / 2)
|
2019-06-08 22:10:47 +01:00
|
|
|
children();
|
2020-12-18 09:22:39 +00:00
|
|
|
}
|
2019-06-08 22:10:47 +01:00
|
|
|
|
2020-12-18 09:22:39 +00:00
|
|
|
module polyhole_stl() {
|
|
|
|
stl("polyhole");
|
2019-06-08 22:10:47 +01:00
|
|
|
|
2020-12-18 09:22:39 +00:00
|
|
|
linear_extrude(3, center = true)
|
2019-06-08 22:10:47 +01:00
|
|
|
difference() {
|
|
|
|
square([100, 27]);
|
|
|
|
|
|
|
|
positions()
|
|
|
|
poly_circle(r = $r);
|
|
|
|
}
|
2020-12-18 09:22:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
module alt_polyhole_stl() {
|
|
|
|
holes = [2.5, 2, 1.5];
|
|
|
|
n = len(holes);
|
|
|
|
size = [n * 10, 10, 10];
|
|
|
|
difference() {
|
|
|
|
translate([-size.x / n / 2, $preview ? 0 : -size.y / 2])
|
|
|
|
cube($preview ? [size.x, size.y / 2, size.z] : size);
|
|
|
|
|
|
|
|
for(i = [0 : n - 1])
|
|
|
|
translate([i * 10, 0])
|
|
|
|
if(i % 2)
|
|
|
|
translate_z(size.z)
|
|
|
|
poly_cylinder(r = holes[i] / 2, h = 2 * size.z, center = true, twist = i + 1);
|
|
|
|
else
|
|
|
|
poly_cylinder(r = holes[i] / 2, h = size.z, center = false, twist = i + 1);
|
|
|
|
}
|
|
|
|
}
|
2019-06-08 22:10:47 +01:00
|
|
|
|
2020-12-18 09:22:39 +00:00
|
|
|
module polyholes() {
|
|
|
|
stl_colour(pp1_colour)
|
|
|
|
polyhole_stl();
|
|
|
|
|
|
|
|
positions()
|
2019-06-08 22:10:47 +01:00
|
|
|
rod(d = 2 * $r, l = 8 * $r + 5);
|
|
|
|
//
|
2020-12-18 09:22:39 +00:00
|
|
|
// Alternating polyholes
|
|
|
|
//
|
|
|
|
translate([30, -40])
|
2024-02-10 01:05:24 +00:00
|
|
|
render_manifold() alt_polyhole_stl();
|
2020-12-18 09:22:39 +00:00
|
|
|
//
|
2019-06-08 22:10:47 +01:00
|
|
|
// Poly rings
|
|
|
|
//
|
|
|
|
ir = 3 / 2;
|
|
|
|
cir = corrected_radius(ir);
|
|
|
|
sizes = [1.5, 2, 3, 4];
|
|
|
|
for(i = [0 : len(sizes) - 1])
|
|
|
|
translate([i * 10, -10]) {
|
2020-04-06 10:27:17 +01:00
|
|
|
stl_colour(pp1_colour)
|
2019-07-19 11:03:26 +01:00
|
|
|
poly_tube(ir = ir, or = cir + sizes[i] * extrusion_width, h = 1);
|
2019-06-08 22:10:47 +01:00
|
|
|
|
|
|
|
rod(2 * ir, 3);
|
|
|
|
}
|
|
|
|
//
|
|
|
|
// Drill and slot
|
|
|
|
//
|
|
|
|
sheet = Steel06;
|
|
|
|
translate([10, -30])
|
|
|
|
render_2D_sheet(sheet)
|
|
|
|
difference() {
|
|
|
|
sheet_2D(sheet, 20, 20, 1);
|
|
|
|
|
|
|
|
translate([0, 5])
|
|
|
|
slot(1.5, 6, 0);
|
|
|
|
|
|
|
|
translate([0, -5])
|
|
|
|
drill(2, 0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-12-18 09:22:39 +00:00
|
|
|
if($preview)
|
|
|
|
polyholes();
|
|
|
|
else {
|
|
|
|
polyhole_stl();
|
|
|
|
|
|
|
|
translate([50, -20])
|
|
|
|
alt_polyhole_stl();
|
|
|
|
}
|