Skip to content

A web app to simulate redstone circuitry (boolean logic) in a minecraft-like 3D environment.

Notifications You must be signed in to change notification settings

GuilhermeRossato/3D-Redstone-Simulator

Repository files navigation

3D Redstone Simulator

A javascript experiment to simulate minecraft and its game behaviors such as redstone logic in the browser.

Click here to run the current version

Left click to break blocks, middle click to select block type, and right click to place blocks. WASD to move horizontally and Space/Shift to move vertically.

Note that during development the above link will not always bring you to a working release, if you want you can download the most recent release and run it yourself. This project doesn't need building or installing dependencies but the multiplayer functionality only works on the link.

Releases

  • v 0.1 - Performance Viability Release

Preview v0.1

  • v 0.2 - Primitive Block Distinction

Preview v0.2

  • v 0.3 - Collision Detection and Block Selection

Preview v0.3

  • v 0.4 - Inventory, Hotbar and Procedural Terrain Generation [Removed]

Preview v0.4

  • v 0.5 - ES6 Rewrite and Voxel AO Implementation

Preview v0.5

  • v 0.6 - Block selection and block placement

Preview v0.6

  • v 0.7 - Multiplayer and World persistance

Preview v0.7

Who is this for

This is an experiment to simulate the game in the browser and eventually to make developing redstone contraptions easier by allowing fast prototyping. It also serves as my project to experiment with project organization, design philosophy, test zone and whatever idea I came up with.

How to run this repo locally

Download this repository and either run npm run start at the root of it or just run a static http server to serve files for frontend folder.

There are no dependencies, so you don't need to call npm install.

However, the backend is not included, so it will not work and your world and the changes you make in it will not be saved.

Objectives, Priorities and Plan

  1. Menu (done)
  2. 3D Controls similar to minecraft (done)
  3. Correct Block Rendering (done)
  4. Crosshair and Block Selection (done)
  5. Collision Detection (removed)
  6. Procedural Terrain Generation (release v0.4 only)
  7. Major update - rewrote everything with modern technology (done)
  8. Inventory and Hotbar system (in progress)
  9. Mobile and Gamepad compatibility (in progress)
  10. Block placement (done)
  11. Area select and selection tools
  12. Multiplayer system (done)
  13. Redstone Simulation
  14. Piston Simulation
  15. Water and Lava Simulation

Easter eggs

You can relive the entire world block history (play it back) in some obscure undocumented way.

Dependencies, Credits and Inspiration

  1. three.js - Javascript 3D Library - Used to render the world
  2. Minecraft - by Mojang - Inspiration and original game
  3. Digital Circuit Logic, or Boolean Algebra - Definition of how complex redstone systems behave