X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=reprap-play.git;a=blobdiff_plain;f=cable-hole-trunking-cover.scad;h=ed2bc31534d42b20673b0fbf58d245991d483ba8;hp=e6faa8ee283c9998a6bbbe7394f03668baeb759a;hb=c827170d69910df04bc8b620f2ed53ed5164e633;hpb=3292cf260a1d1c9d393324ba15a5cc32f59acc21 diff --git a/cable-hole-trunking-cover.scad b/cable-hole-trunking-cover.scad index e6faa8e..ed2bc31 100644 --- a/cable-hole-trunking-cover.scad +++ b/cable-hole-trunking-cover.scad @@ -1,25 +1,30 @@ // -*- C -*- -holedia = 25.4; +holedia = 25; +tapethick = 1.5; +cutoutsz= 15; +innerz = 11; -sidewidth = 5; -tapewidth = 7; +sidesflatbase = 2; +endsflatbase = 8; -innerz = 10; +basex = holedia + endsflatbase*2; +basey = holedia + sidesflatbase*2; -basex = holedia + sidewidth*2; -basey = holedia + tapewidth*2; - -bevelz = 3; +bevely = 2.75; bevelslope = 0.75; -bevely = bevelz * bevelslope; +bevelz = bevely / bevelslope;; +basebevelt = 3; sideslop = 0.5; basebaset = 2; -basebevelt = 3; +sidewallt = 2; +lidt = 1.3; endwallt = 2; +zslop = 0.75; +endslop = 0.75; module sheared_cube(sz, xperz, yperz) { multmatrix([[1,0,xperz,0], @@ -29,33 +34,86 @@ module sheared_cube(sz, xperz, yperz) { cube(sz); } -module Base(){ +module Base(cutouty){ + echo(cutouty); difference(){ union(){ for (mir=[0,1]) mirror([0,mir,0]) { translate([0, basey/2 - basebevelt, 0]) sheared_cube([basex, basebevelt, bevelz], 0, bevelslope); cube([basex, basey/2, basebaset]); - rotate([90, 0, 90]) - linear_extrude(height=endwallt) - polygon([[-0.1, 0], - [basey/2, 0], - [basey/2 + bevely, bevelz], - [basey/2 + bevely, innerz], - [-0.1, innerz]]); } } translate([basex/2, 0, -1]) cylinder(r=holedia/2, h=bevelz+2); } + rotate([90, 0, 90]) { + linear_extrude(height=endwallt) { + difference(){ + for (mir=[0,1]) mirror([mir,0,0]) { + polygon([[-0.1, 0], + [basey/2, 0], + [basey/2 + bevely, bevelz], + [basey/2 + bevely, innerz], + [-0.1, innerz]]); + } + translate([cutouty, 0]) + square(size=[cutoutsz, 3*innerz], center=true); + } + } + } } module Lid(){ + lidx = basex + endslop + endwallt; for (mir=[0,1]) mirror([0,mir,0]) { - translate([0, basey/2 + sideslop, 0]) - sheared_cube([basex, basebevelt, bevelz], 0, bevelslope); + translate([0, basey/2 + sideslop + bevely, 0]) + rotate([90,0,90]) + linear_extrude(height = lidx) + polygon([[0, 0], + [-bevely, 0], + [0, bevelz], + [0, innerz + lidt + zslop], + [sidewallt, innerz + lidt + zslop], + [sidewallt, -tapethick], + [0, -tapethick]]); + translate([0, -1, innerz + zslop]) + cube([lidx, 1 + basey/2 + sideslop + bevely + sidewallt, lidt]); + translate([basex + endslop, -1, -tapethick]) + cube([endwallt, 1 + basey/2 + sideslop + bevely + sidewallt, + tapethick + innerz + zslop + 0.1]); } } -Base(); -Lid(); +module LidT(){ ////toplevel + rotate([180,0,0]) Lid(); +} + +module BaseCMid(){ ////toplevel + Base(0); +} + +module BaseCTop(){ ////toplevel + Base(basey/2 + bevely - cutoutsz/2); +} + +module BaseCBot(){ ////toplevel + Base(-(basey/2 + bevely - cutoutsz/2)); +} + +module BaseCNone(){ ////toplevel + Base(basey); +} + +module Demo(){ ////toplevel + BaseCTop(); + %Lid(); +} + +//BaseCTop(); +//BaseCMid(); +//BaseCBot(); +//BaseCNone(); +//Lid(); +//LidT(); +//Demo();