Aquariums are beautiful and I wish I could get one in real life but I just don’t have the space for it. I’m going to try to build web aquariums instead.
I want it to be a react component I can take anywhere in the blog, just like other components I built for this blog like The Clapper and ARChef.
First I’m going to model an aquarium real quick in Blender.
data:image/s3,"s3://crabby-images/83419/8341945b04208cf0b177995562847bac91dd3f80" alt="blender basic aquarium blender basic aquarium"
low poly fish by Quaternius.
Next, we can throw it up here using React Three Fiber and some very handy tools like gltf to jsx and components from Drei, a library of helpers for react three fiber. I create an Aquarium model component, and it comes out like this:
data:image/s3,"s3://crabby-images/52068/52068cb91026fec0616a9c6b3537d7c92d3cdc06" alt="web basic aquarium web basic aquarium"
Using the Stage component, we can easily place our model in the webpage with lighting and position more or less taken care of.
Next, I want to add some water and there are all kinds of fancy ways we can do this. Probably will look best with a custom shader but for now just using a transparent standard mesh. I still have so much to learn with 3d graphics but the react three post-processing library makes it easy to play and try out different things.
Since it’s a React component, I can reuse these everywhere with different fish, decor and other options. For now, I have something like this:
data:image/s3,"s3://crabby-images/b989a/b989a0e1deae5b44324d67833453b09824016e58" alt="basic aquarium component basic aquarium component"
And then we get an Aquarium with grass, a duck statue and a Butterfly fish created by Quaternius. I added some very light rotation animation to the plant in Blender to give it a bit of movement.
I wanted to make visiting your aquarium relate to the world around you in some way so I decided to use env maps that change based on your local time (according to your browser).
data:image/s3,"s3://crabby-images/fafda/fafda43df0c2ccea1a9f6ad60d3a655114b0ad2b" alt="showing some different env maps dawn, mid-day, dusk and night"
Loading different env maps according to the time of day.
Adding some interactivity with Natuerlich
I listed some ideas for the next post: Look out for Part 2!