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.


233 Comments


Larry Walker
Larry Walker
2 hours ago

Thankyou  for this  wondrous post, I am glad I  observed  this website   on yahoo. Check our best best housekeeping services near me.

Like

Space Joy
Space Joy
3 hours ago

Abstract pattern wallpapers are a popular choice for modern homes, offering a unique blend of texture, movement, and artistic expression. These wallpapers range from soft, delicate designs that create a calm and airy ambiance to bold, structured patterns that add depth and sophistication. Whether inspired by nature, architecture, or fluid artistry, abstract wallpapers can elevate any space, complementing various interior styles. Their versatility makes them suitable for living rooms, bedrooms, hallways, and workspaces, allowing homeowners to craft an environment that reflects their personal aesthetic while maintaining a contemporary feel.

Like

johnanderson
johnanderson
8 hours ago

https://participacion.puertodelrosario.org/profiles/terminalease/activity

https://www.yapstate.gov.fm/forum/main/comment/5c0ab2bb-775e-4271-81d6-ef6a970e5eee?postId=6434dfe44511b6001214c969

https://parsif.al/terminalease/

https://crabbygirlcreations.com/index.php?journal_blog_post_id=1&route=journal3%2Fblog%2Fpost

https://colibris-wiki.org/Tecap2182/?terminalease

https://desksnear.me/users/terminal-ease

https://siapabilang.com/johnanderson

https://www.atipabangkok.com/en/forum/topic/467791/exploring-convenient-flights-from-tampa-to-atlanta

https://www.generativehut.com/post/kinetic-generative-art-tutorial?commentId=633f4340-7796-408e-af59-b27d9190a868

https://www.udrpsearch.com/user/terminalease

http://forko.diskutuje.cz/forum/

https://careers.gita.org/profiles/6841447-terminal-ease

https://vaindeais.com/index.php?journal_blog_post_id=1&route=journal3%2Fblog%2Fpost

https://www.medstartr.com/profile/43969-Terminal-Ease

https://www.muaygarment.com/forum/topic/466180/turkish-airlines-nairobi

https://www.ong-amss.org/infos/main/comment/46d65445-b981-49f4-8e15-d0743ec725de?postId=65bf311503cc0100104143d9

https://www.sekarswiss.ch/blog/best-beauty-products

https://doras.to/terminalease

http://www.izolacniskla.cz/forum-detail.php?dt_id=33507

https://tlcdfw.iteach.world/profile/107635/Terminal%20Ease

https://www.dieteticienne-lorraine.com/single-post/comment-choisir-un-plat-pr%C3%A9par%C3%A9?commentId=8d7176e7-3c9e-4fbc-8986-14fee2d19ffb

https://www.gaymalta.com/post/england-thanks-to-your-support-in-euro-2020?commentId=0e6ad55f-d6ab-46bf-b017-59d0141fe61f

https://www.sitterwise.com/post/legoland-miniland-fun?commentId=4ef77bba-96bd-4c29-adf0-3887749e9a96

https://www.freebookmarkingsubmission.net/page/other/explore-the-lufthansa-cancellation-policy-terms-and-conditions

https://formulamasa.com/elearning/members/termialease/?v=96b62e1dce57

https://wtoregister.com/en/profile/115598/terminal

https://www.aretefinance.com.au/forum/main/comment/34fb0f7e-6172-4a76-868a-75e3dbb04c75?postId=67421022d30683f9092d5264

https://www.diverseplastics.co.za/forum/main/comment/48ef3aa4-c113-4f1d-8bb8-42bc1213146c?postId=632adcc99789430012fdb8b0

https://www.northernskinstudio.com/forum/main/comment/cacf381a-d07a-421a-b5d5-0e6d017d7816?postId=64939eaf33e6770012f34d35

http://2-0092.com/CMS/userinfo.php?uid=10439

https://kizuato.sakura.ne.jp/cgi-bin/nbs2/nbs.cgi

https://bookmark4you.online/page/other/explore-the-lufthansa-cancellation-policy-terms-and-conditions

http://code.qutaovip.com/terminalease

http://newdigital-world.com/members/terminalease.html

