Skip to content

Voxxer3D is basically a "Minecraft Sim", it's a 3D Voxel World Rendering Engine written from "scratch" utilizing the WebGL Interface.

Notifications You must be signed in to change notification settings

j-2k/Voxxer3D

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Voxxer3D

Voxxer3D is a 3D Voxel World Rendering Engine written from "scratch" utilizing the WebGL Interface.

Since I'm basically creating a minecraft clone, I want to focus on the graphics part & the "hidden" features that exist that isn't obvious at first.

ps. I had no clue to how minecraft works (rendering part of it specifically) and thus a lot of the features might seem "normal" but I never knew it was something I had to "do" that probably didn't make much sense but I hope to just showcase what I learned.

  • Features
    • Culling of the following types
      • Backface
      • Chunk bordering faces
      • Inside chunk faces
    • Random procedural terrain generation
      • 2D Noise currently, however 3D was actually possible and created caves
    • Chunk Vertex Builder & Chunk Blocks Array
    • UV Mapping Chunks to specific Texture/Block Type
    • & more...

Project Requirement Notes

Building the project

  1. Enter the correct directory WebGL-Trial/webgl-main
  2. Install dependencies using npm i in your terminal
  3. Run & start the project using npm run dev in terminal again
  4. The website should automatically open on localhost:5173! (Check the terminal incase its a different port! If it is taken Vite will automatically try the next available port.)

My Platform, Versioning, & Dev environment

I will list what I used, just incase for anyone wondering what I used/platform choice to make this project.

  • Mac (Sonoma 14) & Windows 10
  • Visual Studio Code / Cursor (Only tried out Cursor for the free trial to test out the IDE it's pretty nice ngl, went back to VSC though)
  • npm version npm -v 10.8.2
  • node version node -v v20.17.0
  • nvm version nvm -v 0.39.0

Project Dependencies

  • Randomness Libraries (Not going to remake hashing)
  • GL-Matrix
    • For matrix math operations.
  • Typescript
    • For obvious reasons.
  • Vite
    • Vite fixed many issues I had previously.
  • WebGL
    • Make sure your browser/machine supports WebGL!
  • Old/Previous Packages (IGNORE THIS)
    • Was using lite-server & watcher (replaced by vite).

Resources

  • https://github.com/j-2k/WebGL-Triangle-Boilerplate <<< This contains all the resources for everything related to web stuff what I will put below is only related to webGL & graphics stuff
  • chatgpt.com
    • I'm going to use GPT to help me clarify shit while learning some of the topics below + I will need it especially when doing matrix multiplication & when I need an explanation on what happens when an object goes through 50 transformation calcs lmfao
  • WebGL Resources
    • learnwebgl.brown37.net I used this as a intro to WebGL & a refresher for the graphics pipeline. (spent about 10-15% of my time here)
    • webglfundamentals.org I used this for implementation & learning everything, this resource is so fuckin good. (spent about 60-75% of my time here, rest of my time went into miscellaneous resources)
    • MDN Docs - Web GL This resource is insanely good (Just my personal opinion, above 2 are suggested heavily by seasoned graphics engineers!)
  • Looking into hosting services and found this, its a nice website! > https://wheretohostmy.app/free-tier-comparison
    • Used Netlify and it was really fast to setup. Just drag & drop the built project dist files into the host service & thats it! You can get the dist file by doing npm run build and the dist file will be created.

Graphics Rendering Pipeline Process

Very important, I will write this out once I fully/almost understand everything in the pipeline.

Important Computer Graphics Concepts

This is here to list important topics & showcase some things I went through whilst learning CG & WebGL!
I want to make this clear, but im trying to learn more about CG rather than WebGL right now, since if you know CG you will adapt to any graphics specification!

Progress Log

  • Following the guide of WebGL Fundamentals on https://webglfundamentals.org/
  • Showcasing my progress through the guide. I'm mostly going by order but sometimes I skip around.

The journey from start to end

Image Description
Fully refactored the backend from the ORIGINALLY forked repository (Webgl-trial)!
Making UVs
Making Cubes (Orthographic)
Prespective + Multiple Objects
Failing to create a small chunk
Failing to make a big chunk and everything blowing up + custom shader :)
The first chunk!
Mainly failing to create a skybox! + A lot of additions, forgot to take images, but added terrain loading, culling, block shapes & UV Offsets
Added skybox + failing to make leaves on trees work properly
Wrote a huge debugger, added chunk boundaries, & here I made a garbage fix to add leaves to trees (the implementation can be seen on the image its kinda horrid LOL)
The final result + a mashup of images to showcase the journey!

About

Voxxer3D is basically a "Minecraft Sim", it's a 3D Voxel World Rendering Engine written from "scratch" utilizing the WebGL Interface.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published