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/>.
|
|
|
|
//
|
|
|
|
|
|
|
|
//
|
|
|
|
//! Cable zipties.
|
|
|
|
//
|
|
|
|
|
2020-02-29 17:52:36 +00:00
|
|
|
include <../utils/core/core.scad>
|
2019-06-25 17:41:59 +01:00
|
|
|
use <../utils/rounded_polygon.scad>
|
2019-06-08 22:10:47 +01:00
|
|
|
|
|
|
|
function ziptie_width(type) = type[1]; //! Width
|
|
|
|
function ziptie_thickness(type) = type[2]; //! Thickness
|
|
|
|
function ziptie_latch(type) = type[3]; //! Latch dimensions
|
|
|
|
function ziptie_colour(type) = type[4]; //! Colour
|
|
|
|
function ziptie_tail(type) = type[5]; //! The length without teeth
|
|
|
|
|
2020-12-24 16:04:59 +00:00
|
|
|
module ziptie(type, r, t = 0) //! Draw specified ziptie wrapped around radius `r` and optionally through panel thickness `t`
|
2019-06-08 22:10:47 +01:00
|
|
|
{
|
|
|
|
latch = ziptie_latch(type);
|
2019-06-25 17:41:59 +01:00
|
|
|
lx = latch.x / 2;
|
|
|
|
zt = ziptie_thickness(type);
|
|
|
|
cr = zt; // sharp corner raduus
|
|
|
|
z = r + t - cr;
|
|
|
|
x = r - cr;
|
|
|
|
inside_corners = t ? [ [0, 0, r], [-x, z, cr], [x, z, cr] ] : [];
|
|
|
|
outside_corners = t ? [ [0, 0, r + zt], [-x, z, cr + zt], [x, z, cr + zt] ] : [];
|
|
|
|
x1 = lx - zt / 2;
|
|
|
|
x2 = x1 + x1 * zt / r;
|
|
|
|
inside_path = concat([ [0, 0, r], [x1, -r, eps] ], inside_corners);
|
|
|
|
outside_path = concat([ [0, 0, r + zt], [x2, -r - zt, eps] ], outside_corners);
|
|
|
|
|
|
|
|
tangents = rounded_polygon_tangents(outside_path);
|
|
|
|
length = ceil(rounded_polygon_length(outside_path, tangents) + ziptie_tail(type) + latch.z + 1);
|
2019-06-08 22:10:47 +01:00
|
|
|
len = length <= 100 ? 100 : length;
|
2019-08-18 18:39:56 +01:00
|
|
|
width = ziptie_width(type);
|
2019-06-25 17:41:59 +01:00
|
|
|
|
2019-08-18 18:39:56 +01:00
|
|
|
vitamin(str("ziptie(", type[0], ", ", r, "): Ziptie ", width, "mm x ", len, "mm min length"));
|
2019-06-08 22:10:47 +01:00
|
|
|
|
2019-06-25 17:41:59 +01:00
|
|
|
color(ziptie_colour(type)){
|
2020-03-29 20:18:57 +01:00
|
|
|
linear_extrude(width, center = true)
|
2019-06-25 17:41:59 +01:00
|
|
|
difference() {
|
|
|
|
rounded_polygon(outside_path, tangents);
|
|
|
|
rounded_polygon(inside_path);
|
|
|
|
}
|
|
|
|
|
|
|
|
translate([lx, -r])
|
|
|
|
rotate([90, 0, 0])
|
2019-06-08 22:10:47 +01:00
|
|
|
union() {
|
2021-02-08 09:41:07 +00:00
|
|
|
rounded_rectangle(latch, 0.5);
|
2019-06-08 22:10:47 +01:00
|
|
|
|
2019-06-25 17:41:59 +01:00
|
|
|
translate_z((latch.z + 1) / 2)
|
2019-06-08 22:10:47 +01:00
|
|
|
cube([ziptie_thickness(type), ziptie_width(type), latch.z + 1], center = true);
|
|
|
|
}
|
2019-06-25 17:41:59 +01:00
|
|
|
}
|
2019-06-08 22:10:47 +01:00
|
|
|
}
|