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.


521 Comments


jakejackson
12 hours ago

With extensive experience in personal injury law Edmonton clients rely on, Martin G. Schulz & Associates deliver strategic legal solutions tailored to your case. Their proven track record makes them a trusted choice for injury claims.

Like

Eri Mark
Eri Mark
21 hours ago

http://foromodelacion.cemieoceano.mx/member.php?action=profile&uid=10956

http://w.bibliotece.pl/community/users/erimark6653/

http://www.cheaperseeker.com/u/EriMark

http://www.mises.cz/autori/erimark-11169.aspx

http://www.outsideonline.com/activity/53f82e80-9e88-11f0-8080-800011ce4722?utm_source=www.outsideonline.com&utm_medium=sharedlink&utm_campaign=activityfeed

http://start.me/w/QAGaPj

http://hallbook.com.br/blogs/751799/Etihad-Airlines-Baggage-Policy-1-866-666-0215

http://xtiles.app/68dcc270667265678a7be409

http://coinmarketcap.com/community/post/368969620

http://www.toontrack.com/forums/users/erimark/

http://enterthebible.org/members/erimark/

http://www.prodesigns.com/wordpress-themes/author/EriMark

http://ocean.chronicleproject.com/forums/users/erimark/

http://dlive.tv/u/EriMark

http://alumni.ulacit.ac.cr/miembros/erimark6653_gmail-com/

http://theworldwideads.com/ad/etihad-airlines-baggage-policy-1-866-666-0215-1/

http://www.bulkadspost.com/classifieds/etihad-airlines-baggage-policy-1-866-666-0215/

http://postlistd.com/listing/etihad-airlines-baggage-policy-1-866-666-0215-2/

http://adfreeposting.com/en/listing/etihad-airlines-baggage-policy-1-866-666-0215

http://raovatonline.org/rao-vat/etihad-airlines-baggage-policy-1-866-666-0215/

http://unolist.in/desc/728177_Etihad-Airlines-Baggage-Policy-1-866-666-0215.html

http://FreeAdsOnline.biz/389/posts/3/25/1830732.html

http://fWebDirectory.com/482/posts/3/25/1813103.html

http://ClassifiedOnlineAds.net/389/posts/3/25/1822772.html

http://Classifieds4Free.biz/393/posts/3/25/1812834.html

http://NextFreeAds.com/482/posts/3/25/1832599.html

http://GetAdsOnline.com/482/posts/3/25/1826704.html

http://FoldAds.com/588/posts/3/25/1820319.html

http://PostHereAds.com/513/posts/5/36/1792885.html

http://www.adsfare.com/usa/austin/etihad-airlines-baggage-policy-1-866-666-0215-132922

http://medianewsfire.com/travel/etihad-airlines-baggage-policy-1-866-666-0215

http://www.sociomix.com/c/stories/etihad-airlines-baggage-policy-1-866-666-0215/1759310365

http://hackmd.io/@C_G0If-IQFGsnANQekqDwQ/H13LHv9hll

http://app.jenni.ai/published/docs/bQZk4BjosPGZMOADf40R

http://glasp.co/posts/f15e7d77-8a4f-4eb7-b222-818997cc8aae

http://www.youthkiawaaz.com/2025/10/etihad-airlines-baggage-policy-1-866-666-0215/?success=1

http://www.startovac.cz/projects/erimark?ref=PROJECT_HEADER

http://pin.it/15HJuacMB

http://www.besport.com/l/kLLyfI-d

http://seo.entireweb.com/reports/211300

http://learningapps.org/display?v=pp9vwj30525

http://www.wishlist.com/mywish/RE1rvm?page=1&search_string=Etihad+Airlines+Baggage+Policy++%2B1%E2%80%93866%E2%80%93666%E2%80%930215&srchtype=sim

http://www.classcentral.com/list/etihad-airlines-baggage-policy-1-866-666-0215-nymmboixxwpy

