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.


592 Comments



Alice Castle
Alice Castle
3 hours ago

This kinetic generative art tutorial by Pierre Paslier is a brilliant introduction to creativity through code. Using p5.js to simulate pendulum motion not only teaches programming fundamentals but also highlights how structure and logic can produce mesmerizing visual harmony. Just as coding art requires balance, timing, and precision, academic projects demand careful planning and execution. For students aiming to manage their coursework with similar efficiency, project management assignment help Australia offers expert guidance to organize, plan, and deliver high-quality academic work seamlessly.

Like

Anam Rubab
Anam Rubab
a day ago

Great product recommendations. I’ll check them out. www.deeloot.com

Like

angelena
2 days ago

Using the Celebrity CrUsing the Celebrity Cruise Lines Booking Phone Number at Boston Port helps passengers conveniently handle cruise bookings, itinerary changes, cancellations, and travel assistance directly with the cruise line’s customer support for a smooth and hassle-free departure from Boston..

Like

Aria Mark
Aria Mark
2 days ago

http://bookmeter.com/users/1631049

http://maxforlive.com/profile/user/AriaMark?tab=about

http://fueler.io/ariamark

http://notefolio.net/ariam90364764

http://songtr.ee/artist/12439510/Ariamark

http://beforeitsnews.com/v3/contributor/bio/?uid=1030741

http://www.blurb.com/user/ariamark?profile_preview=true

http://www.amino.dk/members/ariamark/default.aspx

http://community.progress.com/s/profile/005Pb00000hShNp

http://www.longisland.com/profile/ariamark66

http://kitsu.app/users/1643487

http://www.ericpetersautos.com/author/AriaMark/

http://www.indiegogo.com/individuals/38806739

http://fashion-id.ru/id75392/

http://www.promoteproject.com/user/ariam9036/

http://freead1.net/ad/6143095/breeze-airways-nashville-office-18887380817.html

http://raovatonline.org/rao-vat/breeze-airways-nashville-office-1-888-738-0817/

http://adfreeposting.com/en/listing/breeze-airways-nashville-office-1-888-738-0817

http://theworldwideads.com/ad/breeze-airways-nashville-office-1-888-738-0817/

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

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

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

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

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

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

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

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

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

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

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

http://www.stylevore.com/breeze-airways-nashville-office-18887380817/

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

http://anonup.com/thread/15817014

http://zdravei.bg/post/307893_breeze-airways-nashville-office-offers-a-seamless-experience-for-travelers-needi.html

http://followingbook.com/post/558110_breeze-airways-nashville-office-offers-a-seamless-experience-for-travelers-needi.html

http://abookmarking.com/story/breeze-airways-nashville-office-1-888-738-0817-2

http://pbookmarking.com/story/breeze-airways-nashville-office-1-888-738-0817-2

http://www.letsdobookmark.com/story/breeze-airways-nashville-office-1-888-738-0817

http://www.freewebmarks.com/story/breeze-airways-nashville-office-1-888-738-0817-3

http://owntweet.com/thread/518445

http://www.wishlist.com/mywish/aVl4M4?page=1&search_string=Breeze+Airways+Nashville+Office+%2B1%E2%80%93888%E2%80%93738%E2%80%930817&srchtype=sim

http://www.classcentral.com/list/breeze-airways-nashville-office-1-888-738-0817-wgjm8virgkr8

http://www.thingstogetme.com/1845167aa32b6

http://a0afa9dd68568f7dec53612d49.doorkeeper.jp/

http://herbalmeds-forum.biolife.com.my/d/301859-breeze-airways-nashville-office-18887380817

http://ariamark.hashnode.dev/breeze-airways-nashville-office-18887380817

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

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

http://www.adsfare.com/usa/austin/breeze-airways-nashville-office-1-888-738-0817-133210

http://turquoise-koala-rz5c7g.mystrikingly.com/

http://www.whizolosophy.com/category/communication-skills/article-essay/breeze-airways-nashville-office-1-888-738-0817

http://www.sociomix.com/c/stories/breeze-airways-nashville-office-1-888-738-0817/1760095824

http://substantial-glider-b61.notion.site/Breeze-Airways-Nashville-Office-1-888-738-0817-287c67d9138180e68ee6c0b408c893f7?source=copy_link

http://livepositively.com/breeze-airways-nashville-office-1ae888ae738ae0817/

http://diigo.com/010zi0r

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

