Skip to content

jotyy/r3f-portfolio

Repository files navigation

React-Three-Blog

A personal blog site build with NextJS, @react-three/fiber and Threejs.

  • TTL ~ 100ms
  • First load JS ~ 88kb
  • Lighthouse score of 100 (Performance, Accessibility, Best Practices, SEO)

This starter allows you to navigate seamlessly between pages with dynamic dom and/or canvas content without reloading or creating a new canvas every time. 3D components are usable anywhere in the dom. The events, dom, viewport, everything is synchronized!

⚫ Demo

Live demo

🗻 Features

  • GLSL imports
  • Canvas is not getting unmounted while navigating between pages
  • Canvas components usable in any div of the page
  • Based on the App directory architecture
  • PWA Support

🚄 Architecture

Thanks to tunnel-rat the starter can portal components between separate renderers. Anything rendered inside the <View/> component of the starter will be rendered in the 3D Context. For better performances it uses gl.scissor to cut the viewport into segments.

<div className='relative'>
  <View orbit className='relative sm:h-48 sm:w-full'>
    <Dog scale={2} />
    // Some 3D components will be rendered here
  </View>
</div>

🎛️ Available Scripts

  • pnpm dev - Next dev
  • pnpm analyze - Generate bundle-analyzer
  • pnpm lint - Audit code quality
  • pnpm build - Next build
  • pnpm start - Next start

⬛ Stack