Skip to content

melaniehuang/generative-sounds

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

15 Commits
 
 
 
 

Repository files navigation

Generative Sounds x Linden New Art

Today we're going to make visuals from sound with a programming language called Processing. Processing is a programming language specifically designed for visual artists, designers and hobbyists as well as those learning how to code(so you're in safe hands!).

To run and write Processing, you would generally download the latest version of Processing but given we don't have a lot of time today - we're going to get up and running right in our browser on a variant called p5. p5.js is a JavaScript library based on Processing but is written slightly differently.

p5 Editor

Sign up for an account to write your code in the browser. Create an account and make sure you're signed in successfully. You can only save files when you're signed in. So to make sure you don't lose any work - make sure you're signed in. Once you're in - press 'Play'. A gray square should appear to the right of the text on screen.

When you've signed in, copy and paste the following into the left-hand side and let's chat about what it's doing. Press 'Play'.

function setup() {
  //this runs once
  createCanvas(450, 300);
  console.log("Hello world!");
}

function draw() {
  //this runs over and over and over
  console.log("Hello friend!");
}

You've successfully written your first sketch!

Functions are like mini programs and the main two functions that exist in p5 are setup() and draw(). setup() runs once at the start of our sketch and draw() runs over and over again on repeat until you press stop.

So here we've told the computer to:

  1. Create a canvas 450px wide and 300px tall
  2. Log the words "Hello world!" in the console
  3. Every time we run the function draw(), log the words "Hello friend!"

My first rectangle

Now let's do something more exciting. Let's draw a rectangle and see what's going on.

function setup() {
  //this runs once
  createCanvas(450, 300);
  console.log("Hello world!");
}

function draw() {
  //this runs over and over and over
  rect(100,100,50,50);
}

Can you describe what is happening in this sketch in plain english? Change some numbers and it should become fairly obvious :)

Co-ordinates

To tell the computer where to draw something, you will need to give it an x and y coordinate. You may remember these bad boys from maths class but in Computer Graphics, it’s a little different.

The top left corner (x,y) is (0,0). The x coordinates increase to the right, the y coordinates INCREASE moving down the canvas.

(0,0)___________ (900,0)
|                      |
|                      |
|                      |
|                      |
|                      |
|                      |
|                      |
(0,900) ________ (900,900)

Therefore rect() accepts the following 4 parameters:

//rect(x, y, width, height);
rect(100,100,50,50);

By default, rect() accepts the x & y position of the rectangle’s top left corner. Now, let’s add some colour!

Sequence, colour and fill

So to add a fill to the rectangle, we need to add a line above our rect() function:

fill(169,225,250);

By default, Processing interprets your numbers as RGB colours - the amount of red, green and blue you want to mix into a single colour. When we write something like:

fill(255);

the computer is actually interpreting that to be:

fill(255,255,255); 

Try the following:

function setup(){
  createCanvas(450, 300);
  console.log("Hello world!");
  background(248,250,169);
}

function draw(){
  fill(169,225,250);
  rect(100,100,50,50);
}
var mic;

function setup() {
  createCanvas(1800, 1200);
  background(255);
  mic = new p5.AudioIn();
  mic.start();
}

function draw() {
  //background(255);
  micLevel = mic.getLevel();
  ellipse(width/2,height/2,micLevel*3000,micLevel*3000)
}

function keyPressed(){
  if(key == 's'){
    save("frame.jpg");
  }
}

About

Generative Sounds workshop

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published