Catalina Angulo: tarea 7

De Casiopea


Processing 7.jpg


TítuloCatalina Angulo: tarea 7
Tipo de ProyectoProyecto de Curso
Palabras Clavetarea 7
AsignaturaImagen Escrita 2012
Del CursoImagen Escrita 2012
CarrerasDiseño Gráfico, Diseño Industrial
Alumno(s)Catalina Angulo
ProfesorHerbert Spencer
Insect[] ins;
float margin = 90;

void setup() {
size(700, 700);

int ynum =6;
int xnum = 4;

ins = new Insect[ynum * xnum];

float ysp = (height - (2 * margin)) / ((float)ynum - 1);
float xsp = (width - (2 * margin)) / ((float)xnum - 1);

int c = 0; // counter

for (float y = margin; y <= height - margin; y+= ysp) {
for (float x = margin; x <= width - margin; x += xsp) {
ins[c] = new Insect(x, y);
c++;
}
}
smooth();
}

void draw() {
background(#76A00D);
for (int i = 0; i < ins.length; i++) {
ins[i].render();
}
}

class Insect {
float x, y;
float[][] v; // vertices
int vn; // número aleatorio de vértices
float tam; // tamaño
float w, h; // width, height

Insect(float y, float x) {
this.x = x;
this.y = y;
vn = round(random(20, 50));
v = new float[vn][2];
tam = 40;
init();
}

void init() {
w = tam/1;
h = tam;
for (int i = 0; i < vn; i++) {
v[i][0] = random(w);
v[i][1] = random(-h/2, h/2);
}
}

void trace() {
noFill();
stroke(15);
strokeWeight(.40);
beginShape();
vertex(v[0][0], v[0][1]);
for (int i = 0; i < vn; i++) {
curveVertex(v[i][0], v[i][1]);
}
vertex(v[vn-1][0], v[vn-1][1]);
endShape();
}

void render() {
pushMatrix();
{
translate(x, y);
trace();
scale(1, 2);
trace();
}
popMatrix();
}
}

void keyPressed() {
if (key == ' ') {
for (int i = 0; i < ins.length; i++) {
ins[i].init();
}
}
if (key == 'a') {
for (int i = 0; i < ins.length; i++) {
ins[i].tam++;
ins[i].init();
}
}
if (key == 's') {
for (int i = 0; i < ins.length; i++) {
ins[i].tam--;
ins[i].init();
}
}
}