X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=poster-tube-lid.scad;h=4ce2176f513dbe34e646cfbac7859aae7a5a0ab6;hb=9cb16ea8efbc65fba14bded7da869c2a0e57b396;hp=4120312141f196d65392367bc7dcbbf05cbd2516;hpb=d5ff2b32f7b194d99bbf12a857386cda45e05eee;p=reprap-play.git diff --git a/poster-tube-lid.scad b/poster-tube-lid.scad index 4120312..4ce2176 100644 --- a/poster-tube-lid.scad +++ b/poster-tube-lid.scad @@ -11,7 +11,7 @@ main_cnr = 6.0; min_wall = 3; -rivet_posn = 6.0 + 0.1; +rivet_posn = 6.0 + 0.30; rivet_thick = 1.67; rivet_width = 4.15 + 1.0; rivet_tall = 5.51 + 1.49; @@ -20,7 +20,7 @@ over_rivet_wall = 1.0; side_rivet_gap = 1.5; inside_rivet_gap = 1.5; -bayo_interf = 0.44; +bayo_interf = 0.30; bayo_behind = 3.5; bayo_interf_width = 2.0; bayo_interf_slope = 0.5; @@ -58,7 +58,7 @@ strap_hoop_inside = 10; strap_hoop_strlen = 10; strap_hoop_elevation = 45; -sm_inner_circum = 218; +sm_inner_circum = 218 - 1.90 - 1.00 - 0.50; sm_main_thick = 2.0; sm_main_width = 20; @@ -75,6 +75,19 @@ sm_bolt_y_over = 0.5; sm_closure_cnr = 3.0; +catch_stem_h = 3; +catch_stem_len = 50; +catch_stem_th = 3; + +catch_knob_dia = 6; +catch_knob_above_gap = 8; +catch_pin_height = 7; + +catch_stem_below_gap = 1.0; +catch_stem_beside_gap = 2.0; +catch_pin_gap = 0.5; +catch_hook_slope = 0.15; + // calculated TAU = PI*2; @@ -125,9 +138,49 @@ smc_max_y = smc_bolt_y + sm_bolt_y_over smc_cnr_c_x = sm_bolt_shaft/2 - sm_closure_cnr + sm_bolt_head_thick/2 + smc_bolt_nut_eff_thick/2; +catch_cr = catch_knob_dia/2 + catch_stem_beside_gap; +catch_strap_width = sm_main_width; +catch_strap_thick = sm_main_thick; +catch_stem_end_h = catch_stem_h; +catch_pin_width = rivet_entry_width - catch_pin_gap; + +cppy6 = -catch_strap_width/2; +cppxC = TAU * 0.34 * main_dia/2; +cppB = [ catch_pin_width/2, + cppy6 + + catch_stem_below_gap + + catch_pin_height + + catch_knob_dia/2 ]; +cpp0 = [ 0, + cppB[1] + + catch_knob_dia + + catch_knob_above_gap ]; +cpp12 = cpp0 + [1,0] * (catch_pin_height * catch_hook_slope); +cpp1 = cpp0 + [0,1] * catch_pin_height; +cpp2 = cpp1 + [1,0] * catch_pin_width; +cpp4 = cpp0 + [0,-1] * catch_stem_end_h; +cpp3 = [ cpp2[0], cpp4[1] ]; +cpp5 = [ cpp0[0] - catch_stem_len, + -catch_stem_h ]; +cpp6 = [ cpp5[0], catch_cr ]; +cpp7 = cppB + [1,-1] * catch_knob_dia/2 + + [ catch_stem_beside_gap, -catch_stem_below_gap ] + + [ 0, -catch_pin_height ] + + [-1,1] * catch_cr; +cpp11 = cpp7 + [1,0] * catch_cr; +cpp10 = [ cpp11[0], 0 - catch_cr ]; +cpp8 = cpp10 + [1,0] * catch_cr; +cpp9 = cpp8 + [0,1] * catch_cr; +cppC = [ cppxC, cpp9[1] ]; +cppA = [ -cppxC, 0 ]; +cppD = cppC + [0,-1] * catch_strap_width; +cppE = [ cppA[0], cppD[1] ]; + $fs= coarse ? 2.5 : 0.5; $fa= coarse ? 5 : 1; +include + // bayonet definition bayo_a = [ bayo_entry_x, 0 ]; @@ -196,7 +249,7 @@ module MainProfile(){ translate([ 0, oring_y_rad ]) scale([ 1/oring_oblate * (oring_compress_more+1) , oring_oblate ]) circle(oring_thick/2); - #translate([ 0, oring_y_rad*2 - oring_thick/2 ]) + translate([ 0, oring_y_rad*2 - oring_thick/2 ]) circle(oring_thick/2); } } @@ -234,10 +287,6 @@ module StrapHoop(){ ////toplevel } } -module HandlingProfile(){ -// translate([ -} - module RotateProjectSlice(offset, slice_size, nom_rad, real_rad){ // nom_rad > real_rad rotate([0,0, atan2(offset, nom_rad) ]){ @@ -339,6 +388,12 @@ module Cover(){ ////toplevel } } } + for (r=[0,180]) + rotate([0,0,r]) + translate([-implheadcup_large_dia * .5 - implheadcup_thick/2, + -implheadcup_large_dia * .0, + middle_bot_z + 0.1]) + ImplHeadCup(); // translate(strap_hoop_thick * [-0.5, 0, +1]) // translate([handling_dia/2, 0, -side_height]) // rotate([0,180,0]) rotate([0,0,90]) @@ -396,6 +451,13 @@ module CoverTest1(){ ////toplevel } } +module ImplHeadCupTest(){ ////toplevel + for (r=[0,180]) + rotate([0,0,r]) + translate([-17,0,0]) + ImplHeadCup(); +} + module StrapMountBolt(l_delta){ ///toplevel // positioned relative to smc_pos translate([(smc_bolt_nut_eff_thick - sm_bolt_head_thick)/2, @@ -455,6 +517,58 @@ module StrapMount(){ ////toplevel } } +module CatchCoreProfile(){ ////toplevel + hull(){ + translate(cppB) circle(r= catch_knob_dia/2); + polygon([cpp4, + cppB, + cpp3]); + } + translate(cpp8) + circle(catch_cr); + polygon([ + cpp4, + cppB, + cpp3, + cpp2, + cpp1, + cpp12, + ]); + difference(){ + polygon([ cpp4, + cpp3, + cpp12, + cppA, + cppE, + cppD, + cppC, + cpp9, + cpp10, + cpp11, + cpp7, + cpp5, + ], convexity=10); + hull(){ + translate(cpp7) circle(r= catch_cr); + polygon([ cpp7, + cpp5, + cpp11 ]); + } + hull(){ + translate(cpp6) circle(catch_cr); + polygon([ cppA, + cpp0, + cpp1 ]); + } + } +} + +module CatchPreDistort(){ /////toplevel + rotate([90,0,0]) + linear_extrude(height=catch_strap_thick, convexity=10) + CatchCoreProfile(); +} + //ProfilesDemo(); //BayonetCutout(); //MainProfile();