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.



I came across your blog. Was really impressed. Your post was easy to understand for someone, like me. You explained things in a way that made sense.
I work for AskForAirlines, a travel support service that helps passengers with Flight Booking & Ticket Cancellations. One of the commonly searched queries by travelers is “Qatar Airways Booking Phone Number Miami Airport”. This type of query is often used by passengers looking for quick assistance and reliable support during their travel process.
Thank you for sharing such valuable content. I’m looking forward to reading more of your posts.
https://f8beta.org/ mình thấy mấy hôm nay lướt đâu cũng nghe nhắc nên tiện tay vào xem thử cho biết. Mình không đăng ký hay chơi gì cả, chỉ xem cách họ làm trang chủ thôi. Cảm giác đầu tiên là bố cục khá “dễ thở”, chia thành từng khối nội dung nhìn phát hiểu ngay đang nói về gì, không bị dồn chữ liền một mạch. Có đoạn họ nhắc cộng đồng thành viên đông kiểu hơn 10 triệu, mình tưởng sẽ rối mắt, mà hóa ra họ trình bày gọn nên đọc lướt vẫn ổn. Thanh menu để ngay chỗ dễ thấy, tiêu đề và mấy hộp thông tin canh thẳng hàng nên kéo xuống không bị lạc, nhất…
Fantastic tutorial! The way you explain kinetic generative art makes the creative process much easier to understand, even for beginners. It's inspiring to see how code and design can work together to produce dynamic visual experiences. Just like the star trek varsity jacket blends timeless style with iconic inspiration, generative art combines creativity and innovation to create something truly memorable. Thanks for sharing this excellent guide!
HIL Software enables real-time simulation and validation of embedded control systems by replicating hardware behavior in virtual environments. It accelerates testing, identifies software issues early, improves system reliability, reduces development costs, and ensures safe, efficient product deployment across industrial and automotive applications.
Interesting overview of web app development services. Building audience engagement, improving brand visibility, and using data-driven strategies can help businesses strengthen their online presence and support long-term growth.