top of page
Writer's picturePierre Paslier

Kinetic Generative Art Tutorial

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.


7,133 views29 comments

Recent Posts

See All

29 Comments


Anaya patel
Anaya patel
20 minutes ago

As a betting personnel at Khelraja, I can’t stress enough how thrilling it is to participate in India Lottery. Whether you’re new or experienced, we offer a platform that makes it easy to play and track results. I’m a result prediction expert, so I can guide you through the entire process, ensuring that you get the best chances of winning. Join Khelraja today and be part of India’s most exciting lottery community!

Like

Indusflyservices
Indusflyservices
19 hours ago

Great insights on the growing role of digital marketing in today’s business world! If you’re looking for a Digital Marketing Company in Canada, I highly recommend checking out Indusfly Services. They offer tailored digital strategies to help businesses grow their online presence effectively. Whether it's SEO, social media, or paid campaigns, their expert team ensures measurable results. 


Like

jimmy marg
jimmy marg
a day ago

The American Airlines LAX Terminal, primarily located in Terminal 4 at Los Angeles International Airport, serves as a hub for domestic and some international flights, with additional gates in the adjacent Tom Bradley International Terminal (TBIT) for international connections. This modern terminal offers a range of amenities, including comfortable seating, diverse dining options from casual to upscale, and retail outlets featuring essentials and luxury brands. Streamlined check-in counters, efficient TSA security checkpoints, and access to the Admirals Club lounges for eligible travelers enhance the travel experience. The terminal’s direct connection to TBIT also makes international and domestic transfers easy and convenient

Like

Airline Terminals
Airline Terminals
a day ago

The Frontier Terminal at Hartsfield-Jackson Atlanta International Airport offers a seamless, affordable travel experience. As the hub for Frontier Airlines, it features efficient check-in, modern amenities, and easy access to gates. Whether you're embarking on a Domestic getaway or an International adventure, ATL Airport Frontier Terminal ensures smooth, stress-free journeys. Enjoy convenient dining, shopping, and services, all while enjoying low-cost flights to a wide range of destinations.

Like

khn333777
2 days ago

The Emirates DXB Terminal at Dubai International Airport is a modern, efficient hub catering to Frontier Airlines passengers. Known for its streamlined design and emphasis on budget-friendly travel, the terminal offers convenient amenities, smooth check-ins, and quick security processing. It ensures a hassle-free experience for domestic and international travelers.

Like
bottom of page