How to create a React, Typescript & ThreeJS GLSL Vite Project
data:image/s3,"s3://crabby-images/b6283/b6283d6dab3a9d5fd6ceacdf08c7e1602be03f81" alt="Oscar de la Hera Gomez"
data:image/s3,"s3://crabby-images/f4abf/f4abf8adead509718f866207630d7c75ecafa92e" alt="Three flowers that represent ReactJS, ThreeJS & ViteJS side by side. Beneath them sits "Starter Project.""
A step by step guide on creating a GLSL powered React, Typescript & 3JS ViteJS project.
Step One: Create Vite React & Typescript Project
data:image/s3,"s3://crabby-images/4d316/4d3169a6e0bb991a8dac0b227e5c6ea18f40dff1" alt="A screenshot of Terminal showing how to setup a React & Typescript, ViteJS project."
Open Terminal and create a project in the chosen directory using the line:
yarn create vite
Give your project a name, select the React framework with the Typescript variant.
Once its generated, set the current directory to that of the project.
cd starter-project
Step Two: Add Dependencies
data:image/s3,"s3://crabby-images/ce839/ce839761a3f8c69384c229a2a255d97757832a3f" alt="A screenshot of the dependencies that we added to the ViteJS project."
Run the following line in terminal
yarn add three; yarn add @types/three; yarn add vite-plugin-glsl; yarn add styled-components; yarn add @types/node
Step Three: Start the project
data:image/s3,"s3://crabby-images/57fee/57feea26b10f40c33c0b4df4f75361fb71e2fda4" alt="A screenshot of the Package.json showing how we updated dev to start."
In the Package.json, update the "dev" script to "start."
Then, in Terminal, run the line below:
yarn start
Step Four: Create the first ThreeJS scene
data:image/s3,"s3://crabby-images/37386/37386f73c83fd8a7ced2aef5b9fe0267cd8729ae" alt="A screenshot of Chrome showing that the plane is now using the shader that we offer in this tutorial."
Follow the tutorial below to create a ThreeJS scene that exhibits a plane that uses a shader.
Step Five: Update the Shader to GLSL
data:image/s3,"s3://crabby-images/bca1a/bca1af04b97501dc6d3923d6873bf6673ea0cc37" alt="A screenshot of VSCode showing how we updated the vertex and fragment files to glsl."
Convert the vertex and fragment shader to GLSL.
Step Six: Update the Imports
data:image/s3,"s3://crabby-images/8500a/8500a13172a0b6973194857ecd0e1e1383bbb5e0" alt="A screenshot of VSCode showing how we updated the imports to use .glsl."
In the Scene, update the imports to .glsl.
Step Seven: Update the Vite Config
data:image/s3,"s3://crabby-images/fdd73/fdd7354e0b9c1a1c165bf759965c71fba903ffeb" alt="A screenshot of VSCode showing how we updated the vite.config.js file to include the vite glsl plugin."
Update the vite.config.js file to make use of the vite-plugin-glsl.
Step Eight: Add the GLSL declaration
data:image/s3,"s3://crabby-images/5eea0/5eea09dca07bc3f7d00ac1216ed488afcd7f26e6" alt="A screenshot of VSCode showing the index.d.ts file."
At the root of the project, create a index.d.ts file and add the declarations for the GLSL files.
Step Nine: Update the TSConfig
data:image/s3,"s3://crabby-images/809eb/809eb5ba071e1634ce1f81b74c4ee25ebe6d214e" alt="A screenshot of VSCode that shows the TSConfig file which highlights that the index.d.ts is now included. On the left side it shows that the error from the import no longer exists."
Update the TSConfig to include the index.d.ts file. This should resolve the error in the Scene imports.
Step Ten: Test
data:image/s3,"s3://crabby-images/37386/37386f73c83fd8a7ced2aef5b9fe0267cd8729ae" alt="A screenshot of Chrome showing that the plane is now using the shader that we offer in this tutorial."
Confirm that the scene renders as expected.
Looking to learn more about ReactJS and ThreeJS ?