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.


853 Comments


katrinacha.vez.52.0.2
11 hours ago

ball88 mình vừa lướt thử vì thấy bạn bè nhắc, vào cái là thấy giao diện làm kiểu tối giản nên đỡ bị ngợp. Mấy khối nội dung nhìn gọn gàng, tập trung vào phần sảnh lobby nên mình tìm chỗ cần bấm khá nhanh, không phải dò từng mục như nhiều trang khác. Có đoạn nói về cách truy cập an toàn bằng VPN 1.1.1.1, viết ngắn gọn nên đọc lướt cũng hiểu ý chứ không kiểu hướng dẫn dài lê thê. Mình cũng thích mấy phần thông tin trình bày dạng bảng cột, nhìn sạch và dễ quét mắt. Nói chung cảm giác họ ưu tiên sự rõ ràng hơn là nhồi hiệu ứng, và các block nội…

Like

dhara234ni
16 hours ago

I studied Graphic Design Courses in Chennai, where I learned the fundamentals of visual communication, color theory, typography, and design tools. This experience helped me create creative and impactful designs while understanding user needs. It also improved my creativity and technical skills, preparing me to work on real-world design projects confidently.


Like

Karan Mathew
Karan Mathew
16 hours ago

Modern routines can often become mentally and physically exhausting without people realizing it immediately. Taking small breaks and maintaining balanced habits has become increasingly important in today’s fast-paced lifestyle. Many individuals now look for simple ways to relax and slow down occasionally within their daily schedules. In a similar way, Best Spa In Velachery is often explored by people interested in calm environments and wellness experiences that encourage relaxation and overall comfort.


Like

zoya khan
zoya khan
19 hours ago

Great post! I found this AC installation in Dubai article both informative and enjoyable to read.

Like

Wright Price
Wright Price
a day ago

hnd law qualification provides a strong foundation in legal principles, contract law, and the practical application of legal concepts. It is a useful pathway for those looking to expand legal knowledge before progressing to higher qualifications or related careers. The College of Contract Management offers flexible online law courses that support professional development through structured learning.


Like

©2023 by Generative Hut.

bottom of page