1
0
mirror of https://github.com/nophead/NopSCADlib.git synced 2025-02-06 07:48:47 +01:00
NopSCADlib/tests/wire.scad
Chris Palmer ed46cbb147 Fixed cable_bundle() bugs and added test.
Added cable_bundle_positions().
Can now mark cables as ribbon to force a flat layout.
2022-02-11 09:07:34 +00:00

100 lines
3.3 KiB
OpenSCAD

//
// 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/>.
//
include <../utils/core/core.scad>
use <../vitamins/wire.scad>
bundle = [7, 1.4];
bundle_r = cable_radius(bundle);
thickness = 2;
w = 60;
d = 20;
h = 40;
wire_l = 90;
mouse_y = 10;
cable_pitch = 7;
module wires() {
translate([0, mouse_y, bundle_r])
rotate([0, 90, 0]) {
n = cable_wires(bundle);
d = cable_wire_size(bundle);
if(n > 6)
color("green") {
cylinder(d = d, h = wire_l, center = true);
wire("green", 7, wire_l);
}
m = n > 6 ? n - 1 : n;
for(i = [0 : m - 1])
rotate(i * 360 / m)
translate([bundle_r - d / 2, 0]) {
colour = ["black", "brown", "red", "orange", "yellow", "blue", "purple"][i];
wire(colour, 7, wire_l);
color(colour)
cylinder(d = d, h = wire_l, center = true);
}
%cylinder(r = bundle_r, h = wire_l - 10, center = true);
}
stl_colour(pp1_colour) {
rotate([90, 0, 90])
linear_extrude(thickness)
difference() {
square([w, h]);
translate([mouse_y, 0])
mouse_hole(bundle, 0, true);
for(i = [1 : 6])
let(cable = [i, 1.4], bundle = cable_bundle(cable))
translate([mouse_y + cable_pitch * i - bundle.x / 2, -eps])
square([bundle.x, bundle.y]);
}
translate_z(-thickness)
linear_extrude(thickness)
difference() {
translate([thickness -d, 0])
square([d, w]);
translate([-15, mouse_y])
cable_tie_holes(bundle_r, 0);
}
}
translate([-15, mouse_y])
cable_tie(bundle_r, thickness);
for(i = [1 : 6]) let(cable = [i, 1.4])
translate([0, mouse_y + cable_pitch * i])
let(positions = cable_bundle_positions(cable))
for(i = [0 : len(positions) - 1])
let(p = positions[i])
translate([0, p.x, p.y])
rotate([0, 90, 0])
color([grey(10), "blue", "red", "orange", "yellow", "green"][i])
cylinder(d = cable_wire_size(cable), h = 60, center = true);
}
if($preview)
wires();