How to color the faces of a box geometry using a shader in ThreeJS
data:image/s3,"s3://crabby-images/b6283/b6283d6dab3a9d5fd6ceacdf08c7e1602be03f81" alt="Oscar de la Hera Gomez"
data:image/s3,"s3://crabby-images/aec0d/aec0d63fba3c76a46d85ab1f611fb78799f41847" alt="Two flowers that represent React and ThreeJS, beneath them sits the text "Box Geometry Colored Faces Shader.""
A step by step tutorial on coloring the faces of a box geometry using a shader in ThreeJS using ReactJS.
We recommend that you clone our Open Source React-Redux Starter Project, checking out the tutorial/three-js/starter branch and carrying out the steps below. The changes can be found on the tutorial/three-js/cube-colored-faces-shader-material branch.
Box Geometry Faces & Vertices
data:image/s3,"s3://crabby-images/f295a/f295ae453afc0252dff260d9d549a4b9bf5c5e8f" alt="An illustration that demonstrates how the vertices are broken down by face on a box geometry."
The diagram above describes what vertex applies to what face within a box geometry and the color that we applied to each face as part of this tutorial.
Tutorial
Step One: Setup the Project
data:image/s3,"s3://crabby-images/3fd35/3fd353f76361efb8eabd7d4b3dd495c46e2c736f" alt="A screenshot of Chrome showing that the orbit controls work and that the cube can now be seen from different angles and distances."
Follow the tutorials below to learn how to create a ThreeJS project that implements a shader on a box geometry, which can be explored using Orbit Controls.
Step Two: Set the Vertex Colors
data:image/s3,"s3://crabby-images/3f6fa/3f6fade41531c85cf8649ee1f828bfd0f22a3934" alt="A screenshot of VSCode showing how we created a Float32Array that holds the colors for each vertex."
Create a Float32Array array that holds the 24 colors for the cube.
If you wish to set specific colors for each vertex, consult the diagram above the tutorial.
Step Three: Set the Color Attribute
data:image/s3,"s3://crabby-images/85390/85390d51ab2514c2c9972555c32d261072a03b56" alt="A screenshot of VSCode showing how to set the colors as an attribute of the shader."
Apply the colors to the shader by setting them as an attribute using code similar to the one below.
const colorAttribute = new THREE.BufferAttribute(colors, 3); // 3 components (RGB) per vertex
geometry.setAttribute("aVertexColor", colorAttribute);
Step Four: Update Shaders
data:image/s3,"s3://crabby-images/d3e0f/d3e0f9fbb1ad7be3e2c337bc47985453e9246950" alt="A screenshot of VSCode showing the updated Vertex and Fragment shader."
Update the vertex and fragment shader to work with the attribute.
Vertex Shader
Fragment Shader
Step Five: Test
data:image/s3,"s3://crabby-images/462d4/462d43af85e6d332716ce56883fd590f065f9ee0" alt="A screenshot of Chrome showing a cube with colored faces that match the colors we set for the vertices in this tutorial."
Run the code and confirm the shader works as expected.
Looking to learn more about ReactJS and ThreeJS ?
Search our blog to find educational content on learning how to use ReactJS and ThreeJS.