Montserrat Salvadó tarea 7
De Casiopea
| Título | Tarea 7 |
|---|---|
| Tipo de Proyecto | Proyecto de Curso |
| Palabras Clave | tarea 7 |
| Período | 2012-2012 |
| Asignatura | Imagen Escrita 2012, |
| Del Curso | Imagen Escrita 2012, |
| Carreras | Arquitectura |
| Alumno(s) | Montserrat Salvadó |
| Profesor | Herbert Spencer |
Insect[] ins; float margin = 70;
void setup() {
size(700, 700);
int ynum = 5;
int xnum = 5;
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(#F55BDC);
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(20, 90));
v = new float[vn][4];
tam =100;
init();
}
void init() {
w = tam/2;
h = tam;
for (int i = 0; i < vn; i++) {
v[i][0] = random(w+5);
v[i][1] = random(-h/2, h/2);
}
}
void trace() {
noFill();
stroke(0);
strokeWeight(.85);
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, 1);
trace();
}
popMatrix();
}
} void keyPressed (){
if (key == 's') { // graba
saveFrame("img/#####.jpg");
}
if (key == 'r') { // hace nueva forma , redibuja
redraw();
}
}