Another take on Nadieh Bremer mesmerizing Breathing Earth visualisation, running at 60fps on a 2D Canvas without libraries or frameworks.
The weekly data are provided by VIIRS geo files from NOAA STAR. Using Canvas ImageData, it was straight forward to render the vegetation health, or “greenness” across the planet.
The Canvas has a pale yellow backround to see the arid areas through. The ImageData is white on the water masses and dark green on the land masses. Setting the alpha channel of each data point allows to shift between the dark green of the lush areas and to see through the pale yellow background of the arid areas. To get smooth animation, the data of two consecutive weeks are linearly interpolated.
By popular demand, and to be true to the original Breathing Earth, the data are also rendered as little discs of radius 1, 2 and 3. The circles are drawn in additive blending mode, which makes the land masses "greener". To compensate the accumulation of "greenness", there is a final pass mixing the exact value of each data point with the value of the circles overlapping it.
This approach cruises at 60 frames per second on a mid-range laptop.
Click or tap the picture of the earth to start/pause the animation.
This was an interesting exersize to test this approach and see the performance one can get out of plain 2D Canvas and ImageData. Hope you liked this little project.
Other recent experiments
There are many experiments and projects like BREATHING EARTH to discover other here.
- MUSIC FOR TINY AIRPORTS AT WEB AUDIO CONFERENCE The Web Audio Conference 2018, held in September 19-21 in Berlin was a great mix of researchers, web developers, artists and performers presenting their projects. I had the chance to provide a deep dive into music for tiny airports, explaining how to generate hours and hours of music in a handful of bytes.
- CODING⯌ART AT RENDER CODING⯌ART at Render 2017 was part of my series of talks + live coding aiming to inspire new web developer artists.
- MINAMI DISTRICT DEMOJS 2013's winner 1k intro. With MINAMI DISTRICT I wanted to do something fresh. Something never seen in normal demos before: A city with a twister skyscraper.
- SUDOKU SOLVER Solves a Sudoku grid using magic, recursion, and 140bytes of brute force.
- MANDELBROT ROTOZOOM Many people did fractals renderers in Javasript in 256 bytes, but no one ever made one that zooms and rotate... until today.
Don't be shy; get in touch by mail, twitter, github, linkedin or pouet if you have any questions, feedback, speaking, workshop or performance opportunity.