mirror of
https://github.com/nophead/NopSCADlib.git
synced 2025-01-17 05:28:14 +01:00
2d091b9d16
PCB text can now specify a colour. Added SOT23_6, TSOT23_8 and CAP1210 SMD packages. Added ESP-201 Wifi Module PCB. Added ESP12F Wifi module. Added tiny_buck converter PCB. Made 2p54joiner a bit longer. Fixed SOIC gullwing shape. Added Wifi antennas. Added Yunpen filtered IEC mains inlet. Added power jack socket. Added right angle option for LEDs. Added gear_motors. Added 686ZZ and 696ZZ ball bearings. Added two larger box section tubes. Added right angle option to square_buttons. Doesn't draw the frame yet. Added multiwatt11 package for L6203. Added ONS9143A 13A mains socket. Added radial electrolytic capacitors. Added LDE10_20B PSU module. Added screw_tearsink() to make horizontal countersunk holes. Can now have solid tracks on veroboard. Added veroboard_base() module to make an STL for a base with spacers. Corrected M6 spring washer thickness. Can now specify the height of a solder meniscus. slot() now has a center option. Added button_6mm_7 with a taller button. Added default fa, fs and fn constants used for drawing vitamins. These can be set via $default_fa and $default_fs that can also be set by environment variables: NOPSCADLIB_DEFAULT_FA and NOPSCADLIB_DEFAULT_FS.
141 lines
5.2 KiB
OpenSCAD
141 lines
5.2 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/>.
|
|
//
|
|
|
|
//
|
|
//! UK 13A sockets at the moment.
|
|
//
|
|
include <../core.scad>
|
|
include <ring_terminals.scad>
|
|
use <insert.scad>
|
|
|
|
function mains_socket_width(type) = type[1]; //! Width at the base
|
|
function mains_socket_depth(type) = type[2]; //! Depth at the base
|
|
function mains_socket_top_w(type) = type[3]; //! Width at the top, might be tapered
|
|
function mains_socket_top_d(type) = type[4]; //! Depth at the top, might be tapered
|
|
function mains_socket_corner(type) = type[5]; //! Corner radius
|
|
function mains_socket_height(type) = type[6]; //! Height
|
|
function mains_socket_t(type) = type[7]; //! Plastic thickness
|
|
function mains_socket_offset(type) = type[8]; //! Offset of the socket from the centre
|
|
function mains_socket_pitch(type) = type[9]; //! Screw hole pitch
|
|
function mains_socket_counterbore(type) = type[10]; //! Screw counterbore
|
|
function mains_socket_screw(type) = M3_cs_cap_screw; //! Screw type
|
|
|
|
earth = M3_ringterm;
|
|
earth_screw = ringterm_screw(earth);
|
|
insert_wall = 3;
|
|
|
|
function mains_socket_insert_boss(type) = 2 * (insert_hole_radius(screw_insert(mains_socket_screw(type))) + insert_wall);
|
|
|
|
module face_plate(type)
|
|
rounded_square([mains_socket_width(type), mains_socket_depth(type)], mains_socket_corner(type));
|
|
|
|
module mains_socket_hole_positions(type) //! Position children at the screw holes
|
|
for(side = [-1, 1])
|
|
translate([side * mains_socket_pitch(type) / 2, 0])
|
|
children();
|
|
|
|
module mains_socket_earth_position(type) { //! Position of earth terminal for DiBond panel
|
|
inset = mains_socket_t(type) + washer_diameter(screw_washer(earth_screw)) / 2 + 1;
|
|
|
|
translate([-mains_socket_width(type) / 2 + inset, -mains_socket_depth(type) / 2 + inset])
|
|
children();
|
|
}
|
|
|
|
module mains_socket_holes(type, h = 0, earth = true, small = false) { //! Panel cutout
|
|
mains_socket_hole_positions(type)
|
|
drill(screw_clearance_radius(mains_socket_screw(type)), h);
|
|
|
|
extrude_if(h)
|
|
offset(cnc_bit_r) offset(-cnc_bit_r) difference() {
|
|
offset(-7) face_plate(type);
|
|
|
|
for(side = [-1, 1])
|
|
hull()
|
|
for(x = [1, 2])
|
|
translate([side * mains_socket_pitch(type) / x, 0])
|
|
if(small)
|
|
square([2 * 4.5, mains_socket_top_w(type)], true);
|
|
else
|
|
circle(4.5);
|
|
|
|
if(earth)
|
|
mains_socket_earth_position(type)
|
|
circle(d = washer_diameter(screw_washer(earth_screw)) + 2);
|
|
}
|
|
|
|
if(earth)
|
|
mains_socket_earth_position(type)
|
|
drill(screw_clearance_radius(earth_screw), h);
|
|
}
|
|
|
|
module mains_socket(type) { //! Draw specified 13A socket
|
|
offset = mains_socket_offset(type);
|
|
screw = mains_socket_screw(type);
|
|
height = mains_socket_height(type);
|
|
width = mains_socket_width(type);
|
|
|
|
vitamin(str("mains_socket(", type[0], "): Mains socket 13A", offset.x || offset.y ? ", switched" : ""));
|
|
|
|
color("white") render() difference() {
|
|
hull() {
|
|
linear_extrude(eps)
|
|
face_plate(type);
|
|
|
|
linear_extrude(height)
|
|
offset(-(width - mains_socket_top_w(type)) / 2)
|
|
face_plate(type);
|
|
}
|
|
// Holes for pins
|
|
translate([offset.x, offset.y, mains_socket_height(type)]) {
|
|
for(side = [-1, 1])
|
|
translate([side * 11.1, -11.1])
|
|
cube([7, 4.5, 8], center = true);
|
|
|
|
translate([0, 11.1])
|
|
cube([4.5, 8.5, 8], center = true);
|
|
}
|
|
// Hollow out the back
|
|
difference() {
|
|
linear_extrude(height - mains_socket_t(type))
|
|
offset(-mains_socket_t(type))
|
|
face_plate(type);
|
|
|
|
cube(50, center = true);
|
|
|
|
cube([mains_socket_top_w(type), 13, 2 * height + 1], center = true);
|
|
}
|
|
// Screw holes
|
|
mains_socket_hole_positions(type) {
|
|
cylinder(r = screw_clearance_radius(screw), h = 100, center = true);
|
|
|
|
counter_bore = mains_socket_counterbore(type);
|
|
translate_z(height - counter_bore[0]) {
|
|
screw_countersink(screw, drilled = false);
|
|
|
|
if(counter_bore[1])
|
|
cylinder(d = counter_bore[1], h = height);
|
|
|
|
if(counter_bore[2])
|
|
vflip()
|
|
cylinder(d = counter_bore[2], h = height);
|
|
}
|
|
}
|
|
}
|
|
}
|