Mariana Valenzuela insectos tarea7

De Casiopea
Revisión del 12:25 24 may 2012 de Marianavr (discusión | contribs.)
(difs.) ← Revisión anterior | Revisión actual (difs.) | Revisión siguiente → (difs.)
Mariana Valenzuela tarea7



TítuloMariana Valenzuela tarea7
Tipo de ProyectoProyecto de Curso
Palabras Clavetarea 7
Del Cursoimagen escrita 2012
CarrerasArquitectura
Alumno(s)Mariana valenzuela
ProfesorHerbert Spencer
 Insect[] ins;
float margin = 30;

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

  int ynum = 9;
  int xnum = 10;

  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();
  stroke(255);
}


void draw() {
  background(#0AB0C4);
  stroke(255);
  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, 40));
    v = new float[vn][2];
    tam = 40;
    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(255);
    strokeWeight(.25);
    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(0.3, 0.1);
      trace();
    }
    popMatrix();
  }
}

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