Catalina Angulo: tarea 7

De Casiopea
La versión para imprimir ya no se admite y puede contener errores de representación. Actualiza los marcadores del navegador y utiliza en su lugar la función de impresión predeterminada del navegador.
Catalina Angulo: tarea 7


TítuloCatalina Angulo: tarea 7
Tipo de ProyectoProyecto de Curso
Palabras Clavetarea 7
AsignaturaImagen Escrita 2012,
Del CursoImagen Escrita 2012,
CarrerasDiseño Gráfico"Diseño Gráfico" is not in the list (Arquitectura, Diseño, Magíster, Otra) of allowed values for the "Carreras Relacionadas" property., Diseño Industrial"Diseño Industrial" is not in the list (Arquitectura, Diseño, Magíster, Otra) of allowed values for the "Carreras Relacionadas" property.
Alumno(s)Catalina Angulo
ProfesorHerbert Spencer
Insect[] ins;
float margin = 90;

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

int ynum =6;
int xnum = 4;

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(#76A00D);
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 y, float x) {
this.x = x;
this.y = y;
vn = round(random(20, 50));
v = new float[vn][2];
tam = 40;
init();
}

void init() {
w = tam/1;
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(15);
strokeWeight(.40);
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, 2);
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 == 's') {
for (int i = 0; i < ins.length; i++) {
ins[i].tam--;
ins[i].init();
}
}
}