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.


794 Comments


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

okfun app mình thấy bạn bè nhắc hoài nên cũng ghé thử cho biết, kiểu vào lướt nhanh vài phút lúc rảnh thôi chứ chưa kịp mò kỹ. Cảm giác đầu tiên là trang nhìn khá “dễ thở”, không bị nhồi quá nhiều thứ lên một màn hình nên kéo xuống cũng nhẹ nhàng. Mình để ý phần điều hướng menu đặt chỗ nằm khá nổi, bấm qua lại mấy mục thấy phản hồi nhanh, không phải tìm vòng vòng. Font chữ với màu nền cũng vừa mắt, đọc không mỏi, nhất là khi xem trên điện thoại. Nói chung mới dùng sơ sơ mà thấy họ chia nội dung thành từng khối rõ ràng, nhìn phát là biết đang…

Like

robert50powell.9.5.8.4+abc123
3 days ago

xoilac tv mình ghé thử lúc đang tìm chỗ coi bóng đá cho lẹ, kiểu vào phát là thấy ngay chỗ xem trực tiếp nên không phải mò mẫm nhiều. Giao diện nhìn đơn giản, chữ dễ đọc, lướt trên điện thoại cũng ổn chứ không bị rối mắt. Mình để ý nhất là trang tải khá nhanh, bấm qua lại mấy mục vẫn mượt, không kiểu đứng hình chờ hoài. Ngoài phần xem thì có khối tin tức bóng đá cập nhật đặt khá rõ ở ngay trang, kéo xuống cái là thấy ngay nên tiện xem nhanh hôm nay có gì mới. Nói chung cảm giác họ làm cho người vào là dùng được liền, nhất là cái…

Like

Nancy Figgs
Nancy Figgs
4 days ago

Delta Offices are dedicated to enhancing the overall customer experience by providing high-quality service and support. Representing Delta Air Lines, these offices ensure that passengers receive the assistance they need at every stage of their journey.


Like

michelwenzer
4 days ago

Hi. Where is the actual tutorial? I only see an introduction and the code (+running code). Then a prompt" let's dive in and start...", Where do I "dive in"? Best Michel

Like

James
James
6 days ago

Great insights on lead nurturing, especially the section on automation workflows. SISGAIN Real Estate applies similar strategies through custom real estate crm software development to streamline follow-ups, improve agent productivity, and manage property leads efficiently.


Like

©2023 by Generative Hut.

bottom of page