This is a starting point with most useful features already implemented.
- run
npm install
- run
npm run dev
- project will automatically open in your browser
- to view it on mobile, after running
npm install
look for the Network address in the console. - run
npm run build
to build for deployment. This will also createstats.html
file which is a Rollup Visualizer that we can open in any browser npm run preview
to locally preview the production build
-
typescript
-
three
,react-three/drei
andreact-three-fiber
installed and configure -
vite
andvite.config.js
file.Rollup
is used for bundling -
leva
GUI installed and configured to be used with basic features needed for webgl. Make your scene perfect using leva controls for:- canvas control
- camera control
- controls control
- directional light control
- shadow camera control
- soft shadow control
- environment map control
- background control
- axes helper control
- grid helper control
- performance monitor(Perf) control
To show/hide the GUI press "h" on the keyboard.
This features can be easily turned off/on or changed.
Leva also exports
set
function that can be used to control it outside of GUI -
preparation
for easy loading and implementation:- model loading - takes compressed and normal version (.glb),
- texture loading - add any texture (diffuse, AO...),
- environment map loading
- action, morph, skinned animation loading - just play different type of animations
- curve loading and follow path - by loading
.json
file with vertices coordinate and calling thecurveMethod
function we can load curves as a mesh or make object follow them (example included) - assets preloading - assets like model, texture, hdr... are preloaded so that app starts quicker
-
Custom shaders loading
- create your own custom shaders. Ability to load.glsl
files is added to vite. Basic fragment and vertex shader example is added and loaded usingshaderMaterial
from drei for ease of use with react components. Hot reload for fragment and vertex shader files is also implemented. -
Physics
- implement physics easy using react-three-rapier library. -
Custom collection names
- render specific model collections in every components based on custom properties -
Suspense
for loading included with option to use fallback or Loader from drei -
eslint
and.eslintrc.cjs
configured for linting the files -
prettier
andprettierrc.json
configured for code formatting- recommended VSCode extensions are: ESlin and Prettier ESLint in order to make linting and formatting live while typing
-
index.css
file for styling
Starting model is a simple model made in Blender exported with Draco compression and imported in three.js. We are also loading basic diffuse texture and environment map
Model contains morph(Shape key) and normal keyframes animation