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
72
73
74
75
76
use scad_tree::prelude::*;
fn main() {
let segments: u64 = 36;
let slices: u64 = 12;
let mut cup_blank_profile = Pt2s::new();
cup_blank_profile.push(Pt2::new(0.0, 0.0));
cup_blank_profile.append(&mut dim2::cubic_bezier(
Pt2::new(40.0, 0.0),
Pt2::new(40.0, 33.0),
Pt2::new(60.0, 66.0),
Pt2::new(60.0, 100.0),
slices,
));
cup_blank_profile.push(Pt2::new(0.0, 100.0));
let cup_blank = rotate_extrude!(angle=360.0, convexity=2, fn=segments,
polygon!(cup_blank_profile);
);
let mut cup_inner_profile = Pt2s::new();
cup_inner_profile.push(Pt2::new(0.0, 3.0));
cup_inner_profile.append(&mut dim2::cubic_bezier(
Pt2::new(37.0, 3.0),
Pt2::new(37.0, 33.0),
Pt2::new(57.0, 66.0),
Pt2::new(57.0, 103.0),
slices,
));
cup_inner_profile.push(Pt2::new(0.0, 103.0));
let cup_inner = rotate_extrude!(angle=360.0, convexity=1, fn=segments,
polygon!(cup_inner_profile);
);
let handle_path = dim3::cubic_bezier(
Pt3::new(37.0, 20.0, 0.0),
Pt3::new(70.0, 30.0, 0.0),
Pt3::new(120.0, 90.0, 0.0),
Pt3::new(57.0, 90.0, 0.0),
segments,
);
let handle_profile = dim2::rounded_rect(8.0, 20.0, 2.5, segments, true);
let mut handle = Polyhedron::sweep(&handle_profile, &handle_path, 0.0, false);
handle.rotate_x(90.0);
let cup = cup_blank + handle.into_scad_with_convexity(2) - cup_inner;
cup.save("output/cup.scad");
}