Programming for Visual Artists
ARTS-A0701 – Digital Art 1
2024 - Lecture 3
- Mon, 26.2: Introduction, P5.js editor, shapes, coordinates and colours
- Tue, 27.2.: Variables, randomness
- Mon, 4.3: Animating with trigonometric functions
- Tue, 5.3: Animating with noise
- Mon, 11.3.: If-else, for-loop
- Tue, 12.3.: For-loop, noise
- Mon, 18.3.: Audio input, Interaction
- Tue, 19.3.: Images and video
- Mon, 25.3.: Recap, personal project
- Tue, 26.3.: Personal project
- Mon, 8.4.: Personal project, course feedback
- Tue, 9.4.: Presentations / exhibition?
8 assignments and course project
Submit at least 6 assignments and present course project to pass the course
data:image/s3,"s3://crabby-images/b224a/b224a7efa001d31ff2af98cd339beafb06f9b597" alt=""
data:image/s3,"s3://crabby-images/66cc8/66cc83e1fe2354d85f8be22ab0ea5d908997926e" alt=""
Today - movement and animation
- A bit more about variables (variable scopes)
- Animate with trigonometric functions
- Transformations (translate, Rotate, Push/Pop)
Moving things with variables
Global and local variable scope
data:image/s3,"s3://crabby-images/e9f0b/e9f0b3cede7f9280127cef89ee30b8a9e0a23cb4" alt=""
data:image/s3,"s3://crabby-images/43479/43479abd3cfa63341c9b98485629195a34f5ee96" alt=""
data:image/s3,"s3://crabby-images/7c476/7c4762d869b3b26c7ffd22d1da0e9424d1b1876f" alt=""
let thisIsGlobal;
function setup() {
createCanvas(windowWidth, windowHeight);
thisIsGlobal = 0;
}
function draw() {
thisIsGlobal = thisIsGlobal + 10;
}
function setup() {
createCanvas(windowWidth, windowHeight);
let thisIsGlobal = 0;
}
function draw() {
thisIsGlobal = thisIsGlobal + 10;
// ReferenceError!
// Variable is not visible here
}
Variable visibility example
let posX;
let posY;
function setup() {
createCanvas(400, 400);
posX = 200;
posY = 200;
}
function draw() {
background(220);
posX = posX + -2 + random(4);
posY = posY + -2 + random(4);
ellipse(posX, posY, 50,50);
}
function setup() {
createCanvas(400, 400);
}
function draw() {
background(220);
let posX = random(width);
let posY = random(height);
ellipse(posX, posY, 50,50);
}
Animate with trigonometric functions
data:image/s3,"s3://crabby-images/535ae/535ae7d76b1293b56704c16567fc7b51aeb6fc1a" alt=""
sin(x)
regardless of x, output is allways between -1 and 1