-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsudigen.scad
executable file
·50 lines (40 loc) · 1.49 KB
/
sudigen.scad
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
// sudigen.scad
include <sudiconfig.scad>;
echo ("If the magic numbers in sudiconfig are small [smooth]");
echo ("then generating is slow, wait for the image to appear");
echo ("When the script is ready, 'Compile and Render' with F6");
echo ("Then export as DXF from the 'File' menu for a 2D vector file");
// build the first panel of a sudiball then lay it down
// and cut takes a slice through the xy plane at z=0
projection(cut=true)
// lay the first panel back down
rotate([-relative_tilt-90,0,0])
translate(-centerofrotation)
// remove the light path and the hole pattern fron the panel(s)
difference() {
intersection() { // isolate the sudiball
// the outside shape of the ball
translate(centerofrotation)
sphere(ball_r);
// position the first panel
sheet([2*ball_r,thickness,2*ball_r],[relative_tilt,0,0],centerofrotation);
}
union(){ // stuff to be removed from the inside
union(){
//the light path to be removed, as defined in sudiconfig.scad
lightpath();
// the hole pattern in first sheet
about([relative_tilt,0,0],centerofrotation)
holepattern(hp_patdia,hp_holedia,hp_holecount,hp_holedepth);
}
// the other panels alternate as inner & outter voids
// intersect_for(rot=[delta:delta:359.9]){
for(rot=[delta:delta:359.9]){
if((rot/delta)%2){
disk(thickness,ball_r-3*thickness,[relative_tilt,0,rot],centerofrotation);
}else{
washer(thickness,ball_r,ball_r-3*thickness,[relative_tilt,0,rot],centerofrotation);
}
}
}
}