http://www.stylevore.com/etihad-airlines-baggage-policy-18666660215/

http://www.thingstogetme.com/1829800a001d6

http://followingbook.com/post/549767_etihad-airlines-baggage-policy-ensures-that-travelers-understand-exactly-what-to.html

http://hackmd.okfn.de/s/Hyefndc3ge

http://zdravei.bg/post/304511_etihad-airlines-baggage-policy-ensures-that-travelers-understand-exactly-what-to.html

http://smart-lily-r7bsrh.mystrikingly.com/

http://anotepad.com/note/read/rii6yex5

http://bouncy-kettledrum-bfd.notion.site/Etihad-Airlines-Baggage-Policy-1-866-666-0215-27fe956fe7b1804982e5dc63d360d446?source=copy_link

http://cloudhound.flarum.cloud/d/120217-etihad-airlines-baggage-policy-1-866-666-0215

http://herbalmeds-forum.biolife.com.my/d/297162-etihad-airlines-baggage-policy-18666660215

http://www.insurances.net/viewthread.php?tid=3587363&extra=

http://sg-docs.gogox.com/discuss/68dcffbecbecb65a91b1b796

http://anonup.com/thread/15789747

http://www.zybuluo.com/erimark/note/2627752

http://owntweet.com/thread/511016

http://sharing.clickup.com/90161226301/t/h/86d0fytkp/1JCK62GCILIAUBF

http://form.typeform.com/to/EcZctrpj

http://slimwiki.com/erimark/getting-started/etihad-airlines-baggage-policy-1-866-666-0215-vc1gzr52t5-brvsapwo96we

http://daddycow.com/blogs/view/63168/etihad-airlines-baggage-policy-1-866-666-0215

http://livepositively.com/etihad-airlines-baggage-policy-1ae866ae666ae0215/

http://erimark.hashnode.dev/etihad-airlines-baggage-policy-18666660215

http://sites.google.com/view/erimark18/home

http://www.diveboard.com/erimark/posts/etihad-airlines-baggage-policy-plus-1-866-666-0215-B3bQ2Nz

http://www.dropbox.com/scl/fi/gk9lm8lk5kigo88p7o5o6/Etihad-Airlines-Baggage-Policy-1-866-666-0215.paper?rlkey=ftfbu9g10851dxzyuix1h0al3&st=cxn3xtcn&dl=0

http://www.deviantart.com/erimark66/art/Etihad-Airlines-Baggage-Policy-1247640824

http://diigo.com/010wcnh

http://blogsgod.com/etihad-airlines-baggage-policy-1-866-666-0215/

http://paidforarticles.in/etihad-airlines-baggage-policy-18666660215-877786

http://ivebo.co.uk/read-blog/174357

http://www.whizolosophy.com/category/communication-skills/article-essay/etihad-airlines-baggage-policy-1-866-666-0215

http://logcla.com/blogs/914762/Etihad-Airlines-Baggage-Policy-1-866-666-0215

http://comunidad.espoesia.com/eri_mark/etihad-airlines-baggage-policy-1-866-666-0215/

http://postr.blog/etihad-airlines-baggage-policy-18666660215

http://groups.google.com/g/ustravellejohnalex/c/CWhGdqJqRss/m/tQ-EibM6AAAJ

http://alumni.myra.ac.in/read-blog/431572

http://pin.it/5Ij2KAPYX

http://baggageinfo123.blogspot.com/2025/10/etihad-airlines-baggage-policy.html

http://medium.com/@erimark6653/aeroitalia-airlines-baggage-policy-1-866-666-0215-eaf6d17bc910

http://postlister.com/user/profile/20943

http://connect.amshq.org/network/members/profile?UserKey=01a38e60-574e-4e49-9232-0199a34761ad

http://getjoys.net/author/EriMark/

http://panorama.solutions/en/user/eri-mark

http://puheenvuoro.uusisuomi.fi/author/eri-mark/

