Alex Quintanilla Insectario
De Casiopea
Título | Alex Quintanilla Insectario |
---|---|
Tipo de Proyecto | Proyecto de Curso |
Palabras Clave | tarea 7 |
Período | 2012- |
Asignatura | Imagen Escrita 2012, |
Del Curso | Imagen Escrita 2012, |
Carreras | Arquitectura |
Alumno(s) | Alex Quintanilla |
Profesor | Herbert Spencer |
Insect[] ins;
float margin = 70;
void setup() {
size(700, 700);
int ynum = 11; int xnum = 9;
ins = new Insect[ynum * xnum];
float ysp = (height - (2 * margin)) / ((float)ynum - 1); float xsp = (width - (2 * margin)) / ((float)xnum - 1);
int c = 0;
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++; } } noSmooth();
}
void draw() {
background(192, 250, 249); 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 x, float y) { this.x = x; this.y = y; vn = round(random(30, 7)); v = new float[vn][3]; tam = 68; init(); }
void init() { w = tam/1.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(71, 82, 82); strokeWeight(2); beginShape(); vertex(v[0][1], 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 == 'x') { for (int i = 0; i < ins.length; i++) { ins[i].init(); } }
}