/three-boilerplate

A modern boilerplate for three.js projects

Primary LanguageJavaScriptMIT LicenseMIT

three-boilerplate

A modern boilerplate for three.js projects 🎉

I whipped this up as a convenient starting point that will make three.js and shader development easier. Clone and you're ready to go with webpack, babel, GLSLify, a hot reloading dev server and a basic three.js scene including some extremely basic GLSLified shaders.

Installation

I find it easist to create new projects based on this repo with a little shell script. If you drop this in your .bashrc or similar, you'll be good to go.

alias NewThreeProject="git clone git@github.com:elifitch/three-boilerplate.git && rm -rf ./three-boilerplate/.git && mv ./three-boilerplate "

$ NewThreeProject my-project-name

If you like to have three.js projects in a monorepo, you can do the same thing in an NPM script.

"new-project": "git clone git@github.com:elifitch/three-boilerplate.git && rm -rf ./three-boilerplate/.git && mv ./three-boilerplate "

$ npm run new-project my-project-name

Usage

  • npm run start => fires up the dev server and watches files for changes
  • npm run build => normal build with babel and all that
  • npm run build-simple => includes three.js from cdnjs, doesn't transpile. Great for Codepen.

Three.js modules

Three.js includes a lot of helpful modules in an examples/ directory. These are aliased in our webpack config so you don't have to import them via the full path in every file. You can add to or modify these aliases in /webpack/three-modules.config.js.

Environment Variables

There are a few environment variables you can use to change the build process

  • ASSET_ENV="http://my-asset-domain.com/" npm run build => Sets webpack publicPath.
  • ROOT_RESOURCES=true npm run build => Outputs 3d models at the root of /dist instead of in a folder. This will make sure your code references resources at eactly puplicPath/fileUrl, instead of publicPath/someFolder/fileUrl which might give you a 404. Super useful when using codepen asset management.

Features

  • Three.js
  • GLSLify for easy shader development
  • Support for obj/mtl loading
  • GSAP for easy animation
  • Babel for nice ES6+ stuff
  • Builds with webpack
  • Hot reloading dev server

Future

  • Turn it into a CLI since that's a thing people do now I guess