Mauro Herrera: Murciélagos F.H

De Casiopea
Murciélagos from hell



TítuloMurciélagos from hell
Tipo de ProyectoProyecto de Curso
Palabras Clavetarea 7
Del CursoImagen Escrita 2012,
CarrerasArquitectura
Alumno(s)Mauro Herrera
ProfesorHerbert Spencer
 

//Basado en el ejemplo del profesor Herbert Spencer y editado, se consiguen probando combinaciones figuras similares a murciélagos (y aletean!)

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; // 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(0);
  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(10, 80));
    v = new float[vn][9];
    tam = 40;
    init();
  }

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

  void trace() {
    fill(#FF0000);
    stroke(255);
    strokeWeight(.25);
    beginShape();
    vertex(v[1][0], v[1][1]);
    for (int i = 0; i < vn; i++) {
      curveVertex(v[0][1], v[i][0]);
    }
    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();
    }
  }
}