Live version can be viewed here
Dash Blockchain Visualizer using Three.js, Cannon.js and Insight API.
Due to the lack of open-source 3D blockchain visualizers I decided to roll one for Dash.. inspired by BitBonkers & BitListen
To create an ultra-simple Dash 3D visualization with minimal code/dependencies that can illustrate real-time activity such as new tx, blocks and future Evolution objects, in an easy-to-use, seamless way and on a wide range of devices.
No build/npm etc yet - just edit the JavaScript in /src/dash-machine.js and load /index.html from a local webserver to run.
Vendor code can be found in /src/vendor and content files are stored in /assets/.
When the page loads, the Dash.Machine object in /src/dash-machine.js is created which runs the visualization in an HTML5 canvas passed into the constructor.
A benchmark is run for 3 seconds behind a loading screen at start to determine the device FPS (and later tune the graphics and physics settings appropriately), preload all the assets and get the best bock and its tx from Insight.
After preload the best block and tx are added to the scene as a starting point and then we listen for new unconfirmed tx and confirmed blocks from a websocket hooked into Insight, defaulted to http://insight.dash.org/insight/.
When a new block hash is seen we re-query Insight to get the block height and a cube is added with the height written on each face and to the html HUD including a timer that just increments since the last block was received.
When new unconfirmed tx are seen we add a sphere for each output, with the size roughly calculated using the log of the spherical volume with r = txo-amount, and different textures for amounts falling between the limits <1, <10, <100, <1000.
During visualization if no network activity is detected within any (default) 30 second period, Insight is pinged for the best block hash to check if it's still alive - if not, the loader screen is shown again until a connection is re-established.