Hi guys,
Is there a way to code a program that proceses text and displays them as specific shapes in processing?
An example of this is the work of Leslie Roberts
https://leslierobertsart.com/section/425019-Recent-works-on-panel.html
we’ve tried making an array with the keyboard keys and the shapes as classes but so far nothing has worked.
thanks!
1 Like
show your code then
that’s the most simple:
int lowerRightCornerX;
String list="asd";
//
// ---------------------------------------------------------------
//
void setup()
{
// init
size(800, 600);
lowerRightCornerX=86 ;
} // func
void draw()
{
background(255);
int x=1;
for (char c : list.toCharArray()) {
switch (c) {
case 'a':
triangle(60*x+4, 75,
58*x+4, 20,
lowerRightCornerX*x*1+4, 75);
break;
case 's':
rect(60*x+4, 20,
33, 56);
break;
case 'd':
ellipse(60*x+4, 20+33,
33, 33);
break;
default:
break;
}//switch
x++;
}//for
} // func
//
// =====================================================================
2 Likes
Wow, by now I improved it greatly!
Also see P.3 in here: http://www.generative-gestaltung.de/1/code
2 Likes
Agreed that Generative Gestaltung is a great resource for projects like yours. Note that they have a little “EN” link if you want the English version of the pages, or direct link:
http://www.generative-gestaltung.de/1/lang/en
You should share what you have attempted!
Do you want something more like an interactive shape typewriter, or do you want to load a text file and display an image?
Here is a very, very simple example of an interactive “shape typer” – no classes, just a core concept.
/**
* SimpleShapeTyper
* 2019-04 Processing 3.4
* discourse.processing.org/t/process-text-as-shapes/10006/4
**/
PVector cursor;
int dim = 20;
void setup() {
cursor = new PVector(0, 0);
}
void draw() {
}
void keyPressed() {
if (key%2==0) {
rect(cursor.x, cursor.y, dim, dim);
} else {
ellipse(cursor.x+dim/2, cursor.y+dim/2, dim, dim);
}
cursor.add(dim, 0);
if (cursor.x >= width) {
cursor.add(-cursor.x, dim);
}
if (cursor.y >= height) {
cursor.set(0, 0);
background(192);
}
}