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.



The structural utility of an advanced cdm course is increasingly defined by its integration of building information modeling workflows with mandatory health and safety files. Modern principal contractors must manage dynamic safety data drops rather than relying on static paper documentation at project handover. Health and Safety Executive research highlights a persistent gap in digital asset compliance during major renovations. One particular data mapping error within shared digital environments consistently invalidates statutory safety file updates.
https://63c.it.com/ apareceu pra mim esses dias e eu entrei sem muita expectativa, só pra ver como era por dentro. O que me chamou atenção logo de cara foi como a interface é limpa e “organizada”, tipo tudo bem separado e fácil de acompanhar sem ficar aquele caos de informação. A navegação flui bem, e não senti travadinhas enquanto ia descendo a página, o que já é meio raro. No celular também ficou bem certinho, com os textos e botões no tamanho certo, sem precisar ficar ajustando zoom. Curti também que o conteúdo é bem direto, com títulos bem visíveis, então dá pra entender rapidinho o que estão explicando sobre a plataforma. No fim, o que mais gostei foi esse jeito…
this was such an interesting perspective. instagram video download helps me keep inspiring reels saved offline.
This kinetic generative art tutorial is inspiring and accessible. It blends creative coding with motion design, making complex techniques feel approachable for artists of all levels. A great resource for exploring algorithmic creativity. --baby
EA88 bữa mình cũng ghé thử vì thấy bạn bè nhắc hoài, kiểu tò mò xem trang trông ra sao thôi. Vừa vào là thấy cái H1 “Lorem ipsum dolor sit amet…” to rõ, nhìn phát biết ngay đây là trang dạng nội dung mẫu chứ không phải gì rườm rà. Mình thích nhất là họ đặt mấy heading dạng câu hỏi ngay bên dưới, như “Lorem Ipsum là gì?” nên lướt qua cũng hiểu họ đang nói về cái gì. Nội dung thì đúng kiểu đoạn văn dài để đọc tham khảo, có nhắc tới Cicero với “De Finibus Bonorum et Malorum” nên cảm giác hơi “cổ điển” nhưng đọc cũng vui. Cuộn xuống không bị rối vì các…