1
0
mirror of https://github.com/nophead/Mendel90.git synced 2025-01-17 21:08:16 +01:00
Mendel90/scad/vitamins/nuts.scad
2012-03-12 01:13:07 +00:00

94 lines
3.1 KiB
OpenSCAD

//
// Mendel90
//
// GNU GPL v2
// nop.head@gmail.com
// hydraraptor.blogspot.com
//
// Washers
//
M3_nut = [3, 6.4, 2.4, 4, M3_washer, M3_nut_trap_depth];
M4_nut = [4, 8.1, 3.2, 5, M4_washer, M4_nut_trap_depth];
M6_nut = [6, 11.5, 5, 8, M6_washer, M6_nut_depth];
M8_nut = [8, 15, 6.5, 8, M8_washer, M8_nut_depth];
function nut_radius(type) = type[1] / 2;
function nut_flat_radius(type) = nut_radius(type) * cos(30);
function nut_thickness(type, nyloc = false) = nyloc ? type[3] : type[2];
function nut_washer(type) = type[4];
function nut_trap_depth(type) = type[5];
module nut(type, nyloc = false) {
hole_rad = type[0] / 2;
outer_rad = nut_radius(type);
thickness = nut_thickness(type);
nyloc_thickness = type[3];
if(nyloc)
vitamin(str("NYLOCM", type[0], ": Nyloc nut M", type[0]));
else
vitamin(str("NUTM", type[0], ": Nut M", type[0]));
if(exploded && nyloc)
cylinder(r = 0.2, h = 10);
color([0.7, 0.7, 0.7]) render() translate([0, 0, (exploded && nyloc) ? 10 : 0]) difference() {
union() {
cylinder(r = outer_rad, h = thickness, $fn = 6);
if(nyloc)
translate([0,0, eta])
rounded_cylinder(r = outer_rad * cos(30) , h = nyloc_thickness, r2 = (nyloc_thickness - thickness) / 2);
}
translate([0,0,-1])
cylinder(r = hole_rad, h = nyloc_thickness + 2);
}
}
module nut_and_washer(type, nyloc) {
washer = nut_washer(type);
translate([0, 0, exploded ? 7 : 0])
washer(washer);
translate([0,0, washer_thickness(washer)])
nut(type, nyloc);
}
M4_wingnut = [4, 10, 3.75, 8, M4_washer, 0, 22, 10, 6, 3];
module wingnut(type) {
hole_rad = type[0] / 2;
bottom_rad = nut_radius(type);
top_rad = type[3] / 2;
thickness = nut_thickness(type);
wing_span = type[6];
wing_height = type[7];
wing_width = type[8];
wing_thickness = type[9];
top_angle = asin((wing_thickness / 2) / top_rad);
bottom_angle = asin((wing_thickness / 2) / bottom_rad);
vitamin(str("WING0", type[0], ": Wingnut M",type[0]));
if(exploded)
cylinder(r = 0.2, h = 10);
color([0.7,0.7,0.7]) render() translate([0, 0, exploded ? 10 : 0]) difference() {
union() {
cylinder(r1 = bottom_rad, r2 = top_rad, h = thickness);
for(rot = [0, 180])
rotate([90, 0, rot]) linear_extrude(height = wing_thickness, center = true)
hull() {
translate([wing_span / 2 - wing_width / 2, wing_height - wing_width / 2])
circle(r = wing_width / 2, center = true);
polygon([
[bottom_rad * cos(top_angle) - eta, 0],
[wing_span / 2 - wing_width / 2, wing_height - wing_width / 2],
[top_rad * cos(top_angle) - eta, thickness],
[bottom_rad * cos(top_angle) - eta, 0],
]);
}
}
translate([0,0,-1])
cylinder(r = hole_rad, h = thickness + 2);
}
}