Skip to content

Latest commit

 

History

History
117 lines (92 loc) · 2.93 KB

README.md

File metadata and controls

117 lines (92 loc) · 2.93 KB

every() - Time based media for p5.js

every() helps you schedule scene changes in p5.js and more, for easily working on time-based media.

// A 6 minute loop, with 3 different scenes, each 2 minutes long
every(2).minutes
  .show(draw1)
  .show(draw2)
  .show(draw3);
every(1).hours
  .show(draw1)
  .show(draw2);

The Clock by Christian Marclay:

const videos = [vid1200, vid1201, ..., vid2359];
every(1).seconds
  .showAll(videos);

Installation

Download p5.every.js from this repository, and include it in your HTML file.

<script src="path/to/p5.every.js"></script>

Replace path/to/p5.every.js with the actual path of where you've placed p5.every.js.

Or use the hosted version

<script src="https://cdn.jsdelivr.net/gh/mngyuan/every/p5.every.js"></script>

Usage

In p5.js, every() belongs in the setup() function:

function setup() {
  createCanvas(400, 400);
  every().seconds
    .show(drawScene1)
    .show(drawScene2);
}

If no duration is passed to every, the duration defaults to 1.

You can provide different times to different scenes; in this case the number in every() indicates the default time if no time is provided for a scene.

every(5).seconds
  .show(draw1)     // shows for 5 seconds
  .show(draw2, 6)  // shows for 6 seconds
  .show(draw3, 4); // shows for 4 seconds

Similarly, you can provide different interactions to different scenes.

every(5).seconds
  .show(draw1, 5, {mousePressed: scene1MousePress, keyPressed: scene1Keypress})
  .show(draw2, 6)
  .show(draw3, 4, {mousePressed: scene3MousePress, keyPressed: scene3Keypress});

If you just need to change scenes when the mouse is clicked or a key is pressed,

every(5).seconds
  .show(draw1).untilKeyPressed([ENTER])
  .show(draw2).untilMousePressed()
  .show(draw3);

A scene can be skipped if a certain condition is not met.

every(5).seconds
  .show(draw1)
  .show(draw2).if(checkDraw2Visible);

function checkDraw2Visible() {
  return keyPressed;
}

Experimental APIs - Request for Comments

You can also only transition scenes if a condition is met; in this case, a scene ends when it has reportDone()'d, which optionally takes a delay.

every(5).seconds
  .show(draw1).until()
  .show(draw2);
function draw1(reportDone) {
  if (mouseIsPressed) {
    // end 2s after mouse press
    reportDone(2000);
  }
}

You can also provide a timestamped list of events to every() to schedule events at specific times. Useful for playing back recorded performances i.e. MIDI performances.

const recordedEvents = {0: [1], 5000: [2], 10000: [3]};
every(recordedEvents).timestamp
  .react(1, draw1)
  .react(2, draw2)
  .react(3, draw3);