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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
extern crate nalgebra as na;
use scad_macros::*;
use scad_element::ScadElement::*;
use scad_element::CircleType;
use scad_object::*;
pub fn centered_cube(size: na::Vector3<f32>, centering: (bool, bool, bool)) -> ScadObject
{
let (x,y,z) = centering;
let mut offset = vec3(0.,0.,0.);
offset.x = if x {size.x} else {0.};
offset.y = if y {size.y} else {0.};
offset.z = if z {size.z} else {0.};
offset /= -2.;
let mut translation = ScadObject::new(Translate(offset));
translation.add_child(ScadObject::new(Cube(size)));
translation
}
pub fn centered_square(size: na::Vector2<f32>, centering: (bool, bool)) -> ScadObject
{
let (x,y) = centering;
let offset = vec2(
if x {size.x} else {0.},
if y {size.y} else {0.}
) / -2.;
let mut translation = ScadObject::new(Translate2d(offset));
translation.add_child(ScadObject::new(Square(size)));
translation
}
pub fn centered_cylinder(height: f32, size: CircleType) -> ScadObject
{
let mut translation = ScadObject::new(Translate(vec3(0., 0., -height / 2.)));
let cylinder = ScadObject::new(Cylinder(height, size));
translation.add_child(cylinder);
translation
}
#[cfg(test)]
mod tests
{
extern crate nalgebra as na;
use super::*;
#[test]
fn cube_center_x()
{
let obj = centered_cube(vec3(1., 1., 1.), (true, false, false));
assert_eq!(obj.get_code(), "translate([-0.5,0,0])\n{\n\tcube([1,1,1]);\n}");
}
#[test]
fn cube_center_yz()
{
let obj = centered_cube(vec3(1., 2., 4.), (false, true, true));
assert_eq!(obj.get_code(), "translate([0,-1,-2])\n{\n\tcube([1,2,4]);\n}");
}
#[test]
fn square_center()
{
let obj = centered_square(vec2(2., 4.), (true, true));
assert_eq!(obj.get_code(), "translate([-1,-2])\n{\n\tsquare([2,4]);\n}");
}
#[test]
fn cylinder_center()
{
let obj = centered_cylinder(10., CircleType::Radius(5.));
assert_eq!(obj.get_code(), "translate([0,0,-5])\n{\n\tcylinder(h=10,r=5);\n}");
}
}