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.


209 comentarios


Azra Persson
Azra Persson
2 hours ago

Behöver du support för McAfee? Kontakta kundtjanst Sverige via Kontaktakundtjanstsverige – din pålitliga partner för McAfee-support. Vi hjälper dig med installation, uppdateringar och tekniska problem. Vårt supportteam är tillgängligt alla dagar för att ge dig trygg och snabb hjälp på svenska. Din datasäkerhet är vår prioritet – kontakta oss idag!

Me gusta

Zara Lind
Zara Lind
17 hours ago

Behöver du googlesverige kundtjänst kontaktuppgifter? Kontaktakundtjanstsverige erbjuder snabb och professionell support för alla dina Google-relaterade problem. Vi hjälper dig på svenska med Gmail, Google Drive, kontoinställningar och mer. Vårt supportteam är tillgängligt när du behöver oss. Kontakta oss idag för personlig service och pålitlig hjälp med dina Google-tjänster i Sverige!

Me gusta

Instant Gaming
Instant Gaming
3 days ago

If you love free games, Steamunlocked will be your favorite.

Me gusta

ezzah fatima
ezzah fatima
3 days ago

Deneme sürümünden tam lisanslı sürüme geçmenin en kolay ve risksiz yolu artık tek tıkla: kmspico indir.

Me gusta

alexis smith
alexis smith
5 days ago

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.

Me gusta

©2023 by Generative Hut.

bottom of page