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.


820 Comments


seo work
seo work
a day ago

Game3RB offers a centralized space for exploring PC gaming content and related information. Covering a diverse selection of genres, the platform helps users discover games, review key details, and follow updates from the broader gaming community. Its organized approach makes it easy to navigate and find content relevant to different gaming preferences.

Like

kandadaa.mri.ttg+abc123
a day ago

f168 com bữa mình thấy mấy đứa bạn nhắc nhẹ nên cũng bấm vào coi thử cho biết thôi. Mình không có ngồi tìm hiểu nội dung hay làm gì nhiều, chủ yếu lướt qua xem họ thiết kế trang ra sao. Cảm giác đầu tiên là giao diện nhìn khá sáng và dễ thở, không bị nhồi nhét quá nhiều thứ một lúc. Mấy phần thông tin được chia thành từng khối rõ ràng nên mắt mình bắt nhịp nhanh, biết chỗ nào để xem tiếp mà không phải đoán. Mình cũng để ý thanh menu đặt khá dễ thấy nên chuyển qua lại vài mục không bị rối. Nói chung lướt tầm vài phút là quen tay, vì…

Like

Orion Hunter
Orion Hunter
3 days 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
3 days ago

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


Like

katrinacha.vez.52.0.2
3 days 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.

Edited
Like

©2023 by Generative Hut.

bottom of page