data:image/s3,"s3://crabby-images/037de/037de1baaa736b9494fe71e0d125bd902057da09" alt=""
This is what it looks like when finished:
data:image/s3,"s3://crabby-images/018fe/018fe347d9d6e0ca6563e7dcb6b971f30fc204ca" alt=""
First we want to calculate the angle between any 2 adjacent ⬠ faces, β in the above diagram. There is a generic relation between β and ⍺. In our specific case of dodecahedron ⍺ = 108º. So β = 116.7º.
draw the bottom ⬠ :
data:image/s3,"s3://crabby-images/fa43d/fa43d06d2f2721c3d40660d59ae2c9b8e9ef062c" alt=""
the 1st ⬠ adjacent to the bottom ⬠ :
data:image/s3,"s3://crabby-images/f367f/f367f0668e3ee57675d5a219c25a5d47253cc07e" alt=""
the 2nd ⬠ adjacent to the bottom ⬠ :
data:image/s3,"s3://crabby-images/563ad/563ad8471dc9c406dfe0f7574eed31f88365be6c" alt=""
the 3rd ⬠ adjacent to the bottom ⬠ :
data:image/s3,"s3://crabby-images/7e312/7e3123a2e940460ed5cc4a3aa37f841e9462644f" alt=""
draw the 4th ⬠ adjacent to the bottom ⬠ :
data:image/s3,"s3://crabby-images/07e06/07e0607e003df6a5f5e9a67e9dd2a019fa36d687" alt=""
the last ⬠ adjacent to the bottom ⬠ :
data:image/s3,"s3://crabby-images/b060b/b060bee307a47f70baf2e1a76dedbfe15ba334a0" alt=""
the top ⬠ facing the bottom ⬠ :
data:image/s3,"s3://crabby-images/b9b74/b9b740e3509a2463050e37d48e1edb27ab25cecd" alt=""
the 1st ⬠ adjacent to the top ⬠ :
data:image/s3,"s3://crabby-images/7f46e/7f46eeb1139d5c98f2c915884f15f3903c914ee3" alt=""
the 2nd ⬠ adjacent to the top ⬠ :
data:image/s3,"s3://crabby-images/5f5be/5f5beaa1aa6b494ad0fca72e9505777639fee8e0" alt=""
the 3rd ⬠ adjacent to the top ⬠ :
data:image/s3,"s3://crabby-images/f6e6c/f6e6c38eaeb2eb9f557f6d65b0c060fc12ab1275" alt=""
the 4th ⬠ adjacent to the top ⬠ :
data:image/s3,"s3://crabby-images/2dea9/2dea9a78e750c8d1e74fa635801dacc420373653" alt=""
let ang = 0;
let r = 100;
let s,t,w,h;
function setup() {
createCanvas(960, 960, WEBGL);
stroke(255);
strokeWeight(3);
s = 2 * r * sin(PI/10);
t = r * cos(TWO_PI/10);
w = 2 * asin(sin(3*PI/10) /
sin(3*PI/5)); //116.7º
let GE = 2*r*sin(PI/5)*sin(PI/5);
let EH = r + t - GE;
h = sin(w) * (2 * EH + GE);
}
function penta(){
push();
translate(t,0,0);
beginShape();
for(let a = 0; a < TWO_PI;
a += TWO_PI/5) {
let x = r*cos(a);
let y = r*sin(a);
vertex(x, y);
}
endShape(CLOSE);
pop();
}
function half(){
push();
translate(-t,0,0);
penta();
pop();
push();
for(let i=0;i<5;i++){
rotateZ(TWO_PI/5);
push();
translate(-t,0,0);
rotateY(-w);
penta();
pop();
}
pop();
}
function draw() {
ang += 0.01;
background(0);
rotateY(ang);
rotateX(ang*0.5);
rotateZ(ang*0.2);
push();
fill(0,0,200,130);
half();
pop();
push();
fill(200,0,200,130);
translate(0,0,h);
rotateY(PI);
half();
pop();
}
ch 2.2 The Regular Polyhedra p22 of
data:image/s3,"s3://crabby-images/4b169/4b1693c8e66fb6f17c369a3452af016982ebf09d" alt=""