http://forum.singaporeexpats.com/memberlist.php?mode=viewprofile&u=681906

http://wpfr.net/support/utilisateurs/EriMark/

http://gettogether.community/profile/392618/

http://app.neptune.ai/erimark6653

http://litmus.com/p/erimark

http://freead1.net/ad/6126360/aeroitalia-airlines-baggage-policy-18666660215.html

http://theworldwideads.com/ad/aeroitalia-airlines-baggage-policy-1-866-666-0215/

http://www.bulkadspost.com/classifieds/aeroitalia-airlines-baggage-policy-1-866-666-0215/

http://postlistd.com/listing/aeroitalia-airlines-baggage-policy-1-866-666-0215/

http://adfreeposting.com/en/listing/aeroitalia-airlines-baggage-policy-1-866-666-0215

http://raovatonline.org/rao-vat/aeroitalia-airlines-baggage-policy-1-866-666-0215/

http://unolist.in/desc/728278_Aeroitalia-Airlines-Baggage-Policy-1-866-666-0215.html

http://FreeAdsOnline.biz/389/posts/3/25/1832140.html

http://fWebDirectory.com/482/posts/3/25/1814271.html

http://ClassifiedOnlineAds.net/389/posts/3/25/1824092.html

http://Classifieds4Free.biz/393/posts/3/25/1814122.html

http://NextFreeAds.com/482/posts/3/25/1833964.html

http://GetAdsOnline.com/482/posts/3/25/1827830.html

http://FoldAds.com/588/posts/3/25/1821478.html

http://PostHereAds.com/513/posts/5/36/1793727.html

http://www.stylevore.com/aeroitalia-airlines-baggage-policy-18666660215/

http://pin.it/7bylacIC4

http://www.besport.com/l/TlVFxhBY

http://hallbook.com.br/blogs/753459/Aeroitalia-Airlines-Baggage-Policy-1-866-666-0215

http://www.adsfare.com/usa/austin/aeroitalia-airlines-baggage-policy-1-866-666-0215-132949

http://medianewsfire.com/travel/aeroitalia-airlines-baggage-policy-1-866-666-0215

http://www.sociomix.com/c/stories/aeroitalia-airlines-baggage-policy-1-866-666-0215/1759390767

http://hackmd.io/@C_G0If-IQFGsnANQekqDwQ/S12hFsjnxx

http://coinmarketcap.com/community/post/369017647

http://www.outsideonline.com/activity/d35b3000-9f64-11f0-8080-80006a41766e?utm_source=www.outsideonline.com&utm_medium=sharedlink&utm_campaign=activityfeed

http://learningapps.org/display?v=pbig9qdoc25

http://www.wishlist.com/mywish/RE1Vbq?page=1&search_string=Aeroitalia+Airlines+Baggage+Policy++%2B1%E2%80%93866%E2%80%93666%E2%80%930215&srchtype=sim

http://www.classcentral.com/list/aeroitalia-airlines-baggage-policy-1-866-666-0215-o2qq3pfvv8y7

http://seo.entireweb.com/reports/211426

Like

Mollie Talbot
Mollie Talbot
a day ago

Meeting the safety management course requirements is essential for professionals aiming to advance in health and safety roles. Most programs expect learners to have prior knowledge or experience in safety practices or related fields. This ensures that participants can engage with advanced concepts and practical applications effectively. Employers often prefer candidates who have completed higher-level qualifications in safety management. You can meet these requirements and gain expertise through Uniccm.

Like

Happyluckyda
a day ago

This p5.js tutorial brings the hypnotic orbits of Core Ballまち針ゲーム to life through the motion of swirling pendulums; it merges code-driven kinetics with the vibrant bounces of a game, creating a captivating digital animation spectacle.

Like

One union solutions
One union solutions
2 days ago

Importer of record services USA help companies handle customs, duties, and compliance for shipments into the United States.


Like

©2023 by Generative Hut.

bottom of page