X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=reprap-play.git;a=blobdiff_plain;f=filamenttrestle.scad;h=712b9eb1a70f0fb0a141a731bef6a24234cc59f8;hp=c45e8af5472f4e58201ee466c5b970a9019b49aa;hb=fd3025ff005de5b2aaa7b6be990009520692f977;hpb=74b59b4dd43bffd9a3c3f349b83d0efb4edf57ee diff --git a/filamenttrestle.scad b/filamenttrestle.scad index c45e8af..712b9eb 100644 --- a/filamenttrestle.scad +++ b/filamenttrestle.scad @@ -1,16 +1,28 @@ // -*- C -*- spoolwidth = 80; // fixme needs to be measured -trestleheight = 80; // fixme needs to be checked -trestlebase = 80; // fixme needs to be checked +spoolinnerrad = 25; // fixme needs to be checked +spoolouterrad = 60; // fixme needs to be checked include +include -spoolwidthgap = 2; -barrady = 5; -barradz = 7; -guidewidth = 3; -guiderad = 20; +spoolradclear = 10; +spoolradslop = 2; + +spoolinnerslop = 2; +axleslop = 0.5; + +axlerad = 7; +barwasherrad = 17; + +hubbasethick = 6; +hubmainthick = 20; +hubbaseweb = 2; +hubbasestalkwidth = 6; +hubwalls = 3; +hubbaserad = spoolinnerrad + 15; +hubmainrad = spoolinnerrad - spoolradslop; legw = 12; plugl = 20; @@ -24,56 +36,83 @@ trestlebaseh = 10; trestleplugd = 1; topblockthick = 4; -topblockbasedepth = 4; +topblockbasedepth = 5; pinbasew = 5.0; pinminh = 1.5; -pinmaxh = 4.0; -pindh = 0.75; +pinmaxh = 4.5; +pindh = 0.50; pindwidth = 0.75; pintaperlen = plugwmax * 0.85; pinstraightlen = 10; +spoolouterpad = AxlePin_holerad()*2 * 1.5; +spoolbarlen = spoolwidth + + 2*(Washer_thick() + hubbasethick + AxlePin_holerad() + + spoolinnerslop + spoolouterpad); + barz = axlerad * 0.5; +axlepin_x = spoolwidth/2 + hubbasethick + + Washer_thick() + spoolinnerslop + AxlePin_holerad()*0.5; + +trestleheight = spoolouterrad + spoolradclear - barz; +trestlebase = trestleheight * 1.2; + module Plug(d=0){ dw = d; dh = d; + dhb = d*2; a = atan(plugslope); - bdx = dw / cos(a); + bdy = -dhb; + bdx = dw / cos(a) + bdy * plugslope; tdy = dh; - tdx = bdx + dh * plugslope; + tdx = bdx + tdy * plugslope; translate([-d,0,0]) rotate([90,0,90]) linear_extrude(height=plugl+0.1+d*2){ - polygon([[-(plugwmin/2 + bdx), 0], + polygon([[-(plugwmin/2 + bdx), bdy], [-(plugwmax/2 + tdx), plugh + tdy], [+(plugwmax/2 + tdx), plugh + tdy], - [+(plugwmin/2 + bdx), 0]]); + [+(plugwmin/2 + bdx), bdy]]); } } -module Bar(){ - spoolw = spoolwidth + spoolwidthgap*2; - barz = barradz * 0.5; +module Bar(){ ////toplevel + spoolw = spoolbarlen; biggestw = spoolw + 50; intersection(){ for (mir=[0,1]) { mirror([mir,0,0]) { - translate([0,0,barz]) { - scale([1,barrady,barradz]) translate([-1,0,0]) - rotate([0,90,0]) cylinder(r=1, h=spoolw/2+2, $fn=30); - translate([spoolw/2,0,0]) - rotate([0,90,0]) cylinder(r=guiderad, h=guidewidth, $fn=60); - } - translate([spoolw/2 + guidewidth, 0, 0]) + translate([spoolw/2, 0, 0]) Plug(); + translate([-1, -50, -50]) + cube([spoolw/2+1.1, 100, 100]); + } + } + difference(){ + translate([-biggestw/2, -50, 0]) + cube([biggestw, 100, 100]); + for (mir=[0,1]) { + mirror([mir,0,0]) + translate([axlepin_x, 0, -50]) + cylinder(r=AxlePin_holerad(), 100, $fn=15); } } - translate([-biggestw/2, -50, 0]) - cube([biggestw, 100, 100]); + translate([0,0,barz]) { + translate([-100,0,0]) + rotate([0,90,0]) cylinder(r=axlerad, h=200, $fn=30); + } } } -module Trestle(){ +module FtAxlePin(){ ////toplevel + AxlePin(axlerad, (axlerad + barwasherrad*2)/3 * 2); +} + +module AxleWasher(){ ////toplevel + Washer(axlerad, barwasherrad); +} + +module Trestle(){ ////toplevel legang = atan2(trestlebase/2, trestleheight); eplen = sqrt(trestleheight*trestleheight + trestlebase*trestlebase*0.25); topblockw = plugwmax + trestleplugd*2 + topblockthick*2; @@ -112,15 +151,18 @@ module Trestle(){ for (rot=[0,180]) { translate([0,0,plugl/2]) rotate([0,rot,0]) translate([0,0,-plugl/2]) { - translate([-(topblockw*0.25+1), - plugh + pindh - (pinmaxh - pinminh)*0.5, + translate([0, + plugh + pindh - (pinmaxh - pinminh)*0.75, (plugl - pinholebasew*2)/3]) { - translate([0,0,pinholebasew/2]) rotate([-90,0,0]) %Pin(); - rotate([0,90,0]) { - linear_extrude(height = topblockw*1.0+2) { - polygon([[-1.0 * pinholebasew, -0.01], - [-0.5 * pinholebasew, pinholeh], - [ 0 , -0.01]]); + translate([-(topblockw*0.25+1), 0, pinholebasew/2]) + rotate([-90,0,0]) %Pin(); + translate([-(topblockw+1), 0, 0]) { + rotate([0,90,0]) { + linear_extrude(height = topblockw*1.0+2) { + polygon([[-1.0 * pinholebasew, -0.01], + [-0.5 * pinholebasew, pinholeh], + [ 0 , -0.01]]); + } } } } @@ -129,7 +171,7 @@ module Trestle(){ } } -module Pin(){ +module Pin(){ ////toplevel rotate([90,0,90]) { hull(){ for (mir=[0,1]) { @@ -151,7 +193,40 @@ module Pin(){ } } -module TestKit(){ +module HubEnd(){ ////toplevel + thick = hubmainthick+hubbasethick; + difference(){ + union(){ + for (ang=[0 : 60 : 359]) { + rotate([0,0,ang]) { + translate([hubmainrad - hubwalls/2, -hubbasestalkwidth/2, 0]) + cube([hubbaserad - (hubmainrad - hubwalls/2), + hubbasestalkwidth, hubbasethick]); +// ExtenderPillars(length = hubmainrad-hubwalls/2, +// width = 10, +// height = hubbasethick + hubmainthick); + } + } + cylinder(r=axlerad+hubwalls, h=thick); + cylinder(r=hubmainrad-0.1, h=hubbaseweb); + difference(){ + cylinder(r=hubmainrad, h=thick, $fn=100); + translate([0,0,-1]) + cylinder(r=hubmainrad-hubwalls, h=thick+2); + } + difference(){ + cylinder(r=hubbaserad, h=hubbasethick, $fn=50); + translate([0,0,-1]) + cylinder(r=hubbaserad-hubwalls, h=hubbasethick+2); + } + } + translate([0,0,-1]) + cylinder(r=axlerad+axleslop, h=thick+2, $fn=50); + } +} + + +module TestKit(){ ////toplevel translate([30,0,0]) Pin(); translate([30,30,0]) Pin(); translate([0,40,0]) intersection(){ @@ -164,11 +239,34 @@ module TestKit(){ } } +module DemoSpool(){ + rotate([0,90,0]) translate([0,0,-spoolwidth/2]) + difference(){ + cylinder(r=spoolouterrad, h=spoolwidth); + translate([0,0,-1]) cylinder(r=spoolinnerrad, h=spoolwidth+2); + } +} + +module Demo(){ + Bar(); + for (mir=[0,1]) { + mirror([mir,0,0]) { + translate([spoolbarlen/2,0,0]) rotate([90,0,90]) Trestle(); + translate([spoolwidth/2 + hubbasethick + spoolinnerslop/4, 0, barz]) + rotate([0,90,0]) AxleWasher(); + translate([axlepin_x, 0, barz]) rotate([90,0,90]) FtAxlePin(); + } + } + %translate([0,0,barz]) DemoSpool(); +} + //Bar(); +//FtAxlePin(); +//AxleWasher(); //Trestle(); //Pin(); - -TestKit(); - +//TestKit(); //Plug(d=1); //ExtenderPillars(80,12,8, baseweb=true); +HubEnd(); +//Demo();