Personal portfolio made to seamlessly switch between scenes, providing an immersive user experience through a surrealist home atmosphere.
The transitions are implemented by using two portals, the first scene contains the home page and the contact section(at a negative position on the z axis), while the projects page is separated inside its own portal and consists in a timeline progressing by scrolling on the z axis. To switch between the two scenes a transition shader(underwater transition) is used. I've made use of howlerJS to add 3D spatial sound and make the experience more immersive. The toasts for the contact form are also implemented without the use of any library to reduce the bundle size and animated using react-spring.
- Vite-React
- Tailwind
- threeJS
- react-three/fiber
- react-three/drei
- react-three/postprocessing
- react-spring/web
- react-router-dom
- howler
- emailjs/browser
- formik
- yup
- uuid
Remember to update `.env` with your EmailJS token!
Example:
_Provided by EmailJS_
PUBLIC_EMAILJS_SERVICE_ID=""
PUBLIC_EMAILJS_TEMPLATE_ID=""
PUBLIC_EMAILJS_PUBLIC_KEY=""
git clone https://github.com/EduardStroescu/R3F-ES-Portfolio.git
npm install
npm run dev
npm run build
I have encountered a few issues due to switching between the postprocessing effects from the first to the second scene, which makes the WebGL context to crash. It seems that the effect composer, at least from my implementation is finicky when used with portals and transition shaders. To achieve more stability and avoid crashes, the timing(increments) of the transition needs to be perfectly fine-tunned, as different timings resulted somewhere from constant crashes to none(also depending on the device used). The lens flare effect from the projects page is computationally expensive and results in, mainly, older mobile devices(< 2015) failing to render the second scene, this can be avoided by disabling the abovementioned effect. It depends on the webGL precision of the device, the lens flare seems to expect highp precisions.