Tomas Gesell bichos
De Casiopea
Título | BICHOS tomi gesell |
---|---|
Tipo de Proyecto | Proyecto de Curso |
Palabras Clave | tarea 7, imagen escrita 2012 |
Asignatura | Taller Inicial Común 1ª y 2ª Etapa, |
Del Curso | Imagen Escrita 2012, |
Alumno(s) | Tomás Gesell |
Profesor | Herbert Spencer |
bichos[] ins; float margin = 70;
void setup() {
size(700, 700);
int ynum = 5; int xnum = 5;
ins = new bichos[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 bichos(x, y); c++; } } smooth();
}
void draw() {
background(0); for (int i = 0; i < ins.length; i++) { ins[i].render(); }
}
class bichos {
float x, y; float[][] v; int vn; float tam; float w, h;
bichos(float x, float y) { this.x = x; this.y = y; vn = round(random(10, 40)); v = new float[vn][2]; tam = 100; init(); }
void init() { w = tam/2; 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(#00FF00); strokeWeight(1); 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, 1); 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 == 'z') { for (int i = 0; i < ins.length; i++) { ins[i].tam--; ins[i].init(); } }
}