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.



Trang Chủ LC88 mình vừa lướt thử cho biết vì thấy bạn bè nhắc mấy lần. Ấn tượng đầu tiên là trang nhìn sáng sủa, chữ không bị dồn dập, mấy mục chính được xếp theo nhóm nên tìm thông tin khá nhanh. Mình chỉ đọc phần giới thiệu sơ sơ thôi, thấy họ có nhắc nền tảng hoạt động từ khoảng 2018 và có nói rõ chuyện giấy phép chứng nhận quốc tế, kiểu ghi thẳng ra nên đỡ phải đoán. Không cần bấm nhiều vẫn nắm được ý chính vì các đoạn được chia thành từng khối, có tiêu đề rõ ràng. Kéo xuống là nội dung hiện theo cụm, nhìn gọn và dễ theo dõi nhờ các…
EA88COM.IO mình lướt thử cho biết vì thấy mọi người nhắc, kiểu vào xem giao diện là chính. Trang nhìn khá sạch sẽ, chữ dễ đọc, mấy khối nội dung chia ra rõ nên kéo xuống không bị “ngợp”. Mình để ý họ nói khá nhiều về chuyện link chính thức 2026 và nhắc cảnh báo link giả, đọc qua thấy cũng hợp lý vì dạo này mấy trang mạo danh nhiều thật. Không phải kiểu nhồi nhét quá đà, chỉ là đặt ngay chỗ dễ thấy nên ai mới vào cũng hiểu họ đang muốn nhấn gì. Mình cũng thích cái cách họ sắp tiêu đề theo cụm, nhìn lướt là biết đang ở đoạn nào, đặc biệt cái…
Precision farming equipment includes GPS-guided tractors, sensors, drones, and automated systems used to monitor and optimise agricultural operations. These technologies improve planting accuracy, irrigation efficiency, crop management, and resource utilisation, helping farmers increase productivity, reduce operational costs, and support sustainable farming practices.
https://tg88.miami/ hôm qua mình lướt thử vì thấy mấy ông bạn nói nhiều, chủ yếu tò mò xem trang họ làm kiểu gì thôi. Vào cái là thấy bố cục chia khối khá rõ, đọc lướt cũng hiểu đang nói về thương hiệu với mấy thông tin kiểu link truy cập an toàn cập nhật theo năm. Mình thích mấy cái tiêu đề to, nổi bật nên kéo xuống không bị rối mắt, kiểu mỗi đoạn đều có heading dẫn đường. Nội dung giới thiệu cũng viết gọn gàng, có nhắc họ hoạt động từ 2012 và thuộc một liên minh giải trí (đọc cho biết vậy chứ mình không đào sâu). Nói chung cảm giác trang này ưu tiên…
https://tg88host.com/ hôm trước thấy mọi người nhắc nên mình ghé thử cho biết, kiểu vào xem giao diện thôi chứ không có ngồi mò sâu. Cảm giác đầu tiên là trang làm khá “sạch”, nhìn không bị nhồi nhét lung tung nên lướt một lát là nắm được bố cục. Mình để ý cái menu đặt ngay chỗ dễ thấy, bấm qua lại mấy mục cũng nhanh, không phải kéo lên kéo xuống tìm hoài. Mấy phần thông tin họ chia thành từng khối riêng nên mắt đỡ mệt, đọc kiểu lướt vẫn hiểu. Nói chung nhìn thân thiện, không làm người mới bị ngợp, nhất là cách họ sắp xếp các khối nội dung và menu điều hướng nổi…