-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathstar_sphere.scad
67 lines (55 loc) · 1.56 KB
/
star_sphere.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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
include <starmap.scad>;
/**
* Draw rods for each star, sized by the apparent magnitude from Earth
*
* Gnu Public License 3.0 https://www.gnu.org/licenses/gpl-3.0.en.html
*/
rodRadius = 100;
rodInnerRadius = 95;
baseRodRadius = 2;
minimumRodRadius = 0.5; // Minimum radius for magnitude 6.5 stars
starFirst = 0;
starCount = 8911;
$fn = 20;
/**
* Draw a rod representing a star
* @param ra the Right Ascension of the star
* @param dec the declination of the star
* @param mag the apparent magnitude of the star
*/
module starRod(ra, dec, mag) {
theta = 15 * ra; // Degrees
phi = 90 - dec; // Degrees from vertical
delta = baseRodRadius - minimumRodRadius;
radius = baseRodRadius - (mag / 6.5) * delta;
rotate(a = [0, 0, theta])
rotate(a = [phi, 0, 0])
translate([0,0,rodInnerRadius])
cylinder(h=rodRadius - rodInnerRadius, r=radius, center=false);
}
/**
* Add rods for a given number of stars
* @param starFirst the index of the first star to output
* @param starCount the number of stars
*/
module starRods(starFirst, starCount) {
for (star = [starFirst:starFirst + starCount - 1]) {
if (star <= 8911) {
echo("Star ",star);
starRod(stars[star][0], stars[star][1], stars[star][2]);
}
}
}
/**
* Subtract the star rods from a spherical shell
*
* Gnu Public License 3.0 https://www.gnu.org/licenses/gpl-3.0.en.html
*/
rodLength = 100;
shellRadius = 99;
shellThickness = 5;
difference() {
sphere(r=shellRadius, center=true, $fn=100);
sphere(r=shellRadius - shellThickness, center=true, $fn=100);
starRods(0,8911);
}