http://www.diveboard.com/ariamark/posts/breeze-airways-nashville-office-plus-1-888-738-0817-B1Mt3hN

http://medianewsfire.com/travel/breeze-airways-nashville-office-1-888-738-0817

http://glasp.co/posts/7ebe5e15-59c2-4432-9ee8-92a9dabb7dd1

http://tcsn.tcteamcorp.com/blogs/110202/Breeze-Airways-Nashville-Office-1-888-738-0817

http://buzzakoo.com/AriaMark

http://www.mateball.com/AriaMark

http://www.techsling.com/author/AriaMark/

http://commu.nosv.org/p/ariam9036

http://www.haikudeck.com/presentations/Aria.Mark

http://lawschoolnumbers.com/AriaMark

http://lincoln-goldfinchlaw.web4.one/AriaMark

http://picgiraffe.com/members-2/ariamark/

http://www.kittl.com/@ariamark

http://ncnews.co/profile/ariamark

http://raffall.com/AriaMark

http://workchest.com/freelancer/AriaMark

http://www.hugi.is/notendur/AriaMark/

http://igli.me/AriaMark

http://www.freelistingindia.in/listings/klm-airlines-frankfurt-office-18887380817

http://raovatonline.org/rao-vat/klm-airlines-frankfurt-office-1-888-738-0817/

http://adfreeposting.com/en/listing/klm-airlines-frankfurt-office-1-888-738-0817

http://theworldwideads.com/ad/klm-airlines-frankfurt-office-1-888-738-0817/

http://postlistd.com/listing/klm-airlines-frankfurt-office-1-888-738-0817/

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

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

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

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

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

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

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

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

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

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

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

http://www.stylevore.com/klm-airlines-frankfurt-office-18887380817/

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

http://anonup.com/thread/15820185

http://zdravei.bg/post/308164_the-klm-airlines-frankfurt-office-provides-comprehensive-support-for-passengers.html

http://followingbook.com/post/559027_the-klm-airlines-frankfurt-office-provides-comprehensive-support-for-passengers.html

http://abookmarking.com/story/klm-airlines-frankfurt-office-1-888-738-0817

http://pbookmarking.com/story/klm-airlines-frankfurt-office-1-888-738-0817

http://www.letsdobookmark.com/story/klm-airlines-frankfurt-office-1-888-738-0817

http://www.freewebmarks.com/story/klm-airlines-frankfurt-office-1-888-738-0817

http://www.socialbookmarkingwebsite.com/story/klm-airlines-frankfurt-office-1-888-738-0817

http://www.wishlist.com/mywish/1lvMdN?page=1&search_string=KLM+Airlines+Frankfurt+Office+%2B1%E2%80%93888%E2%80%93738%E2%80%930817&srchtype=sim

http://www.classcentral.com/list/klm-airlines-frankfurt-office-1-888-738-0817-vy8kdjsnrg5y

http://www.thingstogetme.com/1846794a67afd

http://bd3a7adee6f487799ae5411983.doorkeeper.jp/

http://herbalmeds-forum.biolife.com.my/d/302415-klm-airlines-frankfurt-office-18887380817

http://ariamark.hashnode.dev/klm-airlines-frankfurt-office-18887380817

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

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

http://www.adsfare.com/usa/austin/klm-airlines-frankfurt-office-1-888-738-0817-133230

http://emerald-shrimp-rz5c73.mystrikingly.com/

http://www.whizolosophy.com/category/communication-skills/article-essay/klm-airlines-frankfurt-office-1-888-738-0817

http://www.sociomix.com/c/stories/klm-airlines-frankfurt-office-1-888-738-0817/1760180737

http://tcsn.tcteamcorp.com/blogs/111398/KLM-Airlines-Frankfurt-Office-1-888-738-0817

http://magic.ly/AriaMark/KLM-Airlines-Frankfurt-Office-+1-888-738-0817

http://www.maliweb.net/author/ariamark

http://www.mrjourno.com/story-preview.php?storyid=1760002682

http://9ac554bc7f1cd63936d544e13f.doorkeeper.jp/

http://maps.roadtrippers.com/people/ariamark?lng=-98.35000&lat=39.50000&z=3.30945

http://www.wowchakra.com/author/AriaMark

http://marialsmith.fria.ifokus.se/discussion/1623018/turkish-airlines-vancouver-office-18887380817

Like

©2023 by Generative Hut.

bottom of page