Processing & Generative Art
01 Apr 2020 ∞
I follow a number of people on Twitter who make generative art, and it's something I've been wanting to try myself for a while. With everything going on I finally made the time to sit down and really play with a tool called Processing.
One of my favorite generative artists, Anders Hoff of Inconvergent, does some amazing work with plotters. My favorite piece of his is 706dbb4. I love the way the intersecting lines form a sphere, and the lines that break out of the confines of the circle are almost solar flares.
I wanted to attempt to generate a piece inspired by this print, and wanted to create something that could be drawn on a pen plotter.
I started off by connecting random vertices on the edge of a circle to one another, creating a random web of lines. Eventually I added a limit to the angles in which the vertices could be, which adds a more abstract character. After adding randomization to all of the parameters, I just kept rendering new images.
data:image/s3,"s3://crabby-images/38220/38220b6031a19ae9f61009f2bcd58ae89f41e903" alt=""
data:image/s3,"s3://crabby-images/78428/784285403ecc6a43c7547b12a53d5a548bc4e82f" alt=""
data:image/s3,"s3://crabby-images/9777a/9777a032ba87812223b6f900acf4e2cc2963b7be" alt=""
data:image/s3,"s3://crabby-images/39ac0/39ac0ed4bbe5e28f3024daf04b957c6d0e06c90a" alt=""
With some advice from Andrew Rodgers on Twitter to play with more advanced math functions like sine, cosine, exponents, etc. This came right as I was playing with using Bezier paths instead of straight lines. I created another set of vertices and modified their positions:
anchorPoint = pointOnCircle(center, center, circleRadius + 100, tan(r))
anchor1X = random(0, canvasSize)
anchor1Y = anchorPoint[1]
ancho2X = anchorPoint[1]
anchor2Y = pow(log(anchorPoint[0]), 3)
The blue and green squares are the anchors that Bezier paths move through, each with a start and end point on the circle:
data:image/s3,"s3://crabby-images/9f495/9f49521a20e9516ef1c6495d826babdba8a74f49" alt=""
The new images are much more energetic, and when the angles are small produce an internal flare of lines, as seen in the third image below.
data:image/s3,"s3://crabby-images/e40fa/e40fa75ad70ba798eacabaff115b380016084a81" alt=""
data:image/s3,"s3://crabby-images/1e16c/1e16cb2f764181a9013aa3129eda4df6852887be" alt=""
data:image/s3,"s3://crabby-images/916d3/916d30f9607b88d585d02b71bd390182011fed7c" alt=""
data:image/s3,"s3://crabby-images/9de44/9de440ef8ed608cdb348092052417d8a0b7b52b6" alt=""
All of the images (and possibly more, over time) are available over in the new Generative Art gallery. I hope this will be a fun new area to explore over time.