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
|
|
|
|
|
2021-06-04 18:46:31 +01:00
|
|
|
module ziptie(type, r = 5, t = 0) //! Draw specified ziptie wrapped around radius `r` and optionally through panel thickness `t`
|
2019-06-08 22:10:47 +01:00
|
|
|
{
|
2023-10-29 21:56:08 +00:00
|
|
|
$fa = fa; $fs = fs;
|
|
|
|
|
2019-06-08 22:10:47 +01:00
|
|
|
latch = ziptie_latch(type);
|
2019-06-25 17:41:59 +01:00
|
|
|
zt = ziptie_thickness(type);
|
2022-03-17 20:48:43 +00:00
|
|
|
lx = min(latch.x / 2, r + zt / 2);
|
|
|
|
right_bulge = (r > lx - zt / 2) || !t;
|
|
|
|
cr = zt / 2; // sharp corner radius
|
2019-06-25 17:41:59 +01:00
|
|
|
z = r + t - cr;
|
|
|
|
x = r - 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;
|
2022-03-17 20:48:43 +00:00
|
|
|
outside_path = concat([ if(right_bulge) [0, 0, r + zt], [x2, -r - zt, eps] ], outside_corners);
|
2019-06-25 17:41:59 +01:00
|
|
|
|
|
|
|
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
|
|
|
|
2021-06-04 18:46:31 +01:00
|
|
|
vitamin(str("ziptie(", type[0], "): 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);
|
2022-03-17 20:48:43 +00:00
|
|
|
|
|
|
|
offset(-zt)
|
|
|
|
rounded_polygon(outside_path, tangents);
|
2019-06-25 17:41:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
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
|
|
|
}
|