How to write a spot light shader in GLSL
data:image/s3,"s3://crabby-images/b6283/b6283d6dab3a9d5fd6ceacdf08c7e1602be03f81" alt="Oscar de la Hera Gomez"
data:image/s3,"s3://crabby-images/9de7a/9de7a40e2d1804368245614f0fd653db83abd3db" alt="Two flowers that represent ReactJS and ThreeJS with the text "Spot Light Shader" beneath them."
A step by step guide for coding a spot light shader in Typescript, ReactJS, ThreeJS, ViteJS and GLSL.
The solution that we carried out below can be found on the tutorial/three-js/light-shaders branch of our Open Source React, Typescript & ViteJS Starter Project.
To clone this project, paste the code found below in Terminal.
git clone git@github.com:delasign/reactjs-3js-vitejs-starter-project.git
The tutorial was made possible thanks to the work of OGLDev which provided the code for spot lights at the tutorial linked below.
Step One: Create a Point Light
data:image/s3,"s3://crabby-images/14745/1474584635252bd9d63dd12f9af1abea84780b72" alt="A screenshot of Chrome showing the point light in action."
A spot light is a point light with a direction and a cutoff.
Follow the tutorial below to learn how to setup a Typescript & ViteJS project that works with a Point Light GLSL shader whose R, G, B color values can be adapted using dat.gui.
Step Two: Create the Typescript Type
data:image/s3,"s3://crabby-images/20f15/20f15bbcdbfda6368780929b0dfc318bc7ad7072" alt="A screenshot of VSCode showing the SpotLight typescript type."
Create a file in your project called SpotLight.tsx and paste in the code found below.
We recommend that you place this under a types folder.
Step Three: Create the GLSL Struct
data:image/s3,"s3://crabby-images/5d612/5d612a1767f810f013091062783c92f3d726bc70" alt="A screenshot of VSCode highlighting the Spot Light GLSL struct."
In the structs.glsl file, add the Spotlight struct using the code below.
Step Four: Create the GLSL Spot Light Functionality
data:image/s3,"s3://crabby-images/c7c71/c7c712998123388d339d1b156a2c718469bcb062" alt="A screenshot of VSCode highlighting the GLSL functionality for the Spotlight."
In the functionality.glsl file, add the Spot Light functionality using the code below.
Step Five: Create the GLSL Spot Light Shader
data:image/s3,"s3://crabby-images/fdfa1/fdfa18366c2c18b34db15a07da4b71bb5c5fe8c4" alt="A screenshot of VSCode showing the spot light vertex and fragment shader."
Create a vertex.glsl and fragment.glsl file for your shader.
We recommend that you place these files under a spotLight within a shaders folder.
Vertex Shader
Fragment Shader
Step Six: Update the Scene
data:image/s3,"s3://crabby-images/ebf44/ebf44a91c67aab46c7e9a198acce42efc289bea8" alt="A screenshot of VSCode showing the updates we made to the scene."
Update the scene to make use of the vertex and fragment shader that you created in Step Four.
Make sure that the shader material includes the spotLight and geometryBaseColor required for the shader created in Step Four.
Step Seven: Test
data:image/s3,"s3://crabby-images/807d0/807d08c6e1692dad9c709106447999316f8e0eb8" alt="A screenshot of Chrome showing the Spot Light in action."
Run the code and make sure that everything works as expected.
If you wish to include dat.gui sliders like we have, consult the tutorials below.
Looking to learn more about ReactJS and ThreeJS ?
Search our blog to find educational content on learning how to use ReactJS and ThreeJS.