aboutsummaryrefslogtreecommitdiff
path: root/lib/dice.scad
blob: 05bb23e51725a701a3dcefc666f226b24726f0e8 (plain)
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
use <utils.scad>

module d4(size=false, side=false) {
    l = side ? side : s2s_d4(size);
    if (l == false) {
        echo("ERROR: d6: one of side or size should be defined");
    }
    r = sqrt(6)/4*l;
    c = r*2;
    difference() {
        intersection() {
            sphere(r=r*0.79, $fn=64);
            translate([0, 0, r-r/3]) cube(c, center=true);
            intersection_for ( i = [0:2] ) {
                rotate([0, 0, 120*i]) rotate([acos(1/3)+180, 0, 0]) 
                    translate([0, 0, r-r/3]) cube(c, center=true);
            }
        }
        rotate([180, 0, 0]) translate([0, 0, r/3]) child(0);
        rotate([acos(1/3)+180, 0, 0]) rotate([180, 0, 0]) translate([0, 0, r/3]) child(1);
        rotate([0, 0, 120]) rotate([acos(1/3)+180, 0, 0]) rotate([180, 0, 0]) translate([0, 0, r/3]) child(2);
        rotate([0, 0, 240]) rotate([acos(1/3)+180, 0, 0]) rotate([180, 0, 0]) translate([0, 0, r/3]) child(3);
    }
}

module d6(size=false, side=false) {
    l = side ? side : s2s_d6(size);
    if (l == false) {
        echo("ERROR: d6: one of side or size should be defined");
    }
    difference() {
        intersection() {
            cube(l, center=true);
            sphere(l*0.79);
        }
        translate([0, 0, l/2]) child(0);
        rotate([90, 0, 0]) translate([0, 0, l/2]) child(1);
        rotate([0, 90, 0]) translate([0, 0, l/2]) child(2);
        rotate([-90, 0, 0]) translate([0, 0, l/2]) child(3);
        rotate([0, -90, 0]) translate([0, 0, l/2]) child(4);
        rotate([180, 0, 0]) translate([0, 0, l/2]) child(5);
    }
}

module d8(size=false, side=false) {
    l = side ? side : s2s_d8(size);
    if (l == false) {
        echo("ERROR: d6: one of side or size should be defined");
    }
    r = sqrt(2)/2*l;
    c = r*2;
    i_r = sqrt(6)/6*l;
    difference() {
        intersection() {
            sphere(r*0.86, $fn=64);
            cube([c, c, i_r*2], center=true);
            intersection_for ( i = [0:2] ) {

                rotate([0, 0, 120*i]) rotate([acos(-1/3), 0, 0]) cube([c, c, i_r*2], center=true);
            }
        }
        translate([0, 0, i_r]) child(0);
        rotate([acos(-1/3), 0, 0]) translate([0, 0, i_r]) child(1);
        rotate([0, 0, 120]) rotate([acos(-1/3)+180, 0, 0]) translate([0, 0, i_r]) child(2);
        rotate([0, 0, -120]) rotate([acos(-1/3)+180, 0, 0]) translate([0, 0, i_r]) child(3);
        rotate([0, 0, -120]) rotate([acos(-1/3), 0, 0]) translate([0, 0, i_r]) child(4);
        rotate([0, 0, 120]) rotate([acos(-1/3), 0, 0]) translate([0, 0, i_r]) child(5);
        rotate([acos(-1/3)+180, 0, 0]) translate([0, 0, i_r]) child(6);
        rotate([180, 0, 0]) translate([0, 0, i_r]) child(0);
    }
}