top of page

Kinetic Generative Art Tutorial

  • Writer: Pierre Paslier
    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.


248 Comments


Azra Persson
Azra Persson
17 hours ago

Behöver du support med McAfee? Hos Kontaktakundtjanstsverige får du snabb hjälp via mcafee kundtjänst swedish. Vi erbjuder professionell service för installation, felsökning och uppdateringar. Vårt supportteam finns tillgängligt på svenska för att ge dig trygg och effektiv hjälp när du behöver det. Kontakta oss redan idag!


Like

Monica Geller
Monica Geller
a day ago

Traveling internationally from Dallas and wondering about exchanging your currency? You’re not alone. Whether it’s your first trip abroad or you’re a seasoned traveller, understanding your options for  Dallas Airport currency exchange  can help you avoid unnecessary fees and get more bang for your buck. 

Delta First Class

Alaska Airlines JFK Terminal

qatar first class

Philippine Airlines Unaccompanied Minor policy

frontier cancellation policy

JetBlue Airways First Class

Kuwait Airways Business Class

Currency Exchange at Philadelphia Airport


Like

Natasha Fitzroy
Natasha Fitzroy
2 days ago

Tarvitsetko Facebook tuki -palvelua Suomessa? "Asiakaspalvelu numeroy hteystiedot" tarjoaa luotettavaa apua erilaisiin Facebook-ongelmiin, kuten tilin palautukseen, kirjautumisvaikeuksiin ja asetuksiin. Saat meiltä suomenkielistä asiakaspalvelua nopeasti ja vaivattomasti. Ota yhteyttä ja ratkaise Facebook-haasteesi helposti asiantuntijoidemme avulla.

Like

Taylah Lawson
Taylah Lawson
2 days ago

Tarvitsetko Facebook yhteystiedot Suomi saadaksesi apua Facebookin käyttöön liittyvissä ongelmissa? Me facebook.suomiasiakaspalvelu tarjoamme luotettavaa ja nopeaa tukea suomen kielellä. Autamme esimerkiksi tiliongelmissa, kirjautumisvaikeuksissa ja muissa Facebookin haasteissa. Ota yhteyttä asiantuntijoihimme ja saat henkilökohtaista apua nopeasti ja vaivattomasti!

Like

Isabelle Sargood
Isabelle Sargood
2 days ago

Etsitkö apua Google-palveluihin? Google Help Center Suomi tarjoaa hyödyllistä tietoa, mutta "Asiakaspalvelu numero yhteystiedot" auttaa sinua henkilökohtaisesti. Saat nopean ja selkeän tuen Google-ongelmiisi suomeksi. Ota yhteyttä ja anna asiantuntijoidemme ratkaista haasteesi tehokkaasti – olemme täällä sinua varten!

Like

©2023 by Generative Hut.

bottom of page