For more information and details, please refer to section 2 of arxiv paper: Exploring Bridges Between Creative Coding and Visual Generative AI.
GenP5 is a p5.js library enabling generative procedural art creation with flexibly stylizing canvas content with diffusion model. Stylizing Canvas Contents.
In the p5 code, programmer can flexibly create stylize and nonstylize buffers containing independent art contents, and stylize them with diffusion models as they need with library functions:
let genP5;
var storedframes = [];
let captureinterval = 5;
let finalframerate = 30;
//initiate more variables
//......
function setup() {
genP5 = new GenP5(canvas_size, canvas_bgcolor);
//initiate genP5 object with canvas size and background color
[buffer1, buffer2] = genP5.createstylizebuffers(2);
//create 2 buffers to draw stylized contents
[buffer3] = genP5.createnonstylizebuffers(1);
//create 1 buffer to draw not stylized contents
genP5.setupfinalcanvas(finalframerate, storedframes);
//create final canvas frame view + button to render final animation
}
function draw() {
genP5.clearstylizebuffercontent(buffer1); //clear contents for next frame
//draw contents in buffer1
//......
genP5.clearstylizebuffercontent(buffer2); //clear contents for next frame
//draw contents in buffer2
//......
buffer3.clear(); //clear contents for next frame
//draw contents in buffer3
//......
storedframes.push(buffer3.get()); // Store everyframe of buffer3 because it is not stylized buffer
promptlist = ["prompt for buffer1", "prompt for buffer2"];
strengthlist = [strength1, strength2];
genP5.stylize_buffers(
[buffer1, buffer2],
promptlist,
strengthlist,
5,
canvas
);
//stylize buffer1, buffer2
}
data:image/s3,"s3://crabby-images/8092d/8092d70370c868b91faa39e9efe641e98a1ccc14" alt="Screen Shot 2024-06-19 at 6 36 52 PM"
First open backend_server
and install necesseary node.js dependencies.
Get API key from fal.ai and replace it with API_KEY
in server.js
Adjust port
in server.js
if necessary
Run node server.js
, you should see:
key loaded
WebSocket Server: Running on port xxxx
Run the P5.js projects from frontend_examples/Usage1
or open on p5 web editor.
create your own art content with GenP5 in sketch.js
.
Recommended project structure:
(p5.js project folder)
-- genp5lib.js (library source code),
-- index.html,
-- sketch.js
Make sure to replace 3001 with your server port number in genp5lib.js
data:image/s3,"s3://crabby-images/0dc9e/0dc9e8596a700bc1f7be886b16a0c91bd321a46d" alt="Screenshot 2024-11-15 at 8 55 56 PM"
data:image/s3,"s3://crabby-images/2d53a/2d53ace49e21d7572716716189c7bd68e01b708d" alt="Screenshot 2024-11-15 at 8 55 44 PM"
data:image/s3,"s3://crabby-images/8f672/8f67242dac31744ee44b51efc318f3fa54b0560f" alt="Screenshot 2024-11-15 at 8 56 04 PM"
We first introduce some concepts.
background canvas refer to the p5 canvas that is created by default in any p5.js project.
Stylize buffer is the new off-screen graphics created that allow contents drawn there to be separated from the background canvas. Specifically, the contents drawn on these buffers will be stylized with DMs later.
Nonstylize buffer is also the new off-screen graphics created independently, but the contents drawn on these buffers will not be stylized with DMs later.
Normally drawn p5.js contents will be shown as rendered p5 animations of all the frames. However, to turn them into processable entities for DMs, we need to capture frame images at a certain capture rate.
Original frame images are those images captured from different stylize buffers, with frame index as sequence numbers. They will be processed by DMs and result in stylized frame images as a one-to-one correspondence.
Finally, all the original frame images from background canvas and all the stylized frame images in different stylize buffers who share the same frame index will be overlayed sequentially to create a single final frame image at this frame index. Notice that a background-removal algorithm will be applied to all the stylize buffers before they are overlayed. Moreover, For the p5 content animations in the nonstylize buffer, instead of turning the frames into frame images, we directly store each frame as p5 objects since they do not need to be stylized. In the final step, for all the final frame images and stored frames from nonstylize buffer, if they share the same frame index, they will be overlayed sequentially, to create final frames composing a final animation in a new final canvas.
The library will automatically render simple UIs for programmers to keep track of original and generated contents on each buffer, and the results combining them:
The second part of GenP5 is the functionalities to condition the art creation with predetermined patterns (e.g., color, shape). These predetermined patterns are provided by external images (existing images or generated images from DM).
We provide functions to allow user use input colorful images as color sources and black-white images as contour sources to condition p5 contents:
Example:
let particles = [];
maincanvassize = 400
let sampledColors = []
function setup() {
genP5 = new GenP5(maincanvassize, '#FFFCFD');
// get contour and color from customized images
genP5.get_NSampledColors('./colorimage.png', 0, 16).then((colors) => {
sampledColors = colors; // Store the sampled colors
genP5.load_ContourMap('./contourimage.png', setParticles);
}).catch((error) => {
console.error("Failed to load or sample colors:", error);
});
}
// draw some art with particles
function draw() {
frameRate(20);
clear()
for (let p of particles) {
p.move();
p.update();
p.display();
}
}
// initiate particles on contour
function setParticles() {
particles = [];
let sampledPoints = genP5.sample_ContourPoints(68000);
for (let point of sampledPoints) {
particles.push(new Particle(point.x, point.y));
}
}
class Particle {
//code to define a particle
}
data:image/s3,"s3://crabby-images/473be/473be35d43486388271f039121125876c7a992dc" alt="Screen Shot 2024-06-20 at 12 20 27 AM"
Directly run the example p5 projects from frontend_examples/Usage2
or open on p5 web editor.
create your own art content with GenP5 in sketch.js
and adding customized images as color/contour (black-white images) source in project folder.
Recommended project structure:
(p5.js project folder)
-- genp5lib.js (library source code),
-- index.html,
-- sketch.js
-- color or contour images
data:image/s3,"s3://crabby-images/846e0/846e0df8829c07a63f5f076d4ffc6c67bf201031" alt="Screen Shot 2024-06-20 at 12 28 36 AM"
data:image/s3,"s3://crabby-images/5b847/5b847dd451e48a1d0a5b802aa3b73e7ba8c0ca6e" alt="Screen Shot 2024-06-20 at 12 26 49 AM"
If you find it inspiring, please consider cite our source:
@misc{wu2024exploring,
title={Exploring Bridges Between Creative Coding and Visual Generative AI},
author={Jiaqi Wu},
year={2024},
eprint={2406.05508},
archivePrefix={arXiv},
primaryClass={id='cs.HC' full_name='Human-Computer Interaction' is_active=True alt_name=None in_archive='cs' is_general=False description='Covers human factors, user interfaces, and collaborative computing. Roughly includes material in ACM Subject Classes H.1.2 and all of H.5, except for H.5.1, which is more likely to have Multimedia as the primary subject area.'}
}