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.


818 Comments


Orion Hunter
Orion Hunter
20 hours ago

A quality city tour chauffeur service makes sightseeing much easier. You can simply relax and enjoy the destination without worrying about directions or parking.

Like

ruwokaheqy
a day ago

일정 조율이 쉬워 개인 생활과 병행하기 좋습니다. 중간에 관련 내용을 포함하니 활용성과 장점이 잘 드러나 독자 입장에서 이해하기 유흥알바 편했습니다.


Like

katrinacha.vez.52.0.2
a day ago

https://789bet.agency/ hôm trước mình thấy ai đó nhắc nên tiện tay vào thử cho biết thôi, chứ cũng không ngồi đọc kỹ hay bấm chơi gì. Vào cái là thấy giao diện khá thoáng, nhìn không bị “ngộp” chữ như nhiều trang khác. Mình để ý họ chia nội dung thành từng khối rõ ràng nên lướt một vòng là biết chỗ nào nằm ở đâu, không phải căng mắt tìm. Thanh menu cũng đặt dễ thấy, chuyển qua lại mấy mục khá mượt, không bị vòng vo. Nói chung cảm giác họ làm bố cục gọn gàng, nhìn sạch sẽ và các block nội dung tách bạch ngay trên trang.

Like

Urban Hub UK
Urban Hub UK
a day ago

Preston accommodation offers a wide range of comfortable and affordable living options for students and professionals. With modern facilities, convenient locations, excellent transport connections, and easy access to universities, shopping, and entertainment, residents can enjoy a practical and enjoyable lifestyle.

Like

John Snow
John Snow
3 days ago

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.

Like

©2023 by Generative Hut.

bottom of page