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.



Helpful insights on getting blog comments approved faster—especially the section on writing relevant, value-driven responses. In healthcare application development services like SISGAIN, consistency and real engagement improve approval rates.
https://98wincom.best/ mình ghé thử đúng kiểu tò mò thôi, thấy mấy đứa bạn nói nhiều quá nên bấm vào xem. Ấn tượng đầu là trang nhìn khá sạch sẽ, các phần được chia thành từng khối nên lướt xuống không bị loạn, mắt mình đỡ phải dò. Mình có để ý đoạn họ nhắc về tải app, viết ngắn gọn kiểu dùng app thì thao tác nhanh và ổn định hơn so với dùng trình duyệt, đọc cái là hiểu ngay chứ không vòng vo. Nói chung với người chỉ xem qua như mình thì vậy là ổn, không cần màu mè hay chữ nghĩa dài dòng. Mấy chỗ kiểu hỏi đáp/giải thích cũng đặt dễ thấy nên khỏi phải…
Fantastic tutorial with a creative and beginner-friendly approach. Kinetic generative art beautifully combines motion, coding, and design, making it inspiring for anyone interested in digital creativity. Great step-by-step guidance and an enjoyable read.
A structured approach to site management often includes nvq level 6 site management in professional education. The College of Contract Management provides a programme designed to support this development. Learners study risk assessment and leadership. These areas are essential in construction.
tải go88 hôm bữa mình cũng tò mò nên ghé thử xem giao diện thế nào, chứ không phải kiểu rành mấy trò này đâu. Vào cái là thấy web app làm khá gọn, màu sắc nhìn sáng sủa nên không bị rối mắt, lướt một vòng là biết chỗ nào là phần giới thiệu, chỗ nào là nội dung chính. Mình thích nhất là mấy khối thông tin họ chia tách rõ, đọc nhanh vẫn hiểu ý, kiểu người mới không bị “lạc” giữa một đống mục. Thử bấm qua lại vài trang thấy phản hồi cũng nhanh, gần như không phải chờ load lâu. Nói chung cảm giác dùng ổn vì bố cục mạch lạc và giao diện…