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.



https://tylekeobongda88.com/ hôm bữa mình lướt thấy ai đó nhắc nên bấm vào nghía thử cho biết. Vào cái là thấy giao diện khá dễ chịu, kiểu chia từng mảng nội dung nên nhìn không bị rối mắt. Mình không phải dân chuyên nhưng phần kèo nhà cái với tỷ lệ kèo bóng đá hôm nay để ngay trên trang, số liệu nằm gọn gàng nên liếc phát là hiểu đang nói trận nào. Kéo xuống một chút có khu “bài mới đăng” nên cũng tiện xem họ cập nhật đều không, khỏi phải tìm vòng vòng. Mình thích nhất là mấy bảng tỷ lệ trình bày theo cột, chữ số rõ và canh thẳng hàng nhìn khá sạch trên trang.
Really helpful post! I appreciate the effort you’ve put into making this topic easy to understand for readers. Content that simplifies information about medications such as Sildenafil is always valuable. Keep sharing more!
Analyzing bim online courses requires looking beyond basic software instruction to see how curricula handle federated model coordination under ISO 19650 standards. While learning Revit or ArchiCAD interface commands is common, the real operational bottleneck lies in managing multi-disciplinary data drops. Industry whitepapers from the UK BIM Alliance show that information management failures usually stem from poorly defined asset information requirements. A specific data loss issue during IFC file translation often disrupts project handovers.
Great article on anti-worm treatment options. The content is simple, engaging, and makes it much easier to understand important health information.
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 Oscorm Digital, an IT company that provides services. One of our services is Prompt Engineering Services This service helps businesses run smoothly and work efficiently with the help of digital solutions. Prompt Engineering Services improve AI output quality by refining prompts, reducing errors, and helping businesses generate more accurate responses.
I'm excited to read more of your blog posts. You're doing a job keep it up!