use ; txt = "3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679821480865132823066470938446095505822317253594081284811174502841027019385211055596446229489549303819644288109756659334461284756482337867831652712019091456485669234603486104543266482133936072602491412737245870066063155881748815209209628292540917153643678925903600113305305488204665213841469519415116094330572703657595919530921861173819326117931051185480744623799627495673518857527248912279381830119491298336733624406566430860213949463952247371907021798609437027705392171762931767523846748184676694051"; radius = 20; font_name = "Liberation Sans:style=Bold"; font_size = 2.5; txt_extrude = radius * 0.125; txt_scale = 1.15; ball = true; $fn = 48; bauer_text_sphere(radius, font_name, font_size, txt_extrude, txt_scale, ball); module bauer_text_sphere(radius, font_name, font_size, txt_extrude, txt_scale, ball) { n = len(txt); pts = bauer_spiral(n, radius); if(ball) { render() sphere(radius * 0.9); } /* Based on Bauer's spiral: Bauer R. Distribution of points on a sphere with application to star catalogs. Journal of Guidance, Control, and Dynamics. 2000;23(1):130–137 */ for(i = [0:n - 1]) { x = pts[i][0]; y = pts[i][1]; z = pts[i][2]; ya = atan2(z, sqrt(x * x + y * y)); za = atan2(y, x); render() translate(pts[i]) rotate([0, -ya, za]) rotate([90, 0, -90]) linear_extrude(txt_extrude, scale = txt_scale) mirror([-1, 0, 0]) text(txt[i], size = font_size, font = font_name, valign = "center", halign = "center"); } }