Skip to content

Latest commit

 

History

History
45 lines (30 loc) · 1.67 KB

README.md

File metadata and controls

45 lines (30 loc) · 1.67 KB

Infinite Image Gallery with react-three-fiber

Netlify Status

View Deployment


This is a reimplementation of the infinite image gallery on Bien Joué with react-three-fiber. Performance issues are still around but in general the core logic of an infinite gallery is achieved. It was a really interesting problem.

How to run

yarn
yarn start

or

npm install
npm start

A few words

Two core problems I solved in this project:

  1. How to build an infinite image gallery:
    • Render multiple duplicate grids that surround the center, original grid (I ended up with 3x3 = 9 grids). Keep track of which grid is in center and which are the boundaries
    • Detecting the visibility of each boundary grid, depending on current camera position
    • Under certain conditions (boundary reached), update the grids' position & update the grids' position tracker. E.g.: Top boundary reached, move the whole bottom 3 grids up top. Now the first row becomes the middle row, and the center row becomes the bottom row...
  2. Update vertex shader on mousemove, calculating mouse's offset distance to current camera's position & update image distortion effect.

Major issues I'm awared of and haven't been able to solve:

  • Performance. Rendering multiple meshes at the same time is heavy. I'm still looking for a way to optimize this

Dependencies

  • three.js
  • react and react-three-fiber
  • react-spring
  • zustand
  • GLSL (shaders)