How to alter a ThreeJS Color using dat.gui
data:image/s3,"s3://crabby-images/b6283/b6283d6dab3a9d5fd6ceacdf08c7e1602be03f81" alt="Oscar de la Hera Gomez"
data:image/s3,"s3://crabby-images/c0386/c03864c1328e1b6a370d311c9d6201a48ab9ca43" alt="Two flowers that represent ReactJS and ThreeJS side by side. Beneath them sits the text "dat.gui color.""
A step by step guide on using dat.gui to change a Three.Color via a hex color code.
The proposed solution can be found on the main branch of our Open Source React, Typescript & ViteJS Starter Project.
git clone git@github.com:delasign/reactjs-3js-vitejs-starter-project.git
Step One: Setup the Project
data:image/s3,"s3://crabby-images/503b3/503b3f56846f43199c8caa720145de0cbba07dd9" alt="A screenshot of Chrome showing the shader on a plane and how the shader looks different thanks to the change in colors that we created using the GUI."
Follow the tutorial below to learn how to setup a Typescript & ViteJS project that works with a GLSL shader whose R, G, B color values can be adapted using dat.gui.
Step Two: Create the Hex Color Type
data:image/s3,"s3://crabby-images/d343f/d343f419ebae885bf53cc9e4710418d6de1be4ed" alt="A screenshot of VSCode showing the color type"
In the project, create a new Typescript type for the hex code.
Step Three: Create and Apply the Hex Color
data:image/s3,"s3://crabby-images/87d7a/87d7a8a9bf6ffff8973c90ccee3922acea9bdb49" alt="A screenshot of VSCode demonstrating how we created a hex color and applied it to a ThreeJS Color. Code available below."
In the file that contains the scene, create a new hex color of the type declared in Step 2 and apply it to a shader or geometry using code similar to that found below.
attribute = new THREE.Color(color.hex)
Step Four: Update the GUI
data:image/s3,"s3://crabby-images/7a9b1/7a9b1e861632f7ed205372d474b6c3ff73761f85" alt="A screenshot of VSCode showing how we updated the setupGUI function. Code available below."
Update the dat.gui to make use of a color which takes in the color declared in Step Three and through a listener applies it to a listener.
Sample code of how to do this is found below.
Step Five: Test
data:image/s3,"s3://crabby-images/c4d6e/c4d6e59771482dd58156966cf75e26c6ca491a9c" alt="A screenshot of chrome showing how we can now alter the geometries color using a color picker that changes a hex code. The hex code's color matches the color of the geometry."
Run the app and confirm that you can dynamically change the color of the shader using a color picker.
Looking to learn more about ReactJS and ThreeJS ?
Search our blog to find educational content on learning how to use ReactJS and ThreeJS.