Francisca de la Maza: Insectos 1

De Casiopea



TítuloFrancisca de la Maza tarea 7
Tipo de ProyectoProyecto de Curso
Palabras Clavetarea 7
Período2012-2012
AsignaturaImagen Escrita 2012
Del CursoImagen Escrita 2012, 1º Diseño 2012
CarrerasDiseño Gráfico, Diseño Industrial
Alumno(s)Francisca de la Maza
ProfesorHerbert Spencer


Insect[] ins; float margin =100;

void setup() {

size(700, 700);
int ynum = 11;
int xnum = 9;
ins = new Insect[ynum * xnum];
float ysp = (height - (2 * margin)) / ((float)ynum - .5);
float xsp = (width - (2 * margin)) / ((float)xnum - .5);
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(170);
for (int i = 0; i < ins.length; i++) {
  ins[i].render();
}

}


class Insect {

float x, y;
float[][] v; 
int vn; 
float tam;  
float w, h;
Insect(float x, float y) {
  this.x = x;
  this.y = y;
  vn = round(random(15, 20));
  v = new float[vn][2];
  tam = 25;
  init();
}
void init() {
  w = tam/.8;
  h = tam;
  for (int i = 0; i < vn; i++) {
    v[i][0] = random(h);
    v[i][1] = random(-h/2, h/2);
  }
}
void trace() {
  noFill();
  stroke(#415AF0);
  strokeWeight(1);
  beginShape();
  vertex(v[0][1], v[0][0]);
  for (int i = 0; i < vn; i++) {
    curveVertex(v[i][0], v[i][1]);
  }
  vertex(v[vn-2][0], v[vn-3][1]);
  endShape();
}
void render() {
  pushMatrix();
  {
    translate(x, y);
    trace();
    scale( 2, - 2);
    trace();
  }
  popMatrix();
}

}

void keyPressed() {

if (key == 'f') {
  for (int i = 0; i < ins.length; i++) {
    ins[i].tam--;// disminuir el tamaño
    ins[i].init();
  }
}
if (key == 'v') {
  for (int i = 0; i < ins.length; i++) {
    ins[i].tam++;// aumentar el tamaño
    ins[i].init();
  }
}

}