Preview: When Computers create Collages
2023-12-01 Today I want to share with you a first prototype that will be the basis for a new course that will probably be called “When Computers create Collages”. In this application, a stack of images is loaded and transformed into any number of computer-generated collages.
data:image/s3,"s3://crabby-images/4e5c9/4e5c9fa11b066d930e8c5ef77ef4ec29758f7d83" alt=""
data:image/s3,"s3://crabby-images/03509/03509f44fc1eeff5ff240e82851b6f62fca1dd64" alt=""
data:image/s3,"s3://crabby-images/0e3a3/0e3a39a8b7915198645e1e498b372f7737a49316" alt=""
data:image/s3,"s3://crabby-images/559f1/559f15143cfc76ea18082d23b6060ef493a91405" alt=""
data:image/s3,"s3://crabby-images/a4119/a4119e43fc220ad1195e94d539c3ddab96929035" alt=""
data:image/s3,"s3://crabby-images/9313f/9313fc55320f79ee83962ff9593a3c04a0fa4ec7" alt=""
data:image/s3,"s3://crabby-images/a12af/a12afc1ef8c2b31207df8f2b847e62ccb30cd6e3" alt=""
data:image/s3,"s3://crabby-images/3528e/3528ed36c1bc26ba14862cdbdebbd1dcc5584a6a" alt=""
data:image/s3,"s3://crabby-images/36df4/36df4113182a86d61f754cc042d492ffa59431ae" alt=""
int amount = int(random(5, 25));
PGraphics[] layers = new PGraphics[amount];
PGraphics[] masks = new PGraphics[amount];
import java.io.File;
String [] imageFileNames;
StringList images;
void setup() {
size(1200, 900);
java.io.File folder = new java.io.File(dataPath("images"));
imageFileNames = folder.list();
images = new StringList();
println("loading...");
// Load the image-files and push thems to imagess-arrayList
for (int i = 0; i < imageFileNames.length; i++) {
String filename = imageFileNames[i];
if (filename.indexOf("Store") == -1) {
images.push("data/images/"+filename);
}
}
println(images.size() + " images loaded!");
for (int i = 0; i < layers.length; i++) {
layers[i] = createGraphics(width, height);
masks[i] = createGraphics(width, height);
}
}
PGraphics l, m;
PImage img;
void draw() {
amount = int(random(3, 30));
background(0);
//blendMode(SCREEN);
for (int i = 0; i < layers.length; i++) {
l = layers[i];
img = loadImage(images.get(int(random(images.size()))));
img.resize(width, 0);
l.beginDraw();
l.clear();
l.push();
l.image(img, 0, 0);
l.pop();
l.endDraw();
m = masks[i];
m.beginDraw();
m.background(#FFFFFF);
m.noStroke();
m.fill(0);
m.beginShape();
for (int j = 0; j < 12; j++) {
float x = random(-width, width*2);
float y = random(-height, height*2);
m.curveVertex(x, y);
}
m.endShape();
if (random(1) < 0.1) {
m.circle(random(width), random(height), random(width/2));
}
m.endDraw();
l.mask(m);
image(l, 0, 0);
}
saveFrame("out/###.png");
}
Enjoying the content?
I put a lot of love and effort into developing content on Creative Coding. Since 2018, I have published 228 interviews, case studies, and tutorials, along with over 319 lessons in 20 online courses – and there's more to come! If you'd like to support my work and help keep this platform evolving, please consider supporting me on Patreon. Thank you very much!
data:image/s3,"s3://crabby-images/bcc18/bcc18e72d2a7347eca5c0373ec6a15d631117407" alt="Speaking Image"
Related
data:image/s3,"s3://crabby-images/b597f/b597fc8212b0dbe3c0ed056aee867f15ca32fc55" alt=""
Click here to login or connect!To view this content, you must be a member of Tim's Patreon at €7 or […]
data:image/s3,"s3://crabby-images/83d9c/83d9c9a1d5f2cb5f3f54934d2aafc741e1b50a45" alt=""
For my students at Elisava, I have created a new version of my mockup-tool. You need two different files for […]
data:image/s3,"s3://crabby-images/ee249/ee24900fd72373f8a68d67bc4677a772903bf01c" alt=""
Click here to login or connect!To view this content, you must be a member of Tim's Patreon at €7 or […]
data:image/s3,"s3://crabby-images/0e85e/0e85efc6f7a876fbf19cb15d192a1d8668ffd9eb" alt=""
A few months ago I made a small app that allows you to create image collages with some kind of […]
data:image/s3,"s3://crabby-images/03bc8/03bc87000ccc30d2df1d320c8cc1b1032ee13483" alt=""
Since the beginning of the Corona crisis, I have been more and more interested in the history of ancient philosophy. […]
data:image/s3,"s3://crabby-images/05be9/05be905d6eb36405f48f2f1d3123ba3ab62890c3" alt=""
Generative visuals made from the "Prelude in C" by Johann Sebastian Bach.
data:image/s3,"s3://crabby-images/aa905/aa9057e6babc9a7d9a2062e5a43497b96853631c" alt=""
Click here to login or connect!To view this content, you must be a member of Tim's Patreon at €7 or […]