I’ve been re-exploring p5.js recently (a JavaScript library for creative coding) and am pleased to see a growing number of additions that make it look more and more like a fully fledged creative platform.
As a proof of concept I created a simple sketch that visualises basic geometric shapes in response to incoming MIDI notes. I used the excellent p5.scribble.js library and the super useful WEBMIDI.js utility.
data:image/s3,"s3://crabby-images/504f8/504f8eed7c5093160d4cae6796b8e68a70bea8d1" alt=""
data:image/s3,"s3://crabby-images/4029e/4029e4cd187fb6153973cd51a191a31978a3e43b" alt=""
data:image/s3,"s3://crabby-images/b2ccc/b2ccce163e7f409aa59987a2dac1a6b547d5999a" alt=""
data:image/s3,"s3://crabby-images/0adf7/0adf7ae41168ed0dc528007e15294f7d0ea4e7ec" alt=""
data:image/s3,"s3://crabby-images/e5563/e5563c795c447a76f38be6bc4ca54c809b27d29f" alt=""
data:image/s3,"s3://crabby-images/6e316/6e31608651756ede56396786f23dd856746a3218" alt=""
data:image/s3,"s3://crabby-images/96b95/96b95f08f4a12c47e7eab548381fe6b3a395b971" alt=""
It all went smoothly and resulted in a fairly responsive, if very simple, audio visual proof of concept. Interestingly enough, when I ported the code to good old fashioned Processing, which uses Java rather than JavaScript, I saw no difference in perfomance or latency which makes me think that p5 is just as good a choice as Processing for creative experimentation.
If you are interested in more detail, here is the code, offered without liability, warranty or support! – https://github.com/jamiegledhill/P5-MIDI-notes