Skip to content

markNZed/processism-react-three

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

React-Three

A project built with React and Three.js to manage and animate 3D scenes using Zustand for state management, and Framer Motion for animation. The project includes components for dynamic and interactive 3D entities, and leverages react-three-fiber for rendering and @react-three/drei for helper components.

Project Setup

Prerequisites

Ensure you have the following installed on your development environment:

  • Node.js (>= 12.x)
  • npm (>= 6.x)

Installation

Clone the repository and install the dependencies:

git clone https://github.com/markNZed/react-three.git
cd react-three
npm install

Running the Development Server

To start the development server, run:

npm start

This will start the development server at http://localhost:3000.

Deployment

To deploy the project to GitHub Pages, use the following command:

npm run deploy

You can then view your deployed site at https://markNZed.github.io/react-three.

Development Guidelines

Animation Components

  • Variants: Variants represent states of an animation component. Framer Motion is used for animating these variants whenever possible. The animationState holds the variant and other values needed for animations.
  • Visibility: The visibility of components does not necessarily require Motion and can be controlled through the animationState.
  • Camera Animation: The camera is animated using react-spring instead of Framer Motion.

Scene Management

  • Scenes: A Scene consists of animationComponents that are instantiated and an animationSequence that dictates the order of animations.
  • Animation Speed: The speed in AnimationController can be used to accelerate the animation sequence for faster transitions.

Switching Scenes

The SceneSelector component allows you to switch between different scenes. See SceneSelector.js for implementation details.

Animation Sequence

Define the animation sequence for a scene in an array, specifying delays, component IDs, and animation states. Refer to SceneOne.js and SceneThree.js for examples.

Camera Adjustments

Use the CameraAdjuster component to handle camera adjustments on window resize. Check out App.js for how it integrates with the canvas.

Additional Resources

Working Remotely

To work with this project on a remote server (assuming the server has SSH, Docker installed, and a clone of this repo):

  1. Connect to the server via SSH with VS Code and open the folder with the cloned repo.
  2. From VS Code command palette: Dev Containers: Rebuild and Reopen in Container.
  3. If there are directory permission issues (the directory on the server is owned by a different user than the user in the docker container):
    • From the terminal inside VS Code: sudo chown -R node:node /workspaces/react-three.
    • Complete the setup manually: npm install and npm start.
  4. Configure Git from VS Code terminal:
    • git config --global user.email "[email protected]"
    • git config --global user.name "your_name"

Git-crypt

We use git-crypt for any files iwth .gpg.md extensions

Additional Notes

Releases

No releases published

Packages

No packages published

Languages