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.


219 Comments


Zara Lind
Zara Lind
2 days ago

Letar du efter zgoogle-stod-nummer swedish för snabb hjälp? Hos kontaktakundtjanstsverige erbjuder vi pålitlig Google-support på svenska. Oavsett om det gäller Gmail, YouTube eller Google-konto, är vår kundtjänst här för att hjälpa dig. Kontakta oss idag och få direkt support från vårt erfarna team i Sverige.


Like

Emma Williams
Emma Williams
2 days ago

Whether you're planning a short business trip or a long-distance vacation, knowing where your nearest Amtrak station is can make your travel experience much smoother. Instead of relying on general search engines or inaccurate map results, it’s better to use a direct and dependable method. The best place to begin your search is with amtrak stations near me, a helpful resource designed specifically to locate Amtrak train stations in your area.

Like

Azra Persson
Azra Persson
5 days ago

Behöver du hjälp med McAfee i Sverige? Hos kontaktakundtjanstsverige får du snabb support. Vi erbjuder pålitlig assistans för installation, förnyelse och felsökning. Spara tid – ring McAfee kundtjänst telefonnummer idag och få professionell hjälp direkt. Vår support finns tillgänglig för att lösa dina säkerhetsproblem effektivt och tryggt. Kontakta oss nu!


Like

Zara Lind
Zara Lind
5 days ago

Behöver du hjälp med Google-tjänster? På kontaktakundtjanstsverige erbjuder vi snabb och tillförlitlig support för alla dina Google-relaterade frågor. Vår dedikerade Google kundtjänst Swedish hjälper dig med tekniska problem, kontoinställningar och mycket mer. Kontakta oss idag för personlig service och professionell support direkt i Sverige.

Like

Larry Walker
Larry Walker
5 days ago

Superbly written article, if only all bloggers offered the same content as you, the internet would be a far better place.. wedding dj packages

Like

©2023 by Generative Hut.

bottom of page