Skip to content

Igor-Vuk/ultimate-threejs-boilerplate

Repository files navigation

THREE.JS BOILERPLATE

This is a starting point with most useful features already implemented.

How to use it?

  1. run npm install
  2. run npm run dev
  3. project will automatically open in your browser
  4. to view it on mobile, after running npm install look for the Network address in the console.
  5. run npm run build to build for deployment. This will also create stats.html file which is a Rollup Visualizer that we can open in any browser
  6. npm run preview to locally preview the production build

What does it include?

  • typescript

  • three, react-three/drei and react-three-fiber installed and configure

  • vite and vite.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 the curveMethod 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 using shaderMaterial 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 and prettierrc.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

What is the starting model being used?

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

About

three.js boilerplate to quickly start working on a project

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published