data:image/s3,"s3://crabby-images/bdb06/bdb06d2152278f71ac676bdb8265e56d05bf96b1" alt=""
This is what it looks like when finished:
data:image/s3,"s3://crabby-images/7e844/7e84405a5cb23e1e6a5744ae4c4fd43863e6d9cd" alt=""
Our goal is to let octahedron ABCDEF spin slowly around its center, which is also the origin of our 3D coordinates space.
draw a sphere centered at origin
data:image/s3,"s3://crabby-images/8492b/8492b39d92d29fda513e78d372f2ebd40d0ffa17" alt=""
draw the 1st face ABF
data:image/s3,"s3://crabby-images/29da1/29da14924a8db2566f6d2eb76b068b8fbd62b793" alt=""
draw the 2nd face BCF
data:image/s3,"s3://crabby-images/3f62e/3f62e5cb580198de9ab371869a64878ee6657cff" alt=""
data:image/s3,"s3://crabby-images/8f772/8f7726f8a5ad1cee116624764b4e49352bca825d" alt=""
draw the 3rd face CDF
data:image/s3,"s3://crabby-images/4e2b5/4e2b5068b7439cd8057584085f444dca1a3cd390" alt=""
file octahedron.html
<!DOCTYPE html>
<html lang="en">
<head>
<title>Octahedron</title>
<meta name="viewport"
content="width=device-width,
initial-scale=1" />
<script src=
"https://cdnjs.cloudflare.com/
ajax/libs/p5.js/1.5.0/
p5.min.js">
</script>
<style>
canvas {
width: 100% !important;
height: 100% !important;
}
</style>
<meta charset="utf-8" />
</head>
<body>
<p>
Octahedron
</p>
<script src=
"/scripts/octahedron.js">
</script>
</body>
</html>
file octahedron.js
let ang = 0;
let u = 500;
function setup() {
createCanvas(960, 960, WEBGL);
stroke(255);
strokeWeight(3);
}
function draw() {
background(0);
normalMaterial();
rotateY(ang);
rotateX(ang*0.5);
rotateZ(ang*0.2);
strokeWeight(15);
sphere(70);
let a = [ u, 0, 0];
let b = [ 0, 0, u];
let c = [-u, 0, 0];
let d = [ 0, 0, -u];
let e = [ 0, u, 0];
let f = [ 0, -u, 0];
stroke(255);
strokeWeight(3);
triangleShape(a,b,f,200,0,0);
triangleShape(b,c,f,0,200,0);
triangleShape(c,d,f,0,0,200);
triangleShape(d,a,f,200,200,0);
triangleShape(a,b,e,200,0,200);
triangleShape(b,c,e,0,200,200);
triangleShape(c,d,e,0,100,100);
triangleShape(d,a,e,200,200,0);
ang += 0.01;
}
function triangleShape(i,j,k,r,g,b){
fill(r, g, b, 100);
beginShape();
vertex(i[0], i[1], i[2]);
vertex(j[0], j[1], j[2]);
vertex(k[0], k[1], k[2]);
endShape(CLOSE);
}
ch 2.2 The Regular Polyhedra p21 of
data:image/s3,"s3://crabby-images/85b8e/85b8e547dc3238eee5c7ad0177ace2ca54327b11" alt=""