top of page

Kinetic Generative Art Tutorial

  • Writer: Pierre Paslier
    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.


812 Comments


Alex David
Alex David
7 hours ago

this was such an interesting perspective. instagram video download helps me keep inspiring reels saved offline.


Like

kiki
kiki
21 hours ago

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

Like

uyenghomsoet.h.uy.e.n+abc123
a day ago

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…

Like

uyenghomsoet.h.uy.e.n+abc123
2 days ago

https://luck8.plus/ hôm trước mình lướt thấy ai đó thả link nên tò mò bấm vào xem thử, kiểu xem giao diện họ làm ra sao thôi chứ không định “nghiêm túc” gì. Vào trang cái thấy tiêu đề với mấy khối chữ nổi bật khá dễ nhìn, nên mình không bị lạc khi kéo xuống. Có đoạn giới thiệu họ nói nền tảng hoạt động từ 2014 và số thành viên khá đông, đọc cho biết vậy chứ mình cũng không đi kiểm tra. Mình thích kiểu trình bày gọn, chữ không quá nhỏ, các phần được chia theo cụm nên chuyển mắt khá nhẹ. Nhìn chung trang cho cảm giác cập nhật thường xuyên vì phần “tin tức cập…

Like

laurasanms311989
6 days ago

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.

Like

©2023 by Generative Hut.

bottom of page