The Code Liberation Foundation
Class 2 : p5.js
codeliberation.org
Hello, world!
The Code Liberation Foundation
Class 2 : p5.js
We are a community of
The Code Liberation Foundation
Class 2 : p5.js
Game developers and creative technologists.
Centred on women, nonbinary, femme and girl-identifying people.
We are NOT a coding bootcamp.
Our founder, Phoenix Perry, is with us today.
The Code Liberation Foundation
Class 2 : p5.js
We aim to create community and empower you to keep on learning.
Who am I?
The Code Liberation Foundation
Class 2 : p5.js
I'm into maths, music and machines.
A little about you?
The Code Liberation Foundation
Class 2 : p5.js
Is anyone new this week?
Please tell me your name, a bit about your background, and what drew you to Code Liberation.
Last week recap:
The Code Liberation Foundation
Class 2 : p5.js
Introduction to p5.js
- Comments
- x, y Coordinates
- The Canvas - Shapes - Colours
- Variables - For loops
Last week:
The Code Liberation Foundation
Class 2 : p5.js
- Mouse Interactivity
- Randomness
- Conditions
- Mapping
- Relational operators
Any questions?
The Code Liberation Foundation
Class 2 : p5.js
Feel free to ask any question if you don't understand or want to know more about something.
Just ask/say: I don't understand this, could you maybe give an example? Could you explain this in another way?
Last week's homework:
The Code Liberation Foundation
Class 2 : p5.js
// Random circles
var fr = 15; //starting frame rate
var x = 800;
var y = 600;
var dots = {
x:100, //x=100
y:50
}
var col = {
colR:0,
colG:0,
colB:255
}
function setup(){
createCanvas(x,y);
background(0);
}
function draw(){
if (mouseIsPressed) {
fill(255);
} else {
dots.x = random(0, 800);
dots.y = random(0, 600);
col.colR = random(0, 255);
col.colG = random(0, 255);
col.colB = random(0, 255);
}
stroke(0); // no outline
fill(col.colR, 0, col.colB);
ellipse(mouseX, mouseY, 50, 50);
}
Random circles.
The Code Liberation Foundation
Class 2 : p5.js
https://www.openprocessing.org/sketch/439570
Homework:
The Code Liberation Foundation
Class 2 : p5.js
We were asked to experiment with what was learned in last week's session.
Make some compositions with shapes, create fun characters with these shapes. Make them interactive. Use variables.
Any questions?
This week:
The Code Liberation Foundation
Class 2 : p5.js
- Editor
- Ball catch game
- Scenes
- Adding sound
This week:
The Code Liberation Foundation
Class 2 : p5.js
work in progress. you said charlie would cover some of these topics in week 4.
6/Translate, Rotate, Scale (look up pedagogical examples)
7/Media >> largely in session 4 but 1 image in background
8/Motion: Move and choreograph shapes.
9/Functions: Build new code modules. (week 4)
10/Objects: Create code modules that combine variables and functions. (week 4)
11/Arrays: Simplify working with lists of variables.
The Editor:
The Code Liberation Foundation
Class 2 : p5.js
Atom
- Cross-platform
- Packages
- Autocomplete
Atom.
The Code Liberation Foundation
Class 2 : p5.js
Press the download button on the https://atom.io/ site.
Once you have that file, click on it to extract the application.
Drag the new Atom application into your "Applications" folder.
Using Atom with p5.js
The Code Liberation Foundation
Class 2 : p5.js
https://p5js.org/get-started/
File >> Open ...
The Code Liberation Foundation
Class 2 : p5.js
Using Atom with p5.js
The Code Liberation Foundation
Class 2 : p5.js
Using Atom with p5.js
The Code Liberation Foundation
Class 2 : p5.js
Let's code!
The Code Liberation Foundation
Class 2 : p5.js
Create a ball
The Code Liberation Foundation
Class 2 : p5.js
function setup() {
createCanvas(640, 480);
background(245);
}
function draw() {
fill(200,0,200);
ellipse(320, 240, 80, 80);
}
Ta-dah!
The Code Liberation Foundation
Class 2 : p5.js
Well done!
The Code Liberation Foundation
Class 2 : p5.js
Move ball mouse position
The Code Liberation Foundation
Class 2 : p5.js
function setup() {
createCanvas(640, 480);
background(245);
}
function draw() {
fill(200,0,200);
ellipse(mouseX, mouseY, 80, 80);
}
Move ball mouse position
The Code Liberation Foundation
Class 2 : p5.js
https://www.openprocessing.org/sketch/439492
Try to change the colour
using mouse position
The Code Liberation Foundation
Class 2 : p5.js
Remember mapping from last week
The Code Liberation Foundation
Class 2 : p5.js
// map slider
var colR = 0;
var colG = 0;
var colB = 0;
function setup() {
createCanvas(640,480);
background(245);
}
function draw() {
// map color change to mouse movement
colR = map(mouseY, 0, 480, 0, 255);
colG = map(mouseY, 0, 480, 0, 255);
colB = map(mouseX, 0, 640, 0, 255);
background(245);
fill(colR,colG,colB);
ellipse(mouseX, mouseY, 80, 80);
}
Let's see.
The Code Liberation Foundation
Class 2 : p5.js
https://www.openprocessing.org/sketch/439556
Let's experiment with looping
The Code Liberation Foundation
Class 2 : p5.js
https://p5js.org/reference/#/p5/loop
Create loop
The Code Liberation Foundation
Class 2 : p5.js
loop(); // (default)
noLoop();
See what happens when you insert this code in the draw block.
BREAK
The Code Liberation Foundation
Class 2 : p5.js
Create a variable for position
The Code Liberation Foundation
Class 2 : p5.js
var x;
var y = 0;
// map slider
var colR = 0;
var colG = 0;
var colB = 0;
function setup() {
createCanvas(640,480);
background(245);
}
function draw() {
// map color change to mouse movement
colR = map(mouseY, 0, 480, 0, 255);
colG = map(mouseY, 0, 480, 0, 255);
colB = map(mouseX, 0, 640, 0, 255);
background(245);
fill(colR,colG,colB);
ellipse(x, y, 80, 80);
}
The Code Liberation Foundation
Class 2 : p5.js
See if you can change the y position
If statement
The Code Liberation Foundation
Class 2 : p5.js
// map slider
var colR = 0;
var colG = 0;
var colB = 0;
function setup() {
createCanvas(640,480);
background(245);
}
function draw() {
// map color change to mouse movement
colR = map(mouseY, 0, 480, 0, 255);
colG = map(mouseY, 0, 480, 0, 255);
colB = map(mouseX, 0, 640, 0, 255);
background(245);
fill(colR,colG,colB);
ellipse(mouseX, mouseY, 80, 80);
if (mouseIsPressed == true) {
fill(0);
}
ellipse(mouseX, mouseY, 80, 80);
}
If statement
The Code Liberation Foundation
Class 2 : p5.js
// add if statement to draw block from previous example
background(245);
fill(colR,colG,colB);
ellipse(mouseX, mouseY, 80, 80);
if (mouseIsPressed == true) {
fill(0);
}
ellipse(mouseX, mouseY, 80, 80);
}
What happens now when you click the mouse?
The Code Liberation Foundation
Class 2 : p5.js
If statement
The Code Liberation Foundation
Class 2 : p5.js
https://www.openprocessing.org/sketch/439571
What to do with x position
The Code Liberation Foundation
Class 2 : p5.js
x = random(width);
Click function
The Code Liberation Foundation
Class 2 : p5.js
function mousePressed(){
y = 0;
}
Click function ellipse
The Code Liberation Foundation
Class 2 : p5.js
if(mouseX > x-40 && mouseX < x+40 &&
mouseY > y-40 && mouseY < y+40){
y = 0;
x = random(width);
}
Write some comments for the if statement
The Code Liberation Foundation
Class 2 : p5.js
Add a score counter
The Code Liberation Foundation
Class 2 : p5.js
add text & check p5.js website to look it up by students
Add number to score
The Code Liberation Foundation
Class 2 : p5.js
Make a variable for size
The Code Liberation Foundation
Class 2 : p5.js
change speed
why does the if statement not work when
=== becomes > / can not be the exact height number
End score
The Code Liberation Foundation
Class 2 : p5.js
if( score === 2 ){
x = width/2;
y = height/2;
speed = 0;
fill(255);
text("you won", width/2-40,height/2+10)
}
Add variable for size
The Code Liberation Foundation
Class 2 : p5.js
random size
Switch statement
The Code Liberation Foundation
Class 2 : p5.js
A switch case is used to select one of many blocks of code to be executed.
Switch statement
The Code Liberation Foundation
Class 2 : p5.js
Can anyone think of an example scenario where a switch statement could be used?
Switch case?
The Code Liberation Foundation
Class 2 : p5.js
switch (new Date().getDay()) {
case 0:
day = "Sunday";
break;
case 1:
day = "Monday";
break;
case 2:
day = "Tuesday";
break;
case 3:
day = "Wednesday";
break;
case 4:
day = "Thursday";
break;
case 5:
day = "Friday";
break;
case 6:
day = "Saturday";
}
Scene Manager
The Code Liberation Foundation
Class 2 : p5.js
https://github.com/mveteanu/p5.SceneManager
Challenge.
The Code Liberation Foundation
Class 2 : p5.js
Create a ping pong game.
In pairs.
Homework
The Code Liberation Foundation
Class 2 : p5.js
Coding homework
Think about what game you would like to make
Next week:
The Code Liberation Foundation
Class 2 : p5.js
- Game Design
- Initial discussion of ideas for exhibition
- Game Art
- Presentation of exhibition ideas for feedback
Further reading:
The Code Liberation Foundation
Class 2 : p5.js
An Individual Note of Music, Sound and Electronics
by Daphne Oram
Getting Started with p5.js by Lauren McCarthy
Processing: A Programming Handbook for Visual Designers and Artists by Casey Reas and Ben Fry
Form+Code by Casey Reas and Chandler McWilliams
Staying in contact:
The Code Liberation Foundation
Class 2 : p5.js
Keep in contact with us on social media.
🐤 : @codeliberation
🐤 : @dataflo9000
🐤 : @phoenixperry
Go forth and conquer
create!
The Code Liberation Foundation
Class 2 : p5.js
The Code Liberation Foundation
Class 2 : p5.js
Copy of Code Liberation V & A Workshops Lesson 2
By Nonto
Copy of Code Liberation V & A Workshops Lesson 2
just a backup, pre-edits
- 60