1
0
mirror of https://github.com/nophead/NopSCADlib.git synced 2025-01-16 21:18:15 +01:00

added chamfer distance variable to taper in the bottom of the dome heads

This commit is contained in:
texas 2024-08-16 16:49:04 -05:00
parent e9292d9165
commit 37fe83e2e0
2 changed files with 22 additions and 14 deletions

View File

@ -235,27 +235,35 @@ module screw(type, length, hob_point = 0, nylon = false) { //! Draw specified sc
cylinder(h=2 * eps, r=socket_rad + eps); cylinder(h=2 * eps, r=socket_rad + eps);
shaft(); shaft();
} }
if(head_type == hs_dome) { if(head_type == hs_dome) {
R_minus_h = head_height; // h would be the height of the sphere cap that's cut off of the top of the screw dome edge_height = head_rad / 7.5;
a= socket_rad; head_chamfer_x=edge_height/2;
// this is the trig way to do this, head_fillet_radius= 0.5;
// alpha=atan(R_minus_h/a); p0 = [head_rad, edge_height]; // Lowest point on the arc
// R = R_minus_h/sin(alpha); //Radius if the cap was a perfect unscaled sphere p1 = [1.3 * socket_rad / cos(30), head_height]; // Highest point on the arc
// this is mathematcially equivalent, but may run faster computationally with sqrt and ^2 instead of trig p = (p0 + p1) / 2; // Start of bisector
R= a*sqrt((R_minus_h^2/a^2)+1); // Radius if the cap was a perfect unscaled sphere gradient = (p0.x - p1.x) / (p1.y - p0.y); // Gradient of perpendicular bisector = -1 / gradient of the line between p10 and p1
dome_height_scaling_factor= R/head_rad; c = p.y - gradient * p.x; // Y ordinate of the centre of the dome
r = norm(p1 - [0, c]); // Dome radius is distance from centre
color(colour) { color(colour) {
rotate_extrude() { rotate_extrude() {
difference() { difference() {
intersection() { intersection() {
scale([1,dome_height_scaling_factor]) translate([0, c])
circle(r=head_rad); circle(r);
square([head_rad, head_height]); // square([head_rad, head_height]);
offset(head_fillet_radius) offset(-head_fillet_radius)
polygon(points = [
[0,0],
[head_rad-head_chamfer_x,0],
[head_rad, edge_height],
[head_rad,head_height],
[0,head_height],
]);
} }
translate([0, head_height - socket_depth]) translate([0, head_height - socket_depth])
square([socket_rad, 20]); square([socket_rad, 10]);
} }
} }
linear_extrude(head_height) linear_extrude(head_height)

View File

@ -88,7 +88,7 @@ M3_dome_screw = ["M3_dome", "M3 dome", hs_dome, 3, 5.7, 1.65, 1.04,2.0
M4_dome_screw = ["M4_dome", "M4 dome", hs_dome, 4, 7.6, 2.2, 1.3, 2.5, 20, M4_washer, M4_nut, M4_tap_radius, M4_clearance_radius]; M4_dome_screw = ["M4_dome", "M4 dome", hs_dome, 4, 7.6, 2.2, 1.3, 2.5, 20, M4_washer, M4_nut, M4_tap_radius, M4_clearance_radius];
M5_dome_screw = ["M5_dome", "M5 dome", hs_dome, 5, 9.5, 2.75, 1.56,3.0, 22, M5_washer, M5_nut, M5_tap_radius, M5_clearance_radius]; M5_dome_screw = ["M5_dome", "M5 dome", hs_dome, 5, 9.5, 2.75, 1.56,3.0, 22, M5_washer, M5_nut, M5_tap_radius, M5_clearance_radius];
M6_dome_screw = ["M6_dome", "M6 dome", hs_dome, 6, 10.5, 3.3, 2.5,4.0, 24, M6_washer, M6_nut, M6_tap_radius, M6_clearance_radius]; M6_dome_screw = ["M6_dome", "M6 dome", hs_dome, 6, 10.5, 3.3, 2.5,4.0, 24, M6_washer, M6_nut, M6_tap_radius, M6_clearance_radius];
M8_dome_screw = ["M8_dome", "M8 dome", hs_dome, 8, 14, 4.4, 3,5.0, 30, M8_washer, M8_nut, M8_tap_radius, M8_clearance_radius]; M8_dome_screw = ["M8_dome", "M8 dome", hs_dome, 8, 14, 4.4, 3, 5.0, 30, M8_washer, M8_nut, M8_tap_radius, M8_clearance_radius];
M2p5_pan_screw = ["M2p5_pan", "M2.5 pan", hs_pan, 2.5, 4.7, 1.7, 0, 0, 0, M2p5_washer, M2p5_nut, M2p5_tap_radius, M2p5_clearance_radius]; M2p5_pan_screw = ["M2p5_pan", "M2.5 pan", hs_pan, 2.5, 4.7, 1.7, 0, 0, 0, M2p5_washer, M2p5_nut, M2p5_tap_radius, M2p5_clearance_radius];
M3_pan_screw = ["M3_pan", "M3 pan", hs_pan, 3, 5.4, 2.0, 0, 0, 0, M3_washer, M3_nut, M3_tap_radius, M3_clearance_radius]; M3_pan_screw = ["M3_pan", "M3 pan", hs_pan, 3, 5.4, 2.0, 0, 0, 0, M3_washer, M3_nut, M3_tap_radius, M3_clearance_radius];