ffd8 / P5LIVE

p5.js collaborative live-coding vj environment!
https://p5live.org
GNU General Public License v3.0
229 stars 35 forks source link

Update P5L_syncdata-presets.json #51

Closed guidobouman closed 4 years ago

guidobouman commented 4 years ago

Bug #47 was present in the SyncData sample as well. This PR fixes the typo.

ffd8 commented 4 years ago

Thanks and good catch! Totally forgot the typo was elsewhere too... Guess that means you're testing out SyncData w/ midi?? How's the experience been? Great to know what's working well and not so well.

guidobouman commented 4 years ago

We've been co-coding in hosted (offline) mode with a MIDI controller on my machine for a hackathon. Amazing work with P5LIVE, can't thank you enough! This is the least I could do.

We're making live visuals with simpele pattern-based ellipse animations with a self-written CRT shader. (Which is expensive in the browser, apparently. 😅 )

Getting DataSync to work was a little hard with the bug.

Screenshot 2020-11-05 at 18 18 12
ffd8 commented 4 years ago

Looks awesome + CRT shader sounds really interesting! Is the shader available anywhere for testing? A pending update to P5LIVE will also include some shader demo examples (after a former student spent their thesis working in that domain). Do you have these experiments documented anywhere for checking out? Feel free to spam with linkage.

guidobouman commented 3 years ago

The code is available at https://github.com/Q42/av-bonanza

Interesting parts

It uses midi from one machine to control the effects with a KORG nanoKONTROL & midi from another machine to react to the music notes being played from Max for Live.

As extra bonus we've made a session cache to restore dynamic variables between compiles.

PS: The CRT shader looks a bit better now.

ffd8 commented 3 years ago

Looks wild! And the session cache is great. As you've noticed, frameCount among a handful of other vars are persistant on recompiles – I was going to build a small transporter object/var that would always be grabbed/sent on the recompile for persistance... but then I created softCompile, which creates seemless recompiles for any code/functions changed within the draw() – maybe it could still use something along these lines.. then potentially your stored vars could just have a pre-fix like 'p5c. (or whatever) in front of them? Ah, but I see you were storing them in the URL.. maybe localStorage overwriting is also a good place? will have another look at this after pending update.

Really great to see your passing of shader textures within textures – (very) slowly getting into shaders, so lots to learn from here. Let me know when you have docu footage of the jam w/ visuals to share.

guidobouman commented 3 years ago

Actually, I switch between keyed localStorage & generic sessionsStorage based on if you're in a co-coding session or not. With a co-coding session, we can use the session key (from the URL) as the storage key. Otherwise we need to use the session storage (which will clean on tab close) as you can switch between different sketches.

Edit: A bit over engineered for a hackathon, I know. 😅

guidobouman commented 3 years ago

Forgot to make footage during most of the jam session, of course. We did do a live stream on Twitch, though.

Here's a short clip I recorded: https://we.tl/t-TvCUQmoll0