https://onlinedigitalbookmark.com/page/other/explore-the-lufthansa-cancellation-policy-terms-and-conditions

http://sdh.jerisno.cz/sdhjerisno/index.php/kniha-navstev

https://sbmoffpagesites.com/page/other/explore-the-lufthansa-cancellation-policy-terms-and-conditions

https://seoprovidercompany.com/page/other/explore-the-lufthansa-cancellation-policy-terms-and-conditions

https://seosubmissionsiteslist.com/page/other/explore-the-lufthansa-cancellation-policy-terms-and-conditions

https://simplesiteseo.com/page/other/explore-the-lufthansa-cancellation-policy-terms-and-conditions

https://perpetual-addition-ec1.notion.site/Explore-The-Lufthansa-Cancellation-Policy-Terms-And-Conditions-226aa9fac15d8096a9deda6b98a06777

https://blacksocially.com/terminalease

https://dapp.orvium.io/profile/terminal--ease

https://www.napavas.com/profile/johnanderson4291351268/profile

https://www.nvthespians.org/profile/johnanderson4291349423/profile

https://epifaniocruz.wixsite.com/paubaya/profile/johnanderson4291350704/profile

https://participer.fleurylesaubrais.fr/profiles/Ease/activity

https://edutous.com/explore-the-lufthansa-cancellation-policy-terms-and-conditions-2/

https://www.megavalanchetrail.com/profile/johnanderson4291379428/profile

https://www.mamaschocolate.com/profile/johnanderson4291355673/profile

https://www.ikengineering.org/profile/johnanderson429135795/profile

https://www.vladeguigni.com/profile/johnanderson4291325995/profile

https://www.denverviral.com/profile/terminalease

https://www.sgcarshoppers.com/profile/johnanderson4291314174/profile

https://www.vanlifeuksurvivorsguide.co.uk/profile/johnanderson4291360467/profile

https://www.mslrefoils.com/profile/johnanderson4291329330/profile

https://farm86.com/terminalease

https://fnfansite.wixstudio.com/fridaynightfansite/profile/johnanderson4291324377/profile

https://forumforex.id/forum/diskusi-forex/tentang-forex/14845-my-friends-experience-at-heathrow

https://jasuog.wixsite.com/learning/forum/main/comment/7db5c3d2-5492-4606-93da-78f0eb3b3a41?postId=608f771858eedb0016890a72

https://id.devby.io/users/terminalease

https://ks4044820.wixsite.com/subhashnagarescorts/post/get-sexy-massage-by-west-bengal-escorts?commentId=bfd1b8cd-457b-452e-a318-80f40d8a291c

https://kktix.com/user/7592887

https://www.languagepacifica.com/post/winter-words?commentId=96fa84c8-d4f4-4ada-a0db-89ac27369c52

https://www.clayandglass.on.ca/group/faces-of-fusion-in-february-thomas-aiken-group/discussion/38981017-65ea-4f8a-b7ea-b11168424841

Like

lila summer
lila summer
9 hours ago

A project coordinator has the responsibilities in handling schedules, budgets, and team communication everyday. In order to succeed in this role, strong organisational and interpersonal skills are required. The College of Contract Management provides  training programs that prepare you for the responsibilities and required skills. Studying with them can be a smart way to start your journey in this role.

Like

vandanaswarajmanturgekar
10 hours ago

Dimethyl Ether (DME) is a colorless, non-toxic gas with the chemical formula CH₃OCH₃, primarily used as a clean-burning alternative fuel and aerosol propellant. It is produced through the dehydration of methanol or directly from synthesis gas (a mixture of carbon monoxide and hydrogen), and its physical properties are similar to those of liquefied petroleum gas (LPG). Due to its high cetane number and excellent combustion characteristics, DME is increasingly considered a promising substitute for diesel in compression ignition engines. Its environmental benefits include significantly lower emissions of nitrogen oxides (NOx), particulate matter (PM), and sulfur oxides (SOx), making it suitable for cleaner energy applications, especially in transportation and power generation.

Beyond its fuel potential, dimethyl ether is widely utilized in the…

Like

©2023 by Generative Hut.

bottom of page