Kinetic Generative Art Tutorial
- Pierre Paslier
- Jun 3, 2023
- 2 min read
Tutorial Intro
Welcome to this tutorial where we're going to explore the mesmerizing world of generative art, inspired by the kinetic sculptures of artists like Reuben Margolin. We'll use p5.js, a powerful JavaScript library that makes coding visual and interactive elements on the web accessible to everyone.
Our goal is to create a digital artwork with a series of rotating pendulums, each varying in speed and size, to simulate the motion seen in kinetic sculptures. The final result is a beautiful, ever-changing pattern that reflects the dynamic essence of kinetic art.
This tutorial is beginner-friendly, so don't worry if you're new to p5.js or programming in general. We'll walk through each line of code step by step, explaining the concepts as we go along.
By the end of this tutorial, not only will you have created a piece of generative art, but you will also have gained a deeper understanding of loops, arrays, and object-oriented programming in p5.js. You'll be equipped with the knowledge to create your own unique generative artworks. So, let's dive in and start coding!
Generative Art Code
let pendulums = [];
let pendulumCount = 40;
function setup() {
createCanvas(windowWidth, windowHeight);
for(let i = 0; i < pendulumCount; i++){
pendulums[i] = new Pendulum(i);
}
}
function draw() {
blendMode(NORMAL);
background(255 );
translate(width / 2, height / 2);
for(let i = 0; i < pendulumCount; i++){
pendulums[i].display();
pendulums[i].update();
}
}
class Pendulum {
constructor(n){
this.angle = 0;
this.angleSpeed = 0.01 + n * 0.004;
this.radius = 30 + n * 6;
}
update() {
this.angle += this.angleSpeed;
}
display(){
let x = this.radius * cos(this.angle);
let y = this.radius * sin(this.angle);
stroke(0,100);
line(0, 0, x, y);
fill(0);
ellipse(x, y, 5, 5);
}
}
That's it! Hope you've enjoyed learning about this particular piece and make sure to check out the other free tutorials on generativehut.com.
Learning through apc qualification course builds a strong foundation. The College of Contract Management has a course that includes detailed induction and clear pathways. It’s useful for both MRICS and AssocRICS. Many have succeeded with the help of this course.
Onko sinulla ongelmia Facebookin kanssa? Facebook asiakaspalvelu auttaa esimerkiksi tilin palautuksessa, kirjautumisongelmissa ja tietoturva-asioissa. Asiakaspalvelu Numeroy Yhteystiedot tarjoaa luotettavaa ja asiantuntevaa tukea Suomessa. Ota yhteyttä heti – saat nopeaa apua ja ratkaisun Facebook-ongelmaasi vaivattomasti!
Tarvitsetko facebook yhteystiedot saadaksesi apua tilisi tai mainostesi kanssa? Me facebook.suomiasiakaspalvelu tarjoamme suomenkielistä asiakastukea nopeasti ja helposti. Autamme sinua tiliongelmissa, turvallisuuskysymyksissä ja muissa Facebook-palveluun liittyvissä asioissa. Ota yhteyttä asiantuntevaan tukitiimiimme ja saat henkilökohtaista apua juuri silloin kun tarvitset sitä!
Google Help Center Suomi tarjoaa perustietoa palveluista, mutta henkilökohtaisissa ongelmissa Asiakaspalvelu Numero Yhteystiedot auttaa sinua nopeasti ja asiantuntevasti. Tarjoamme apua suomalaisille käyttäjille Gmailin, YouTuben, Google Mapsin ja muiden palveluiden kanssa. Ota yhteyttä asiantuntijoihimme ja saat luotettavaa tukea suomeksi – helposti ja vaivattomasti!
Szukasz Facebook Polska kontakt? Firma Klienta Polska oferuje profesjonalne wsparcie techniczne w języku polskim. Pomagamy w sprawach konta, reklam, bezpieczeństwa i innych problemów z Facebookiem. Skontaktuj się z nami i otrzymaj realną pomoc bez zbędnego czekania. Działamy szybko, skutecznie i z indywidualnym podejściem do każdego klienta.