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.





sad
The recent statistics indicate that nearly sixty percent of small enterprises are unable to maintain a twenty four hour presence as employee recruitment in the local area is expensive. That is why smart companies are resorting to Customer Support Offshore so as to bridge the difference between their service and global audience. It is a smooth tactic that ensures that the brands remain competitive as the show runs all day and each day.
Nice article, I am a big time fan of your site, keep up the nice work, Data recovery Dubai. And I will be a frequent visitor for a very long time.
When you make those cheap tickets, keep that refund policy in mind not all fares are refunded. Others will refund your ticket on a call within 24 hours of purchase and they will include a threat of making a huge change in your schedule or even canceling the flight by the carrier. In a particular breakdown, make calls to the Green Bay Austin Straubel International Airport Customer Support Phone Number to discover the deadlines, forms you must have, and understand whether you will get a credit or a straight refund depending on the policies of the airline.
Military-inspired jackets are a versatile wardrobe essential. Built with durable materials, functional pockets, and a structured design, they combine rugged style with practicality, making them perfect for everyday wear and outdoor adventures.