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.



If you’re into quick, skill-based challenges, Drive Mad is a solid pick. It’s easy to start but hard to master, and that balance makes it a great option for casual but focused gameplay.
LX88 mình lướt thử cho biết thôi, kiểu xem giao diện ra sao chứ không đào sâu. Ấn tượng đầu là trang nhìn gọn, các phần nội dung chia theo khối nên kéo xuống không bị rối mắt, đọc lướt vẫn nắm được ý chính. Mình có để ý họ có đoạn nói về giấy phép Curacao eGaming với mấy chứng chỉ kiểm tra độc lập, đặt trong kiểu box thông tin nên nhìn phát nhận ra ngay, không phải mò. Menu cũng để chỗ dễ thấy, bấm qua lại giữa các mục khá mượt, không có cảm giác bị “nhồi chữ” hay bắt tìm link vòng vèo. Nói chung trải nghiệm xem nhanh ổn, nhất là cách họ đóng…
TG88 Đăng Nhập hôm bữa mình cũng tò mò bấm vào xem thử chứ chưa chơi bời gì đâu. Vào cái là thấy giao diện khá “thoáng”, kiểu chữ với khoảng cách nhìn dễ chịu nên lướt không bị mỏi mắt. Mình chỉ kéo lên kéo xuống vài vòng để coi họ trình bày thế nào, thấy nội dung chia thành từng khối riêng nên nhìn phát biết chỗ nào là thông tin chính, chỗ nào là phụ. Có mấy bảng thông tin dạng cột nhìn gọn, không bị nhét chữ quá nhiều nên đọc nhanh hiểu luôn. Thanh menu đặt ngay chỗ dễ thấy nên đổi qua lại vài mục cũng tiện, không phải mò. Nói chung cảm giác…
Proficiency in writing is valuable, but subject knowledge is more so. An economist-knowledgeable author will be better able to narrow down Academic content writing economic research than a generalist. Be sure each time to check out samples of past work in your community.
f8betlv com mình vừa ghé thử vài phút cho biết thôi, kiểu lướt nhanh xem giao diện có dễ nhìn không. Ấn tượng đầu là trang sắp xếp khá gọn, các khối nội dung tách bạch nên mắt không bị loạn, kéo xuống cũng dễ bắt nhịp. Mình để ý phần chữ và khoảng trắng vừa phải, đọc lướt vẫn nắm được ý chứ không bị dồn dập như nhiều trang khác. Thanh menu đặt ngay chỗ dễ thấy nên muốn chuyển mục thì bấm cái là qua, không phải mò mẫm. Nói chung cảm giác dùng khá “nhẹ đầu”, nhất là mấy ô thông tin dạng block nhìn rõ ràng và đều tay.